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在Web开发领域的优势
Oct 09 PHP
MYSQL 小技巧 -- LAST_INSERT_ID
Nov 24 PHP
PHP改进计算字符串相似度的函数similar_text()、levenshtein()
Oct 27 PHP
php常见的魔术方法详解
Dec 25 PHP
网站防止被刷票的一些思路与方法
Jan 08 PHP
php实现根据词频生成tag云的方法
Apr 17 PHP
PHP实现无限级分类(不使用递归)
Oct 22 PHP
php实现文件管理与基础功能操作
Mar 21 PHP
PHP中register_shutdown_function函数的基础介绍与用法详解
Nov 28 PHP
PHP PDOStatement::fetch讲解
Jan 31 PHP
PHP使用JpGraph绘制折线图操作示例【附源码下载】
Oct 18 PHP
Yii框架小部件(Widgets)用法实例详解
May 15 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
PHP关联数组实现根据元素值删除元素的方法
2015/06/26 PHP
php获得刚插入数据的id 的几种方法总结
2018/05/31 PHP
解决windows上php xdebug 无法调试的问题
2020/02/19 PHP
[原创]用javascript实现检测指定目录是否存在的方法
2008/01/12 Javascript
使用SyntaxHighlighter实现HTML高亮显示代码的方法
2010/02/04 Javascript
基于Asp.net与Javascript控制的日期控件
2010/05/22 Javascript
js加载之使用DOM方法动态加载Javascript文件
2013/11/08 Javascript
javascript实现根据3原色制作颜色选择器的方法
2015/07/17 Javascript
浅谈JavaScript中的string拥有方法的原因
2015/08/28 Javascript
浅谈JavaScript的内置对象和浏览器对象
2016/06/03 Javascript
javascript弹出带文字信息的提示框效果
2016/07/19 Javascript
使用vue.js实现checkbox的全选和多个的删除功能
2017/02/17 Javascript
详解JS中的立即执行函数
2017/02/24 Javascript
vue2.0全局组件之pdf详解
2017/06/26 Javascript
vue proxyTable 接口跨域请求调试的示例
2017/09/12 Javascript
vue中如何创建多个ueditor实例教程
2017/11/14 Javascript
vue中eslintrc.js配置最详细介绍
2018/12/21 Javascript
详解JS函数防抖
2020/06/05 Javascript
关于angular浏览器兼容性问题的解决方案
2020/07/26 Javascript
Vue中强制组件重新渲染的正确方法
2021/01/03 Vue.js
[04:15]DOTA2-DPC中国联赛1月19日Recap集锦
2021/03/11 DOTA
python实现数组插入新元素的方法
2015/05/22 Python
python xml解析实例详解
2016/11/14 Python
Python生成器generator用法示例
2018/08/10 Python
Python实现12306火车票抢票系统
2019/07/04 Python
pytorch 实现查看网络中的参数
2020/01/06 Python
TensorFlow中如何确定张量的形状实例
2020/06/23 Python
PyCharm2019 安装和配置教程详解附激活码
2020/07/31 Python
python爬虫构建代理ip池抓取数据库的示例代码
2020/09/22 Python
如何将anaconda安装配置的mmdetection环境离线拷贝到另一台电脑
2020/10/15 Python
家居设计专业个人自荐信范文
2013/11/26 职场文书
解放思想演讲稿
2014/09/11 职场文书
党支部鉴定意见
2015/06/02 职场文书
python利用pandas分析学生期末成绩实例代码
2021/07/09 Python
如何避免mysql启动时错误及sock文件作用分析
2022/01/22 MySQL
Python可视化神器pyecharts之绘制箱形图
2022/07/07 Python