文档章节

Laravel框架数据库CURD操作、连贯操作使用方法

 时间财富网
发布于 2016/11/22 09:31
字数 1401
阅读 553
收藏 14
点赞 2
评论 1

Laravel框架数据库CURD操作、连贯操作使用方法
Laravel框架数据库CURD操作、连贯如何来操作了这个操作性是非常的方便简单了我们在这里来为各位介绍一篇相关的教程,具体的细节步骤如下文介绍。
Laravel是一套简洁、优雅的PHP Web开发框架(PHP Web Framework)。它可以让你从面条一样杂乱的代码中解脱出来;它可以帮你构建一个完美的网络APP,而且每行代码都可以简洁、富于表达力。
一、Selects
检索表中的所有行
$users = DB::table('users')->get();
foreach ($users as $user)
{
var_dump($user->name);
}
从表检索单个行
$user = DB::table('users')->where('name', 'John')->first();
var_dump($user->name);
检索单个列的行
$name = DB::table('users')->where('name', 'John')->pluck('name');
检索一个列值列表
$roles = DB::table('roles')->lists('title');
该方法将返回一个数组标题的作用。你也可以指定一个自定义的键列返回的数组
$roles = DB::table('roles')->lists('title', 'name');
 
指定一个Select子句
$users = DB::table('users')->select('name', 'email')->get();
$users = DB::table('users')->distinct()->get();
$users = DB::table('users')->select('name as user_name')->get();
Select子句添加到一个现有的查询
$query = DB::table('users')->select('name');
$users = $query->addSelect('age')->get();
where
$users = DB::table('users')->where('votes', '>', 100)->get();
OR
$users = DB::table('users')->where('votes', '>', 100)->orWhere('name', 'John')->get();
 
Where Between
$users = DB::table('users')->whereBetween('votes', array(1, 100))->get();
 
Where Not Between
$users = DB::table('users')->whereNotBetween('votes', array(1, 100))->get();
 
Where In With An Array
$users = DB::table('users')->whereIn('id', array(1, 2, 3))->get();
$users = DB::table('users')->whereNotIn('id', array(1, 2, 3))->get();
 
Using Where Null To Find Records With Unset Values
$users = DB::table('users')->whereNull('updated_at')->get();
 
Order By, Group By, And Having
$users = DB::table('users')->orderBy('name', 'desc')->groupBy('count')->having('count', '>', 100)->get();
Offset & Limit
$users = DB::table('users')->skip(10)->take(5)->get();
二、连接
Joins
查询构建器也可以用来编写连接语句。看看下面的例子:
DB::table('users')
->join('contacts', 'users.id', '=', 'contacts.user_id')
->join('orders', 'users.id', '=', 'orders.user_id')
->select('users.id', 'contacts.phone', 'orders.price')
->get();
左连接语句
DB::table('users')
->leftJoin('posts', 'users.id', '=', 'posts.user_id')
->get();
DB::table('users')
->join('contacts', function($join)
{
$join->on('users.id', '=', 'contacts.user_id')->orOn(...);
})
->get();
DB::table('users')
->join('contacts', function($join)
{
$join->on('users.id', '=', 'contacts.user_id')
->where('contacts.user_id', '>', 5);
})
->get();
 
三、分组
有时候,您可能需要创建更高级的where子句,如“存在”或嵌套参数分组。Laravel query builder可以处理这些:
DB::table('users')
->where('name', '=', 'John')
->orWhere(function($query)
{
$query->where('votes', '>', 100)
->where('title', '<>', 'Admin');
})
->get();
 
上面的查询将产生以下SQL:
select * from users where name = 'John' or (votes > 100 and title
<> 'Admin')
Exists Statements
DB::table('users')
->whereExists(function($query)
{
$query->select(DB::raw(1))
->from('orders')
->whereRaw('orders.user_id = users.id');
})
->get();
上面的查询将产生以下SQL:
select * from userswhere exists (
select 1 from orders where orders.user_id = users.id
)
 
四、聚合
查询构建器还提供了各种聚合方法,如统计,马克斯,min,avg和总和。
$users = DB::table('users')->count();
$price = DB::table('orders')->max('price');
$price = DB::table('orders')->min('price');
$price = DB::table('orders')->avg('price');
$total = DB::table('users')->sum('votes');
Raw Expressions
有时您可能需要使用一个原始表达式的查询。这些表达式将注入的查询字符串,所以小心不要创建任何SQL注入点!创建一个原始表达式,可以使用DB:rawmethod:
Using A Raw Expression
$users = DB::table('users')
->select(DB::raw('count(*) as user_count, status'))
->where('status', '<>', 1)
->groupBy('status')
->get();
 
