Laravel框架 mysql 数据库 —— 基本使用

增删改查

配置完数据库连接,就可以使用DB类进行查询了。

查询

$results = DB::select(‘select * from users where id = ?‘, array(1));

select方法会以数组形式返回查询结果。

插入

DB::insert(‘insert into users (id, name) values (?, ?)‘, array(1, ‘Dayle‘));

更新

DB::update(‘update users set votes = 100 where name = ?‘, array(‘John‘));

删除

DB::delete(‘delete from users‘);

注意:update和delete语句返回受影响的行数。

通用语句

DB::statement(‘drop table users‘);

监听Query事件

DB::listen(function($sql, $bindings, $time)
{
    //
});

数据库事务

DB::transaction(function()
{
    DB::table(‘users‘)->update(array(‘votes‘ => 1));
    DB::table(‘posts‘)->delete();
});

注意:transaction闭包中的任何异常将会导致事务自动回滚。

有时候也许你想自己开启事务:

DB::beginTransaction();

你也可以自己回滚事务:

DB::rollback();

最后,你可以通过commit方法提交事务:

DB::commit();

多个数据库连接访问

当使用多个数据库连接时,可以通过DB::connection方法访问它们:

$users = DB::connection(‘foo‘)->select(...);

你可以通过PDO实例访问原生连接:

$pdo = DB::connection()->getPdo();

有时候你需要重连数据库:

DB::reconnect(‘foo‘);

如果因为超出PDO实例的最大连接数限制而要断开连接,使用disconnect方法:

DB::disconnect(‘foo‘);

查询日志

默认情况下,Laravel使用日志记录当前请求的所有数据库查询操作,但是某些时候,比如插入大量数据,会引起应用使用过量内存。为了关闭日志,可以使用disableQuery方法:

DB::connection()->disableQueryLog();

获取查询日志记录,可以用过getQuery方法:

 $queries = DB::getQueryLog();

参考:http://nonfu.me/p/10911.html 、 http://nonfu.me/job
时间: 2024-10-14 22:51:15

Laravel框架 mysql 数据库 —— 基本使用的相关文章

laravel框架之数据库操作

1.使用DB门面进行基本操作 一旦你设置好了数据库连接,就可以使用 DB facade 来进行查找.DB facade 提供每个类型的查找方法:select.update.insert.delete.statement. 1.1增-> DB::insert('insert into users (id, name) values (?, ?)', [1, 'Dayle']); 1.2删-> $deleted = DB::delete('delete from users'); 返回值:删除的行

bottle框架学习(八)之Mysql数据库的操作

MySQLdb 是用于Python连接Mysql数据库的接口. 安装MySQLdb [[email protected] bottle]# yum install MySQL-python –y 如果使用编译安装请到这里下载安装包https://pypi.python.org/pypi/MySQL-python并执行以下命令 [[email protected] bottle]# gunzip  MySQL-python-1.2.3.tar.gz [[email protected] bottl

在Jena框架下基于MySQL数据库实现本体的存取操作

在Jena框架下基于MySQL数据库实现本体的存取操作 转自:http://blog.csdn.net/jtz_mpp/article/details/6224311 最近在做一个基于本体的管理系统.其中对本体的操作部分,我使用的是Jena框架:数据模型是基于本体的语义模型:数据存储则是MySQL 5.5.9版本.由此看来,将本体模型存入数据库和从数据库中取出模型是常用的操作,这里总结一下我学到的方法. 我使用的开发环境是Eclipse3.6,在开发前要将必要的与jena有关的类包加入java

如何实现一个php框架系列文章【6】mysql数据库

实现一个mysql数据库封装需要考虑的问题 使用方便性 采用直接sql语句操作方式.只要会写sql语句,那么将没有其他学习成本. uctphp框架提供的dba辅助封装类,用会之后将爱不释手. 使用前需要显示初始化并连接到数据库吗,当然不需要. 直到执行第一条sql语句之前,都不会去连接数据库,甚至不会new一个db对象. dba将会在合适的时机去连接数据库并执行初始化字符编码操作. 查询语句.不需要new一个查询构造器也不提供链式操作方式,那样复杂且低效. dba提供了以下的查询辅助函数. 1

在Abp框架中使用Mysql数据库的方法以及相关问题小记

最近发现了一款DDD的框架 看起来不错,据说挺流弊的 刚好最近要弄点小东西,拿来试试也不错 苦于穷逼买不起高配服务器,只好装mysql数据库了 下面说下如何在该框架下使用Mysql数据库 打开项目后,在"程序包管理器控制平台"中选择*.EntityFramwork以及*.Web项目(*号为你的项目名称前缀) Install-Package MySql.Data.Entity // Install-Package MySql.Data.Entity - 安装MySql.Data.Enti

记录一次Spring boot 搭建框架连接Mysql数据库注解事务不回滚的故障

搭建了一个新框架,使用了spring boot 替换以简化原来繁杂的spring配置,使用Spring注解管理事务,持久层使用mybatis. 连接mysql数据库完成项目的过程中发现不支持事务,因为用的新框架自己本身也不是很了解,刚开始一直以为是自己的框架搭建的有问题, 后来发现是mysql数据库引擎的问题 解决方案 MyISAM不支持事物,InnoDB支持事物 先检查你的mysql版本 ,mysql 4.0系列之前是不支持事务的.    SELECT VERSION(); 检查你的数据库支持

第9课:备份mysql数据库、重写父类、unittest框架、多线程

1. 写代码备份mysql数据库: 1)Linux下,备份mysql数据库,在shell下执行命令:mysqldump -uroot -p123456 -A >db_bak.sql即可 import os import datetime class BakDb(object): def __init__(self, ip, username, passwd, port=3306, path='/tmp/db_bak'): self.ip = ip self.username = username

maven web项目中整合ssm框架(连接Mysql数据库)

前面说完怎么样创建maven web项目,这篇继续向web项目中整合进ssm(spring+springmvc+mybatis)的框架. 先发个目录图片,让萌新们知道下面提到的文件是创建在什么地方. 1.web.xml文件 修改如下: <?xml version="1.0" encoding="UTF-8"?> <web-app version="3.0" xmlns="http://java.sun.com/xml/

Abp框架连接mysql数据库

开始想用Abp框架来搭建公司的新项目,虽然一切还没有定数,但是兵马未动,粮草先行,我先尝试一下整个过程,才能够更好的去争取机会. 此次技术选型:Abp(Asp.Net core mvc)+mysql(8.0)+docker Abp官网地址:https://aspnetboilerplate.com/ 1.Nuget中安装mysql相关包,oracle公司提供的mysql包用起来还有问题,所以现在都是用的第三方的mysql包. pomelo.entityframeworkcore.mysql po