1.1.1 查询所有数据
$selData = DB::table('article')->get();
1.1.2 单条件查询
#DB::table('表名')->where('字段','表达式','数据')->get();
$selData = DB::table('article')->where('id','=',10)->get();
1.1.3 多条件查询
#DB::table('表名')->where([[条件1],[条件2],[条件3]])->get();
$selData = DB::table('article')->where([['a_id','<',10],['a_title','like','%a%']])->get();
1.1.4 between区间查询+orderBy排序
#DB::table('表名')->whereBetween('字段',[起始范围,终止范围])->orderBy('字段','排序方式')->get();
$selData = DB::table('article')->whereBetween('a_id',[20,30])->orderBy('a_id','desc')->get();
1.1.5 orderBy排序+limit查询
#DB::table('表名')->orderBy('排序的字段','排序方式')->limit(条数)->get();
DB::table('article')->orderBy('a_id','desc')->limit(1)->get();
1.1.6 in和not in查询
#DB::table('表名')->whereIn('字段',[结果范围])->get();
DB::table('users')->whereIn('id', [1, 2, 3])->get(); #DB::table('表名')->whereNotIn('字段',[结果范围])->get();
DB::table('users')->whereNotIn('id', [1, 2, 3])->get(); 1.1.7 连接查询
#DB::table('主表名')->join('副表名','主表.关联字段','表达式','副表.关联字段')
$users = DB::table('users')
->join('contacts', 'users.id', '=', 'contacts.user_id')
->join('orders', 'users.id', '=', 'orders.user_id')
->select('users.*', 'contacts.phone', 'orders.price')
->get(); #DB::table('主表名')->leftJoin('副表名','主表.关联字段','表达式','副表.关联字段')
$users = DB::table('users')
->leftJoin('posts', 'users.id', '=', 'posts.user_id')
->get(); #DB::table('主表名')->rightJoin('副表名','主表.关联字段','表达式','副表.关联字段')
$users = DB::table('users')
->rightJoin('posts', 'users.id', '=', 'posts.user_id')
->get(); 1.1.8 子查询
#有时你可能需要构造一个 where 语句,将子查询的结果与一个给定值进行比较。这你可以通过给 where 方法传递一个闭包以及给定值实现。
#举例来说,下面的查询语句将会获取到所有属于最近一个会员类型的所有用户。
#whereColumn用于比较两个字段的值是否相等
$users = User::where(function ($query) {
$query->select('type')
->from('membership')
->whereColumn('user_id', 'users.id')
->orderByDesc('start_date')
->limit(1);
}, 'Pro')->get();
1.1.9 分组查询
#根据账户ID进行分组.并对分组之后的数据进行筛选,id大于100的数据
$users = DB::table('users')
->groupBy('account_id')
->having('account_id', '>', 100)
->get(); 1.1.1 聚合函数
#统计总用户量
$users = DB::table('users')->count(); #找出订单中价格最高的记录
$price = DB::table('orders')->max('price'); #查询以支付成功的订单平均价钱
$price = DB::table('orders')
->where('finalized', 1)
->avg('price');
更多查询方案
first取一条数据
find根据ID取一条数据
value从记录中获取单个值
pluck获取一列的值
select指定字段查询
orWhere或者
inRandomOrder方法被用来将结果随机排序
latest/oldest方法可以使你轻松地通过日期排序
whereColumn用于比较两个字段的值是否相等

