找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1977|回复: 0
打印 上一主题 下一主题

PHP开发框架Laravel数据库操作方法总结

[复制链接]

2647

主题

2647

帖子

7881

积分

论坛元老

Rank: 8Rank: 8

积分
7881
跳转到指定楼层
楼主
发表于 2018-2-14 05:54:48 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            一、读/写连接
有时您可能希望使用一个SELECT语句的数据库连接,,另一个用于插入、更新和删除语句。Laravel使这微风,将始终使用正确的连接是否使用原始查询,查询生成器或雄辩的ORM。
如何读/写连接应该配置,让我们看看这个例子:
[U]复制代码[/U] 代码如下:
'mysql' => array('read' => array('host' => '192.168.1.1'),'write' => array('host' => '196.168.1.2'),'driver' => 'mysql','database' =>'database','username' => 'root','password' => '','charset' => 'utf8','collation' => 'utf8_unicode_ci','prefix' => '')
注意,两个键添加到配置阵列:读和写。这两个键有数组值包含一个关键:主机。其余的读写数据库选项从主mysql连接将合并后的数组。所以,我们只需要将物品放入读取和写入数组如果我们希望覆盖主要数组中的值。所以,在这种情况下,192.168.1.1将被用作“读”连接,while192.168.1.2将被用作“写”连接。数据库凭证、前缀、字符集和所有其他选项在主mysql数组将跨两个共享连接。
二、运行查询
一旦你已经配置了数据库连接,你可以使用DB运行查询类。
运行一个Select查询
[U]复制代码[/U] 代码如下:
$results = DB::select('select * from users where id = ?', array(1));
结果的选择方法总是返回一个数组。
运行一个Insert语句
[U]复制代码[/U] 代码如下:
  DB::insert('insert into users (id, name) values (?, ?)', array(1, 'Dayle'));
运行一个更新语句
[U]复制代码[/U] 代码如下:
  DB::update('update users set votes = 100 where name = ?', array('John'));
运行一个Delete语句
[U]复制代码[/U] 代码如下:
DB::delete('delete from users');
注意:update和delete语句返回的行数的影响操作。
运行一个通用声明
[U]复制代码[/U] 代码如下:
DB::statement('drop table users');
查询事件监听
你可以查询事件监听使用DB::听方法:
[U]复制代码[/U] 代码如下:
DB::listen(function($sql, $bindings, $time){ //});
三、数据库事务
  运行在一个数据库事务的一组操作,您可以使用事务方法:
[U]复制代码[/U] 代码如下:
 DB::transaction(function(){ DB::table('users')->update(array('votes'
=> 1)); DB::table('posts')->delete();});
注意:在事务抛出的任何异常关闭将导致自动事务将回滚
有时你可能需要开始一个事务:
[U]复制代码[/U] 代码如下:
DB::beginTransaction();
你可以通过回滚事务回滚方法:
[U]复制代码[/U] 代码如下:
DB::rollback();
最后,您可以通过提交方法:提交一个事务
[U]复制代码[/U] 代码如下:
DB::commit();
四、访问连接
当使用多个连接,你可以访问它们通过DB::连接方法:
[U]复制代码[/U] 代码如下:
$users = DB::connection('foo')->select(...);
你也可以访问原始的、潜在的PDO实例:
[U]复制代码[/U] 代码如下:
$pdo = DB::connection()->getPdo();
有时你可能需要重新连接到一个给定的数据库:
[U]复制代码[/U] 代码如下:
DB::reconnect('foo');
如果你需要断开从给定的数据库将超过底层PDO实例'smax_connections限制,使用断开连接方法:
[U]复制代码[/U] 代码如下:
DB::disconnect('foo');
五、查询日志
默认情况下,Laravel日志保存在内存的所有查询运行当前的请求。然而,在某些情况下,例如当插入的行数,这可能会导致应用程序使用多余的内存。禁用日志,你可以使用disableQueryLog方法:
[U]复制代码[/U] 代码如下:
DB::connection()->disableQueryLog();
o得到一组执行的查询,您可以使用getQueryLog方法:
[U]复制代码[/U] 代码如下:
$queries = DB::getQueryLog();
            
            
您可能感兴趣的文章:
  • PHP框架Laravel的小技巧两则
  • PHP开发框架laravel安装与配置教程
  • ThinkPHP、ZF2、Yaf、Laravel框架路由大比拼
  • Nginx中运行PHP框架Laravel的配置文件分享
  • 全面解读PHP的人气开发框架Laravel
  • 详解PHP的Laravel框架中Eloquent对象关系映射使用
  • PHP的Laravel框架中使用消息队列queue及异步队列的方法
  • PHP的Laravel框架结合MySQL与Redis数据库的使用部署
  • 深入解析PHP的Laravel框架中的event事件操作
  • 详解php语言最牛掰的Laravel框架
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端