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


Posted in PHP onSeptember 03, 2014

一、读/写连接

有时您可能希望使用一个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容易被忽略而出错陷阱 数字与字符串比较
Nov 10 PHP
深入PHP与浏览器缓存的分析
Jun 03 PHP
php判断电脑访问、手机访问的例子
May 10 PHP
phpmailer发送邮件之后,返回收件人是否阅读了邮件的方法
Jul 19 PHP
php+mysqli使用预处理技术进行数据库查询的方法
Jan 28 PHP
php将数组存储为文本文件方法汇总
Oct 28 PHP
PHP实现的一致性Hash算法详解【分布式算法】
Mar 31 PHP
Laravel框架实现利用监听器进行sql语句记录功能
Jun 06 PHP
php中的explode()函数实例介绍
Jan 18 PHP
Yii 使用intervention/image拓展实现图像处理功能
Jun 22 PHP
laravel 使用auth编写登录的方法
Sep 30 PHP
解决PHP使用CURL发送GET请求时传递参数的问题
Oct 11 PHP
Fedora下安装php Redis扩展笔记
Sep 03 #PHP
使用YUI+Ant 实现JS CSS压缩
Sep 02 #PHP
在Ubuntu 14.04上部署 PHP 环境及 WordPress
Sep 02 #PHP
PHP高级编程实例:编写守护进程
Sep 02 #PHP
php输入流php://input使用浅析
Sep 02 #PHP
php获取URL中带#号等特殊符号参数的解决方法
Sep 02 #PHP
PHP中提问频率最高的11个面试题和答案
Sep 02 #PHP
You might like
全国FM电台频率大全 - 5 内蒙古自治区
2020/03/11 无线电
php中url函数介绍及使用示例
2014/02/13 PHP
php图像处理类实例
2015/07/28 PHP
利用ajax和PHP实现简单的流程管理
2017/03/23 PHP
php 策略模式原理与应用深入理解
2019/09/25 PHP
laravel 框架实现无限级分类的方法示例
2019/10/31 PHP
地震发生中逃生十大法则
2008/05/12 Javascript
document.body.scrollTop 值总为0的解决方法 比较常见的标准问题
2009/11/30 Javascript
JavaScript中变量提升 Hoisting
2012/07/03 Javascript
javascript实现漂亮的拖动层,窗口拖拽特效
2015/04/24 Javascript
基于html5和nodejs相结合实现websocket即使通讯
2015/11/19 NodeJs
js实现的彩色方块飞舞奇幻效果
2016/01/27 Javascript
Bootstrap 模态框(Modal)插件代码解析
2016/12/21 Javascript
Javascript仿京东放大镜的效果
2017/03/01 Javascript
vue mintui-Loadmore结合实现下拉刷新和上拉加载示例
2017/10/12 Javascript
Vue2 配置 Axios api 接口调用文件的方法
2017/11/13 Javascript
通过vue-router懒加载解决首次加载时资源过多导致的速度缓慢问题
2018/04/08 Javascript
重新认识vue之事件阻止冒泡的实现
2018/08/02 Javascript
浅谈Vue页面级缓存解决方案feb-alive(上)
2019/04/14 Javascript
python mysqldb连接数据库
2009/03/16 Python
python读取注册表中值的方法
2013/04/08 Python
Python实现类继承实例
2014/07/04 Python
Python中的MongoDB基本操作:连接、查询实例
2015/02/13 Python
Python基于select实现的socket服务器
2016/04/13 Python
python编程实现归并排序
2017/04/14 Python
详解python函数传参是传值还是传引用
2018/01/16 Python
css3 响应式媒体查询的示例代码
2019/09/25 HTML / CSS
css3通过scale()、rotate()实现放大、旋转
2020/03/19 HTML / CSS
HTML5 本地存储之如果没有数据库究竟会怎样
2013/04/25 HTML / CSS
优质的学校老师推荐信
2013/10/28 职场文书
外贸业务员岗位职责
2013/11/24 职场文书
《开国大典》教学反思
2014/04/19 职场文书
小学优秀教育工作者事迹材料
2014/05/09 职场文书
2014年员工工作总结范文
2014/11/18 职场文书
2015入党自传格式范文
2015/06/26 职场文书
Python用tkinter实现自定义记事本的方法详解
2022/03/31 Python