数据库-高级查询

快捷查询

快捷查询方式是一种多字段相同查询条件的简化写法,可以进一步简化查询条件的写法,在多个字段之间用|分割表示OR查询,用&分割表示AND查询,可以实现下面的查询,例如:

Db::table(‘think_user‘)
    ->where(‘name|title‘,‘like‘,‘thinkphp%‘)
    ->where(‘create_time&update_time‘,‘>‘,0)
    ->find();

生成的查询SQL是:

SELECT * FROM `think_user` WHERE ( `name` LIKE ‘thinkphp%‘ OR `title` LIKE ‘thinkphp%‘ ) AND ( `create_time` > 0 AND `update_time` > 0 ) LIMIT 1

快捷查询支持所有的查询表达式。

区间查询

区间查询是一种同一字段多个查询条件的简化写法,例如:

Db::table(‘think_user‘)
    ->where(‘name‘,[‘like‘,‘thinkphp%‘],[‘like‘,‘%thinkphp‘])
    ->where(‘id‘,[‘>‘,0],[‘<>‘,10],‘or‘)
    ->find();

生成的SQL语句为:

SELECT * FROM `think_user` WHERE ( `name` LIKE ‘thinkphp%‘ AND `name` LIKE ‘%thinkphp‘ ) AND ( `id` > 0 OR `id` <> 10 ) LIMIT 1

区间查询的查询条件必须使用数组定义方式,支持所有的查询表达式。

下面的查询方式是错误的:

Db::table(‘think_user‘)
    ->where(‘name‘,[‘like‘,‘thinkphp%‘],[‘like‘,‘%thinkphp‘])
    ->where(‘id‘,5,[‘<>‘,10],‘or‘)
    ->find();

批量查询

可以进行多个条件的批量条件查询定义,例如:

Db::table(‘think_user‘)
    ->where([
        ‘name‘  =>  [‘like‘,‘thinkphp%‘],
        ‘title‘ =>  [‘like‘,‘%thinkphp‘],
        ‘id‘    =>  [‘>‘,0],
        ‘status‘=>  1
    ])
    ->select();

生成的SQL语句为:

SELECT * FROM `think_user` WHERE `name` LIKE ‘thinkphp%‘ AND `title` LIKE ‘%thinkphp‘ AND `id` > 0 AND `status` = ‘1‘

闭包查询

Db::table(‘think_user‘)->select(function($query){
    $query->where(‘name‘,‘thinkphp‘)
        ->whereOr(‘id‘,‘>‘,10);
});

生成的SQL语句为:

SELECT * FROM `think_user` WHERE `name` = ‘thinkphp‘ OR `id` > 10

使用Query对象查询

也可以事先封装Query对象,并传入select方法,例如:

$query = new \think\db\Query;
$query->name(‘user‘)
    ->where(‘name‘,‘like‘,‘%think%‘)
    ->where(‘id‘,‘>‘,10)
    ->limit(10);
Db::select($query);    

如果使用Query对象的话,select方法之前调用的任何的链式操作都是无效。

混合查询

可以结合前面提到的所有方式进行混合查询,例如:

Db::table(‘think_user‘)
    ->where(‘name‘,[‘like‘,‘thinkphp%‘],[‘like‘,‘%thinkphp‘])
    ->where(function($query){
        $query->where(‘id‘,[‘<‘,10],[‘>‘,100],‘or‘);
    })
    ->select();

生成的SQL语句是:

SELECT * FROM `think_user` WHERE ( `name` LIKE ‘thinkphp%‘ AND `name` LIKE ‘%thinkphp‘ ) AND ( `id` < 10 or `id` > 100 )

字符串条件查询

对于一些实在复杂的查询,也可以直接使用原生SQL语句进行查询,例如:

Db::table(‘think_user‘)
    ->where(‘id > 0 AND name LIKE "thinkphp%"‘)
    ->select();

为了安全起见,我们可以对字符串查询条件使用参数绑定,例如:

Db::table(‘think_user‘)
    ->where(‘id > :id AND name LIKE :name ‘,[‘id‘=>0, ‘name‘=>‘thinkphp%‘])
    ->select();

V5.0.4+开始,ThinkPHP支持对同一个字段多次调用查询条件,例如:

Db::table(‘think_user‘)
    ->where(‘name‘,‘like‘,‘%think%‘)
    ->where(‘name‘,‘like‘,‘%php%‘)
    ->where(‘id‘,‘in‘,[1,5,80,50])
    ->where(‘id‘,‘>‘,10)
    ->find();