DB门面-数据查询的更多相关文章

  1. DB门面,查询构建器,Eloquent ORM三者的CURD

    一.DB门面 1.insert DB::insert('insert into table(`name`) value(?)', ['test']); 2.update DB::update('upd ...

  2. Laravel 数据库实例教程 —— 使用DB门面操作数据库

    Laravel支持多种数据库,包括MySQL.Postgres.SQLite和SQL Server,在Laravel中连接数据库和查询数据库都非常简单,我们可以使用多种方式与数据库进行交互,包括原生S ...

  3. Yii2 数据查询

    转载来自: http://www.yiichina.com/tutorial/95 数据查询 User::find()->all(); 此方法返回所有数据: User::findOne($id) ...

  4. MVC5 + EF6 + Bootstrap3 (10) 数据查询页面

    文章来源:Slark.NET-博客园 http://www.cnblogs.com/slark/p/mvc5-ef6-bs3-get-started-search-page.html 系列教程:MVC ...

  5. 技术分享:如何用Solr搭建大数据查询平台

    0×00 开头照例扯淡 自从各种脱裤门事件开始层出不穷,在下就学乖了,各个地方的密码全都改成不一样的,重要帐号的密码定期更换,生怕被人社出祖宗十八代的我,甚至开始用起了假名字,我给自己起一新网名”兴才 ...

  6. 我的EntityFramework(2):简单的数据查询

    原文:我的EntityFramework(2):简单的数据查询 在上一篇博文中,已经搭建了基本的框架,接下来就进行简单的数据查询,这里主要用了Linq 常见的数据集查询 var companyList ...

  7. Mongodb DB shell数据操作

    shell命令操作语法和JavaScript很类似,其实控制台底层的查询语句都是用JavaScript脚本完成操作的. Ø 数据库 1.Help查看命令提示 help db.help(); db.yo ...

  8. MongoDB源码分析——mongod数据查询操作

    源码版本为MongoDB 2.6分支 Edit mongod数据查询操作 在mongod的初始化过程中说过,服务端接收到客户端消息后调用MyMessageHandler::process函数处理消息. ...

  9. ECMall关于数据查询缓存的问题

    刚接触Ecmall的二次开发不久,接到一个任务.很常见的任务,主要是对数据库进行一些操作,其中查询的方法我写成这样: 01 function get_order_data($goods_id) 02 ...

随机推荐

  1. js 斐波那契数列的获取和曲线的实现(每日一更)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta http ...

  2. 「JOI 2015 Final」城墙

    「JOI 2015 Final」城墙 复杂度默认\(m=n\) 暴力 对于点\((i,j)\),记录\(ld[i][j]=min(向下延伸的长度,向右延伸的长度)\),\(rd[i][j]=min(向 ...

  3. Nginx实现跨域配置详解

    主要给大家介绍了关于Nginx跨域使用字体文件的相关内容,分享出来供大家参考学习,下面来一起看看详细的介绍: 问题描述 今天在使用子域名访问根域名的CSS时,发现字体无法显示,在确保CSS和Font字 ...

  4. PHP扩展开发编译环境的搭建

    PHP允许使用扩展的方式,直接使用C语言开发PHP的功能,由于编译的问题,很多底层和框架的基础工作如果用PHP必然会带来额外的开销,降低系统的吞吐量,必然yaf就是这样的思路,把框架封装在扩展里,让系 ...

  5. Web容器中DefaultServlet详解

    万分感谢原文作者:_licho 原文链接:https://blog.csdn.net/qq_30920821/article/details/78328608 Web容器中DefaultServlet ...

  6. laravel 依赖注入 接口设计

    假设我现在需要做一个支付服务,那么我先设计一个接口 interface PayInterface{ public function pay(Order $order) : string; } 然后实现 ...

  7. spring filter详解

    一.Filter基本工作原理 1.Filter 程序是一个实现了特殊接口的 Java 类,与 Servlet 类似,也是由 Servlet 容器进行调用和执行的. 2.当在 web.xml 注册了一个 ...

  8. MySQL日志管理、备份与恢复

    MySQL日志管理.备份与恢复 目录 MySQL日志管理.备份与恢复 一.MySQL日志管理 1. MySQL日志路径 2. 设置.修改日志路径 3. 查询日志功能是否开启 二.MySQL备份与恢复 ...

  9. 关于Java多线程-interrupt()、interrupted()、isInterrupted()解释

    多线程先明白一个术语"中断状态",中断状态为true,线程中断. interrupt():就是通知中止线程的,使"中断状态"为true. isInterrupt ...

  10. linux 定时删除图以及crontab介绍

    执行 sudo crontab -e 0 3 1 * * /etc/letsencrypt/certbot-auto renew --renew-hook "sudo nginx -s re ...