一、读/写连接
有时您可能希望使用一个SELECT语句的数据库连接,,另一个用于插入、更新和删除语句。Laravel使这微风,将始终使用正确的连接是否使用原始查询,查询生成器或雄辩的ORM。
如何读/写连接应该配置,让我们看看这个例子:
复制代码 代码如下:
'mysql' => array('read' => array('host' => '19216811'),'write' => array('host' => '19616812'),'driver' => 'mysql','database' =>'database','username' => 'root','password' => '','charset' => 'utf8','collation' => 'utf8_unicode_ci','prefix' => '')
注意,两个键添加到配置阵列:读和写。这两个键有数组值包含一个关键:主机。其余的读写数据库选项从主mysql连接将合并后的数组。所以,我们只需要将物品放入读取和写入数组如果我们希望覆盖主要数组中的值。所以,在这种情况下,19216811将被用作“读”连接,while19216812将被用作“写”连接。数据库凭证、前缀、字符集和所有其他选项在主mysql数组将跨两个共享连接。
二、运行查询
一旦你已经配置了数据库连接,你可以使用DB运行查询类。
运行一个Select查询
复制代码 代码如下:
$results = DB::select('select from users where id = ', array(1));
结果的选择方法总是返回一个数组。
运行一个Insert语句
复制代码 代码如下:
DB::insert('insert into users (id, name) values (, )', array(1, 'Dayle'));
运行一个更新语句
复制代码 代码如下:
DB::update('update users set votes = 100 where name = ', array('John'));
运行一个Delete语句
复制代码 代码如下:
DB::delete('delete from users');
注意:update和delete语句返回的行数的影响 *** 作。
运行一个通用声明
复制代码 代码如下:
DB::statement('drop table users');
查询事件监听
你可以查询事件监听使用DB::听方法:
复制代码 代码如下:
DB::listen(function($sql, $bindings, $time){ //});
三、数据库事务
运行在一个数据库事务的一组 *** 作,您可以使用事务方法:
复制代码 代码如下:
DB::transaction(function(){ DB::table('users')->update(array('votes'
=> 1)); DB::table('posts')->delete();});
注意:在事务抛出的任何异常关闭将导致自动事务将回滚
有时你可能需要开始一个事务:
复制代码 代码如下:
DB::beginTransaction();
你可以通过回滚事务回滚方法:
复制代码 代码如下:
DB::rollback();
最后,您可以通过提交方法:提交一个事务
复制代码 代码如下:
DB::commit();
四、访问连接
当使用多个连接,你可以访问它们通过DB::连接方法:
复制代码 代码如下:
$users = DB::connection('foo')->select();
你也可以访问原始的、潜在的PDO实例:
复制代码 代码如下:
$pdo = DB::connection()->getPdo();
有时你可能需要重新连接到一个给定的数据库:
复制代码 代码如下:
DB::reconnect('foo');
如果你需要断开从给定的数据库将超过底层PDO实例'smax_connections限制,使用断开连接方法:
复制代码 代码如下:
DB::disconnect('foo');
五、查询日志
默认情况下,Laravel日志保存在内存的所有查询运行当前的请求。然而,在某些情况下,例如当插入的行数,这可能会导致应用程序使用多余的内存。禁用日志,你可以使用disableQueryLog方法:
复制代码 代码如下:
DB::connection()->disableQueryLog();
o得到一组执行的查询,您可以使用getQueryLog方法:
复制代码 代码如下:
$queries = DB::getQueryLog();
、Bundle是Laravel的扩展包组织形式或称呼。Laravel的扩展包仓库已经相当成熟了,可以很容易的帮你把扩展包(bundle)安装到你的应用中。你可以选择下载一个扩展包(bundle)然后拷贝到bundles目录,或者通过命令行工具“Artisan”自动安装。
2、在Laravel中已经具有了一套高级的PHP ActiveRecord实现 -- Eloquent ORM。它能方便的将“约束(constraints)”应用到关系的双方,这样你就具有了对数据的完全控制,而且享受到ActiveRecord的所有便利。Eloquent原生支持Fluent中查询构造器(query-builder)的所有方法。
3、应用逻辑(Application Logic)可以在控制器(controllers)中实现,也可以直接集成到路由(route)声明中,并且语法和Sinatra框架类似。Laravel的设计理念是:给开发者以最大的灵活性,既能创建非常小的网站也能构建大型的企业应用。
表名问题不大,关键是你的表是适合MVC结构的,spring应该差不多,要玩转laravel,还是要使用Eloquent ORM,这样你需要给你的表建立对应的entity(也就是model),然后通过model建立好表间关系。另外有个插件可以 从现有的表 直接生成 migration
Laravel框架中的DB类让我们可以方便的进行数据库 *** 作,比如常见的query查询:
DB::query('SELECT FROM users');
Larvel还提供了类似CI框架中Active Record的Fluent Query Builder : DB::table('user')->where('id','=','1')->get();
虽然从 *** 作上和普通查询相差不大,但是需要注意到是Laravel的查询结果和原生查询不同。
简单建立一个contents表测试下,表里有content字段,我们查询一下:
$content = DB::table('contents')->where('id','=','1')->get();
最后打印一下$content变量看看有什么不同:
array(1)
{
[0]=> object(stdClass)#31 (1) {
["content"]=> string(24) "这是一个测试~~" }
}
从上面可以知道查询的结果是一个包含对象的数组,因此我们要取得content值就必须先迭代:
foreach($contents as $content)
{ echo $content->content;
}
总体来说Laravel的数据库 *** 作很容易上手。
laravel框架 这个我倒是没用过 但是 框架应该 有属性设置的,如果你的框架 安装的时候 默认GBK 创建项目的时候 UTF8 PHP 基本用这个 所以会乱码,调节下你的1框架默认编码格式
OQL是我设计用来处理PDFNET开发框架的ORM查询的,因此叫做ORM查询语言。自2006年第一版以来,经历了多次重构,到PDFNET Ver 4X 版本,已经比较稳定了,在我做的项目和框架用户朋友的项目中得到成功应用,基本符合一般的常规应用需求。
OQL有下面3个显著特点:
抽象的SQL,屏蔽了具体数据库的差异,因此支持所有数据库;
对象化的“SQL”,写OQL代码能够获得IDE的智能提示,能够得到编译时检查确保不会写出错误的SQL;
没有使用NET的特性,比如泛型、反射、表达式树等东西,因此理论上OQL可以跨语言平台,比如移植到Java,C++,VB等。
OQL的原理基于2大特性:
表达式的链式调用
属性的实例调用
OQL支持4大类数据 *** 作
数据查询:
单实体类(单表)查询
多实体类(多表)关联查询
数据修改
更新数据
删除数据
统计、聚合运算
OQL分页
首先将项目拷贝至Web服务器的文档目录下,比如 /laravel,假设你服务器的本地地址为>
vhostsconf
<VirtualHost :80>ServerAdmin local@devcom
DocumentRoot "/;
hosts
127001 localdevcom经过以上配置后,重启服务器,就可以通过>
2 如果存在数据库,需要对数据库做一下设定。首先,根据/app/config/databasephp中的设定建立数据库。如果项目提供了数据库的DDL SQL文,那么直接将其导入数据库。如果是Laravel的Migrations,那么直接在项目根目录运行如下artisan命令:
php artisan migrate大概以上两步就足够了,如果项目还有其他设定需要,可参考他们的文档。
\vendor\laravel\framework\src\Illuminate\Database\Connectionphp
public function select($query, $bindings = [], $useReadPdo = true){}
$useReadPdo 执行查询语句时指定为false即可
以上就是关于laravel *** 作数据库需要判断是否成功吗全部的内容,包括:laravel *** 作数据库需要判断是否成功吗、laravel用的是什么数据库、打算使用laravel现有的数据库上做开发,会有哪些坑等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)