递增或递减一个列的值

DB::table('users')->increment('votes');
DB::table('users')->increment('votes', 5);
DB::table('users')->decrement('votes');
DB::table('users')->decrement('votes', 5);
 
您还可以指定额外的列更新:

DB::table('users')->increment('votes', 1, array('name' => 'John'));
 
Inserts
将记录插入表
DB::table('users')->insert(
array('email' => 'john@example.com', 'votes' => 0)
);
 
将记录插入表自动增加的ID
如果表,有一个自动递增的id字段使用insertGetId插入一个记录和检索id:
1
2
3
$id = DB::table('users')->insertGetId(
array('email' => 'john@example.com', 'votes' => 0)
);
 
注意:当使用PostgreSQL insertGetId方法预计,自增列被命名为“id”。
多个记录插入到表中
代码如下:
DB::table('users')->insert(array(
array('email' => 'taylor@example.com', 'votes' => 0),
array('email' => 'dayle@example.com', 'votes' => 0),
));
 
四、Updates
更新一个表中的记录
代码如下:
DB::table('users')
->where('id', 1)
->update(array('votes' => 1));
 
五、 Deletes
删除表中的记录
代码如下:
DB::table('users')->where('votes', '<', 100)->delete();
 
删除表中的所有记录
代码如下:
DB::table('users')->delete();
删除一个表
 
代码如下:
 
DB::table('users')->truncate();
 
六、Unions
查询构建器还提供了一种快速的方法来“联盟”两个查询:
 
代码如下:
$first = DB::table('users')->whereNull('first_name');
$users =
DB::table('users')->whereNull('last_name')->union($first)->get();
 
unionAll方法也可以,有相同的方法签名。
Pessimistic Locking
查询构建器包括一些“悲观锁定”功能来帮助你做你的SELECT语句。  运行SELECT语句“共享锁”,你可以使用sharedLock方法查询:
代码如下:
DB::table('users')->where('votes', '>',
100)->sharedLock()->get();
更新“锁”在一个SELECT语句,您可以使用lockForUpdate方法查询:
 
代码如下:
 
DB::table('users')->where('votes', '>', 100)->lockForUpdate()->get();
 
七、缓存查询
你可以轻松地缓存查询的结果使用记忆法:
代码如下:
$users = DB::table('users')->remember(10)->get();
在本例中,查询的结果将为十分钟被缓存。查询结果缓存时,不会对数据库运行,结果将从默认的缓存加载驱动程序指定您的应用程序。  如果您使用的是支持缓存的司机,还可以添加标签来缓存:
 
代码如下:
 
$users = DB::table('users')->cacheTags(array('people', 'authors'))->remember(10)->get();
需要更多PHP资讯可以关注时间财富网。

© 著作权归作者所有

共有 人打赏支持
粉丝 2
博文 37
码字总数 57314
作品 0
成都
加载中

评论(1)

首席技师
首席技师
多好的ORM放着不用可惜!
zfeig/laravel-blog

基于laravel4.2开发的博客系统,完善的前台和后台 前端采用bootstrap响应式布局,后端手写普通布局,以及artdailog弹窗,构建了简单简洁的后台界面,实现了文章,文章标签,文章分类,文章搜...

zfeig
2016/04/28
0
0
ThinkPHP 连贯操作详解

ThinkPHP 连贯操作 连贯操作是 ThinkPHP 极富特色的一大特性,在使用连贯操作进行数据库操作时,就像玩游戏搭积木一样容易:嗯,程序编写就应该如此简洁而容易才对。 连贯操作的一个例子: ...

ywppengpeng
2016/11/30
9
0
laravel的安装和curd操作

第一部分:部署 使用composer创建项目:在www根目录下,执行命令:composer create-project laravel/laravel --prefer-dist;命令执行完成后会在www目录下创建一个名为laravel的文件夹,其中...

笨小熊
2016/09/22
83
0
如何才能算得上一个PHP大师?

作为一名PHPer,如何定位自己的水平如何呢?我想很多在学习Php的朋友肯定会有疑问,自己的水平如何,去公司能拿多少薪资。根据我多年PHP水群经验,总结出一些经验。 入门 初记得自己刚入门的...

阿牧的日记
06/10
0
0
ThinkPHP 学习笔记 (二) Model模型操作

一、Model类中的部分属性意义及设定 tableName 属性 当表前缀和系统设置的前缀(DB_PREFIX)一致而表名和模型名称不一致时,可设置此属性,例如表名称为 users ,而模型名称为 UserModel ,那...

bugyang
2013/02/19
0
0
ThinkPHP框架安全实现分析

