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

 更新时间:2014年09月03日 11:16:24   投稿:junjie  
这篇文章主要介绍了PHP开发框架Laravel数据库操作方法总结,包含Select查询、Insert语句、update语句、Delete语句、事务等,需要的朋友可以参考下

一、读/写连接

有时您可能希望使用一个SELECT语句的数据库连接,,另一个用于插入、更新和删除语句。Laravel使这微风,将始终使用正确的连接是否使用原始查询,查询生成器或雄辩的ORM。

如何读/写连接应该配置,让我们看看这个例子:

复制代码 代码如下:

'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查询

复制代码 代码如下:

$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();

相关文章

  • PHP实现的多彩标签效果代码分享

    PHP实现的多彩标签效果代码分享

    这篇文章主要介绍了PHP实现的多彩标签效果代码分享,经常可以看到一些博客中的标签(TAGS)页面是彩色的效果展现,本文就给出了实现这个功能的PHP代码,需要的朋友可以参考下
    2014-08-08
  • php侧拉菜单 漂亮,可以向右或者向左展开,支持FF,IE

    php侧拉菜单 漂亮,可以向右或者向左展开,支持FF,IE

    其中menu UL UL的left或者right控制向右或者向左显示子菜单
    2009-10-10
  • PHP 使用memcached简单示例分享

    PHP 使用memcached简单示例分享

    在很多场合,我们都会听到 memcached 这个名字,但很多同学只是听过,并没有用过或实际了解过,只知道它是一个很不错的东东。这里简单介绍一下,memcached 是高效、快速的分布式内存对象缓存系统,主要用于加速WEB动态应用程序。今天我们就先来简单探讨下memcached的用法
    2015-03-03
  • PHP中常见的错误与异常处理总结大全

    PHP中常见的错误与异常处理总结大全

    任何程序员在开发时都可能遇到过一些失误,或其他原因造成错误的发生。当然,用户如果不愿意或不遵循应用程序的约束,也会在使用时引起一些错误发生。下面这篇文章主要给大家介绍了关于PHP中常见的错误与异常处理,需要的朋友可以参考下,
    2017-08-08
  • Laravel5.1 框架模型查询作用域定义与用法实例分析

    Laravel5.1 框架模型查询作用域定义与用法实例分析

    这篇文章主要介绍了Laravel5.1 框架模型查询作用域定义与用法,结合实例形式分析了laravel5.1定义一个查询作用域及动态的查询作用域相关操作技巧,需要的朋友可以参考下
    2020-01-01
  • 初识Laravel

    初识Laravel

    最近因为项目问题,接触到了Laravel框架,说说自己的使用感受吧。
    2014-10-10
  • php 发送带附件邮件示例

    php 发送带附件邮件示例

    php发送邮件,在网上会很多的相关文章,而本文为大家介绍的是发送带附件邮件,不了解的朋友可以参考下
    2014-01-01
  • php截取字符串函数分享

    php截取字符串函数分享

    这里给大家分享的是一个使用php截取字符串的函数,非常实用,推荐给有需要的小伙伴。
    2015-02-02
  • php 生成自动创建文件夹并上传文件的示例代码

    php 生成自动创建文件夹并上传文件的示例代码

    本篇文章主要是对php生成自动创建文件夹并上传文件的示例代码进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2014-03-03
  • PHP 接入支付宝即时到账功能

    PHP 接入支付宝即时到账功能

    这篇文章主要介绍了PHP 接入支付宝即时到账功能,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-09-09

最新评论