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. Nginx网络压缩 CSS压缩 图片压缩 JSON压缩

    一.序言 使用Nginx作为web应用服务时,会代理如下常见文件:js.css.JSON.图片等,本文提供基于Nginx内置的压缩技术,提供网络请求响应速度的解决方案. 1.网络压缩原理 网络压缩的原 ...

  2. 「MtOI2018」魔力环

    首先发现是经典的循环置换本质不同个数模型,根据 Burnside 引理: \[|X / G| = \frac{1}{|G|}\sum\limits_{g \in G} |X ^ g| \] 考虑第 \ ...

  3. 「JOISC 2016 Day 1」棋盘游戏

    「JOISC 2016 Day 1」棋盘游戏 先判无解:第1,3行有连续的空格或四个角有空格. 然后可以发现有解的情况第1,3行可以在任意时间摆放. 对于某一列,若第2行放有棋子,那么显然可以把棋盘分 ...

  4. CF1270G Subset with Zero Sum

    首先一定要从每个数的范围 \(i - n \le a_i \le i - 1\) 入手,最开始是这样一个想法,不难发现对于每个 \(i\) 都能选 \(n\) 个数,并且能选的右端点在 \(i - 1 ...

  5. UDP数据包最大传输长度

    概念以太网(Ethernet)数据帧的长度必须在46-1500字节之间,这是由以太网的物理特性决定的.这个1500字节被称为链路层的MTU(最大传输单元). 但这并不是指链路层的长度被限制在1500字 ...

  6. bom-简单动画

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  7. Linux Ubuntu安装Nvidia多GPU通信库NCCL

    0. 前言 在使用Python版本的PaddleDetection进行一些实验时,想同时利用多个GPU提高效率,遇到了一点问题 You may need to install 'nccl2' from ...

  8. Docker容器和宿主机互传文件

    1.docker容器向宿主机传送文件 格式: docker cp container_id:<docker容器内的路径> <本地保存文件的路径> 例: docker cp 10 ...

  9. Java中stream的详细用法

    来自于:Java 8 stream的详细用法_旅行者-CSDN博客_java stream 一.概述 Stream 是 Java8 中处理集合的关键抽象概念,它可以指定你希望对集合进行的操作,可以执行 ...

  10. Java基于ClassLoder/ InputStream 配合读取配置文件

    阅读java开源框架源码或者自己开发系统时配置文件是一个不能忽略的,在阅读开源代码的过程中尝尝困惑配置文件是如何被读取到内存中的.配置文件本身只是为系统运行提供参数的支持,个人阅读源码时重点不大可能放 ...