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 相关文章推荐
javascript 小型动画组件与实现代码
Jun 02 PHP
php whois查询API制作方法
Jun 23 PHP
用PHP实现Ftp用户的在线管理
Feb 16 PHP
PHP 万年历实现代码
Oct 18 PHP
php实现的短网址算法分享
Jun 20 PHP
ajax+php控制所有后台函数调用
Jul 15 PHP
PHP封装CURL扩展类实例
Jul 28 PHP
PHP邮件群发机实现代码
Feb 16 PHP
PHP Static延迟静态绑定用法分析
Mar 16 PHP
PHP cookie与session会话基本用法实例分析
Nov 18 PHP
thinkphp框架实现路由重定义简化url访问地址的方法分析
Apr 04 PHP
php + ajax 实现的写入数据库操作简单示例
May 16 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
神族 PROTOSS 概述
2020/03/14 星际争霸
destoon在各个服务器下设置URL Rewrite(伪静态)的方法
2014/06/21 Servers
使用PHP实现下载CSS文件中的图片
2015/12/06 PHP
window.onload 加载完毕的问题及解决方案(上)
2009/07/09 Javascript
Mootools 1.2教程(2) DOM选择器
2009/09/14 Javascript
Javascript 设计模式(二) 闭包
2010/05/26 Javascript
jQuery创建插件的代码分析
2011/04/14 Javascript
jquery 之 $().hover(func1, funct2)使用方法
2012/06/14 Javascript
checkbox使用示例
2013/08/23 Javascript
js采用map取到id集合组并且实现点击一行选中一行
2013/12/16 Javascript
javascript+canvas制作九宫格小程序
2014/12/28 Javascript
js实现同一页面多个不同运动效果的方法
2015/04/10 Javascript
最简单纯JavaScript实现Tab标签页切换的方式(推荐)
2016/07/25 Javascript
简单实现jQuery多选框功能
2017/01/09 Javascript
vue-i18n实现中英文切换的方法
2020/07/06 Javascript
Vue使用screenfull实现全屏效果
2020/09/17 Javascript
python encode和decode的妙用
2009/09/02 Python
python的正则表达式re模块的常用方法
2013/03/09 Python
python连接数据库的方法
2017/10/19 Python
对pandas中两种数据类型Series和DataFrame的区别详解
2018/11/12 Python
Python3.4学习笔记之常用操作符,条件分支和循环用法示例
2019/03/01 Python
Python实现Linux监控的方法
2019/05/16 Python
Python OpenCV中的resize()函数的使用
2019/06/20 Python
Python自定义一个异常类的方法
2019/06/27 Python
Python实现微信小程序支付功能
2019/07/25 Python
Python绘制热力图示例
2019/09/27 Python
Windows平台Python编程必会模块之pywin32介绍
2019/10/01 Python
CSS3解决移动页面上点击链接触发色块的问题
2016/06/03 HTML / CSS
创业大赛策划书
2014/03/01 职场文书
房屋委托书范本
2014/04/04 职场文书
原料仓管员岗位职责
2014/04/12 职场文书
销售顾问工作计划书
2014/08/15 职场文书
三严三实心得体会范文
2014/10/13 职场文书
实施意见格式范本
2015/06/05 职场文书
利用Python读取微信朋友圈的多种方法总结
2021/08/23 Python
分享Python异步爬取知乎热榜
2022/04/12 Python