ThinkPHP框架是国内比较流行的PHP框架之一,虽然跟国外的那些个框架没法比,但优点在于,恩,中文手册很全面。最近研究SQL注入,之前用TP框架的时候因为底层提供了安全功能,在开发过程中没怎...

simple简单
2016/12/23
0
0
Laravel框架数据库CURD操作\连贯操作

一、Selects 检索表中的所有行: $users = DB::table('users')->get(); foreach ($users as $user){ var_dump($user->name); } 从表检索单个行: $user = DB::table('users')->where('name', '......

笨小熊
2016/09/22
19
0
ThinkPHP 3.2.3 正式版发布

ThinkPHP 3.2.3版本发布 ThinkPHP3.2.3版本是一个优化和修正版本,比3.2.2更加稳定、高效和安全,主要更新如下: [ 更新 ] [ 数据库方面 ] 数据库驱动完全用PDO重写; 支持通用insertAll方法...

流年
2014/12/24
9.9K
36
eric_1989/jfire-sql

#Jfire-Sql框架 [TOC] ##框架说明## Jfire-sql是一个sql映射框架,通过将一个接口方法和sql语句绑定,来达到调用方法就是发出sql语句的目的。框架提供了透明自动的结果到对象,对象集合的转换...

eric_1989
2015/09/02
0
0
ThinkPHP扩展,实现Redis的CURD操作。

接下为将以ThinkPHP作为MVC开发框架,详细介绍Redis的CURD操作。需要说明 的是,在ThinkPHP中本身并不支持Redis开发环境,只支持使用Redis开发简单的数据缓存功能。所以我们必须要通过扩展功...

peasant
2016/11/28
42
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

shell中的函数、shell中的数组、告警系统需求分析

shell中的函数 格式: 格式: function f_name() { command } 函数必须要放在最前面 示例1(用来打印参数) 示例2(用于定义加法) 示例3(用于显示IP) shell中的数组 shell中的数组1 定义数...

Zhouliang6
今天
2
0
用 Scikit-Learn 和 Pandas 学习线性回归

      对于想深入了解线性回归的童鞋,这里给出一个完整的例子,详细学完这个例子,对用scikit-learn来运行线性回归,评估模型不会有什么问题了。 1. 获取数据,定义问题     没有...

wangxuwei
今天
1
0
MAC安装MAVEN

一:下载maven压缩包(Zip或tar可选),解压压缩包 二:打开终端输入:vim ~/.bash_profile(如果找不到该文件新建一个:touch ./bash_profile) 三:输入i 四:输入maven环境变量配置 MAVEN_HO...

WALK_MAN
今天
0
0
33.iptables备份与恢复 firewalld的9个zone以及操作 service的操作

10.19 iptables规则备份和恢复 10.20 firewalld的9个zone 10.21 firewalld关于zone的操作 10.22 firewalld关于service的操作 10.19 iptables规则备份和恢复: ~1. 保存和备份iptables规则 ~2...

王鑫linux
今天
2
0
大数据教程(2.11):keeperalived+nginx高可用集群搭建教程

上一章节博主为大家介绍了目前大型互联网项目的系统架构体系,相信大家应该注意到其中很重要的一块知识nginx技术,在本节博主将为大家分享nginx的相关技术以及配置过程。 一、nginx相关概念 ...

em_aaron
今天
1
0
Apache Directory Studio连接Weblogic内置LDAP

OBIEE默认使用Weblogic内置LDAP管理用户及组。 要整理已存在的用户及组,此前办法是导出安全数据,文本编辑器打开认证文件,使用正则表达式获取用户及组的信息。 后来想到直接用Apache Dire...

wffger
今天
2
0
HFS

FS,它是一种上传文件的软件。 专为个人用户所设计的 HTTP 档案系统 - Http File Server,如果您觉得架设 FTP Server 太麻烦,那么这个软件可以提供您更方便的档案传输系统,下载后无须安装,...

garkey
今天
1
0
Java IO类库之BufferedInputStream

一、BufferedInputStream介绍 /** * A <code>BufferedInputStream</code> adds * functionality to another input stream-namely, * the ability to buffer the input and to * sup......

老韭菜
今天
0
0
STM 32 窗口看门狗

http://bbs.elecfans.com/jishu_805708_1_1.html https://blog.csdn.net/a1985831055/article/details/77404131...

whoisliang
昨天
1
0
Dubbo解析(六)-服务调用

当dubbo消费方和提供方都发布和引用完成后,第四步就是消费方调用提供方。 还是以dubbo的DemoService举例 -- 提供方<dubbo:application name="demo-provider"/><dubbo:registry address="z...

青离
昨天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部