快捷方法(V5.0.5+

V5.0.5+版本开始新增了一系列快捷方法,用于简化查询,包括:

方法 作用
whereNull 查询字段是否为Null
whereNotNull 查询字段是否不为Null
whereIn 字段IN查询
whereNotIn 字段NOT IN查询
whereBetween 字段BETWEEN查询
whereNotBetween 字段NOT BETWEEN查询
whereLike 字段LIKE查询
whereNotLike 字段NOT LIKE查询
whereExists EXISTS条件查询
whereNotExists NOT EXISTS条件查询
whereExp 表达式查询
时间: 2024-10-12 07:59:53

数据库-高级查询的相关文章

15-07-17 数据库--高级查询

高级查询 --连接查询 select * from 表1,表2 -- 形成笛卡尔积 select * from 表1,表2 where 表1.主键=表2.外键 --主外键位置可以互换 --join on 内连接 select * from 表1 join 外键 on 表1.主键 = 表2.外键 --查哪位学生的哪一门课考了多少分 select student.sname,course.cname,score.degree from student join score on score.sno=

MySQL数据库 高级查询(二)

高级查询(二)  EXISTS 子查询 语法: SELECT ..... FROM  表名 WHERE EXISTS (子查询); EXISTS 关键字后面的参数是一个任意的子查询,如果该子查询有返回值,则EXISTS 子查询的结果为true,此时再执行外层查询语句.如果没有返回行,则EXISTS 子查询 的结果为false,此时外层语句不再执行查询.  NOT EXISTS 子查询 EXISTS 子查询和NOT EXISTS 子查询的结果只取决于是否有返回记录,不取决于这些记录的内容,所以EX

MySQL数据库 高级查询(一)

常用函数 常用聚合函数: AVG() 返回某字段的平均值 COUNT() 返回某字段的行数 MAX() 返回某字段的最大值 MIN( ) 返回某字段的最小值 SUM( ) 返回某字段的和 函数名 作用 常用的字符串函数 函数名 作用 举例 CONCAT(str1,str2,...,strn) 连接字符串str1,str2,...,strn为一个完整字符串 SELECT CONCAT('My','S','QL'); 返回:MySQL INSERT(str,pos,len,newstr) 将字符串s

2014.9.9数据库高级查询

1 select * from Nation 2 select * from Info 1 --连接(列的扩展) 2 --把两个表连起来显示(第一种方法) 3 select Info.Code,Info.Name,Info.Sex,Nation.Name as nation,Info.Birthday 4 from Info,Nation 5 where Nation.Code=Info.Nation --笛卡尔积 --把列名换成汉字 [as]空格+列名 执行结果: 1 --把两个表连接起来(第

MySQL 数据库 高级查询

1.连接查询select * from Info,Nation #笛卡尔积select * from Info,Nation where Info.Nation=Nation.Code join on 连接select * from Info join Nation #join连接select * from Info join Nation on Info.Nation=Nation.Code 2.联合查询select Code,Name from Infounionselect Code,Na

数据库高级查询的使用 201409005

一.连接查询 将多个表格列出来,不是SQL国际标准方法,但适用于每个表,是表格中列的扩展,表格横着铺开. 1.连接查询的方法: 1)形成笛卡尔积 select * from Info select * from nation 笛卡尔积: select info.code,info.name,info.sex,nation.name as nation,info.birthday from INFO,nation --显示info表中的code,name,sex列,并且将nation表中的name

Java数据库 高级查询

插入数据记录 1.插入单行数据 语法: INSERT INTO 表名 [(字段名列表)]  VALUES (值列表); 2.插入多行数据 语法:INSERT INTO 新表 (字段名列表) VALUES (值列表1), (值列表2), ......, (值列表n); 注意:在是INSERT语句插入记录时,如果不包含字段名称,VALUES后值列表中各字段的顺序必须和表定义中各字段的顺序相同,如果表结构变了(如执行了添加数据操作) 则值列表也要变化,否则会出现错误.如果指定了插入的字段名,就会避免这

数据库高级查询

1.连接查询,对结果集列的扩展select * from info ①select * from info,nation #形成笛卡尔积(学名) 简单查询②select * from info,nation where info.nation=nation.code info.nation=nation.code: 属于等于也属于 .:后面的数据属于前面的数据. =:起到连接的作用. ③select info.code,info.name,sex,nation.name,birthday fro

数据库——基础(数据库操作,表格操作)——增加高级查询

笔记 LAMP:Linx(操作系统) A(阿帕奇)——网页的应用程序 M(Mysql):体积小,应用简单 P(PHP) 第一步:搭建网页环境——A\M\P WAMP:用WAMP搭建环境 DW:更好的显示 数据库的基本操作: 数据库——表结构——字段(列) 每一行数据成为一条数据(记录) 特点:关系型数据库,有严格的规范 1.必须有主键:能够唯一标识一条数据的字段 2 T-SQL:通用的数据库操作语句 自增长列code(主键列) ;连接键表 最后一个字段不加 ,#注释 创建表:create tab