Thinkphp查询 1.查询方式 2.表达式查询 3.快捷查询 4.区间查询 5.组合查询 6.统计查询 7.动态查询 8.SQL 查询
1.使用字符串作为条件查询
$user = M('User');
var_dump($user->where('id=1 AND user="蜡笔小新"')->select());
//最终生成的 SQL 语句 SELECT * FROM `think_user` WHERE ( id=1 AND user="蜡笔小新" )
2.使用索引数组作为查询条件
$user = M('User');
$condition['id'] = 1; $condition['user'] = '蜡笔小新';
var_dump($user->where($condition)->select());
//最终生成的 SQL 语句 SELECT * FROM `think_user` WHERE ( `id` = 1 ) AND ( `user` = '蜡笔小 新' )
PS:索引数组查询的默认逻辑关系是 AND,如果想改变为 OR,可以使用_logic 定义查 询逻辑。
基于上面的代码增加如下一行: $condition['_logic'] = 'OR'; //将默认 AND 改成 OR
3.使用对象方式来查询
$user = M('User');
$condition = new \stdClass();
$condition->id = 1; $condition->user = '蜡笔小新';
var_dump($user->where($condition)->select());
//最终生成的 SQL 语句 SELECT * FROM `think_user` WHERE ( `id` = 1 ) AND ( `user` = '蜡笔小 新' )
PS:stdClass 类是 PHP 内置的类,可以理解为一个空类,在这里可以理解为把条件的 字段作为成员保存到 stdClass 类里。
而这里的'\'是将命名空间设置为根目录,否则会导 致当前目录找不到此类。使用对象和数组查询,效果是一样的,可以互换。
在大多数情况下, ThinkPHP 推荐使用数组形式更加高效。
二.表达式查询
查询表达式格式:$map['字段名'] = array('表达式','查询条件');
PS:表达式不区分大小写。
//EQ:等于(=)
$map['id'] = array('eq', 1); //where 为 id=1 //NEQ:不等于(<>)
$map['id'] = array('neq', 1); //where 为 id<>1 //GT:大于(>)
$map['id'] = array('gt', 1); //where 为 id>1 //EGT:大于等于(>=)
$map['id'] = array('egt', 1); //where 为 id>=1 //LT:小于(<)
$map['id'] = array('lt', 1); //where 为 id<1 //ELT:小于等于(<=)
$map['id'] = array('elt', 1); //where 为 id<=1 //[NOT]LIKE:模糊查询
$map['user'] = array('like', '%小%'); //where 为 like %小% //[NOT]LIKE:模糊查询
$map['user'] = array('notlike', '%小%'); //where 为 not like %小% //[NOT]LIKE:模糊查询的数组方式
$map['user'] = array('like', array('%小%', '%蜡%'), 'AND'); //生成的 SQL SELECT * FROM `think_user` WHERE ( (`user` LIKE '%小%' AND `user` LIKE '%蜡%') ) //[NOT] BETWEEN:区间查询
$map['id'] = array('between','1,3'); //where 为`id` BETWEEN '1' AND '2' //同上等效 $map['id'] = array('between',array('1','3')); //[NOT] BETWEEN:区间查询
$map['id'] = array('not between','1,3'); //where 为`id` NOT BETWEEN '1' AND '2' //[NOT] IN:区间查询
$map['id'] = array('in','1,2,4'); //where 为`id` IN ('1','2','4') //[NOT] IN:区间查询
$map['id'] = array('not in','1,2,4'); //where 为`id` NOT IN ('1','2','4') //EXP:自定义
$map['id'] = array('exp','in (1,2,4)'); //where 为`id` NOT IN ('1','2','4') PS:使用 exp 自定义在第二个参数直接写 where 语句即可 //EXP:自定义增加 OR 语句
$map['id'] = array('exp', '=1'); $map['user'] = array('exp', '="蜡笔小新"');
$map['_logic'] = 'OR'; //WHERE 为( (`id` =1) ) OR ( (`user` ="蜡笔小新") )
三.快捷查询 快捷查询方式是一种多字段查询的简化写法,在多个字段之间用'|'隔开表示OR,用'&' 隔开表示 AND。
1.不同字段相同查询条件
//使用相同查询条件
$user = M('User');
$map['user|eemail'] = 'a'; //'|'换成'&'变成AND
var_dump($user->where($map)->select());
2.不同字段不同查询条件
//使用不同查询条件
$user = M('User');
$map['id&user'] = array(1,'蜡笔小新','_multi'=>true);
var_dump($user->where($map)->select());
PS:设置'_multi'为 true,是为了让 id 对应 1,让 user 对应'蜡笔小新',否则就 会出现 id 对应了 1 还要对应'蜡笔小新'的情况。而且,这设置要在放在数组最后。
//支持使用表达式结合快捷查询
$user = M('User');
$map['id&user'] = array(array('gt', 0),'蜡笔小新','_multi'=>true);
var_dump($user->where($map)->select());
四.区间查询 ThinkPHP 支持对某个字段的区间查询。
//区间查询
$user = M('User');
$map['id'] = array(array('gt', 1), array('lt', 4));
var_dump($user->where($map)->select());
//第三个参数设置逻辑OR
$user = M('User');
$map['id'] = array(array('gt', 1), array('lt', 4), 'OR');
var_dump($user->where($map)->select());
五.组合查询
组合查询是基于索引数组查询方式的一个扩展性查询,添加了字符串查询(_string)、复 合查询(_complex)、请求字符串查询(_query),由于采用的是索引数组,重复的会被覆盖。
//字符串查询(_string)
$user = M('User');
$map['id'] = array('eq', 1);
$map['_string'] ='user="蜡笔小新" AND email="xiaoxin@163.com"';
var_dump($user->where($map)->select());
//请求字符串查询(_query)
$user = M('User');
$map['id'] = array('eq', 1);
$map['_query'] ='user=蜡笔小新&email=xiaoxin@163.com&_logic=OR';
var_dump($user->where($map)->select());
PS:这种方式是 URL 方式,不需要加引号。
//复合查询(_complex)
$user = M('User');
$where['user'] = array('like', '%小%');
$where['id'] = 1; $where['_logic'] = 'OR';
$map['_complex'] = $where; $map['id'] = 3;
$map['_logic'] = 'OR';
var_dump($user->where($map)->select());
六.统计查询 ThinkPHP 提供了一些数据统计查询的方法。
//数据总条数
$user = M('User');
var_dump($user->count()); //字段总条数,遇到NULL不统计
$user = M('User');
var_dump($user->count('email')); //最大值
$user = M('User');
var_dump($user->max('id')); //最小值
$user = M('User');
var_dump($user->min('id')); //平均值
$user = M('User');
var_dump($user->avg('id')); //求总和
$user = M('User');
var_dump($user->sum('id'));
七.动态查询
1.getBy 动态查询
//查找email=xiaoin@163.com的数据
$user = M('User');
var_dump($user->getByemail('xiaoxin@163.com')); 2.getFieldBy 动态查询
//通过user得到相对应id值
$user = M('User');
var_dump($user->getFieldByUser('路飞', 'id'));
八.SQL 查询
1.query 读取
//查询结果集,如果采用分布式读写分离,则始终在读服务器执行
$user = M('User');
var_dump($user->query('SELECT * FROM think_user')); 2.execute写入
//更新和写入,如果采用分布式读写分离,则始终在写服务器执行
$user = M('User');
var_dump($user->execute('UPDATE think_user set user="蜡笔大新" WHERE id=1'));
Thinkphp查询 1.查询方式 2.表达式查询 3.快捷查询 4.区间查询 5.组合查询 6.统计查询 7.动态查询 8.SQL 查询的更多相关文章
- 在Delphi中动态地使用SQL查询语句 Adoquery sql 参数 冒号
在Delphi中动态地使用SQL查询语句 在一般的数据库管理系统中,通常都需要应用SQL查询语句来提高程序的动态特性.下面介绍如何在Delphi中实现这种功能.在Delphi中,使用SQL查询语句的途 ...
- sql查询语句面试题
几个表 employees 表: EMPLOYEE_ID NUMBER(6) FIRST_NAME VARCHAR2(20) LAST_NAME ...
- 如何编写更好的SQL查询:终极指南-第一部分
结构化查询语言(SQL)是数据挖掘分析行业不可或缺的一项技能,总的来说,学习这个技能是比较容易的.对于SQL来说,编写查询语句只是第一步,确保查询语句高效并且适合于你的数据库操作工作,才是最重要的.这 ...
- Thinkphp中查询复杂sql查询表达式,如何表达MYSQL中的某字段不为空is not null?
Thinkphp中查询复杂sql查询表达式,如何表达MYSQL中的某字段不为空is not null?先上两种实现方式的实例:$querys["house_type_image"] ...
- ThinkPHP(3)SQL查询语句
ThinkPHP中对查询语句,包含了基本的查询方式.表达方式.快速查询.区间查询.组合查询.SQL查询.动态查询和子查询. 一.查询方式 ThinkPHP提供了三种基本的查询方式:字符串条件查询.索引 ...
- 【三十三】thinkphp之SQL查询语句(全)
一:字符串条件查询 //直接实例化Model $user=M('user1'); var_dump($user->where ('id=1 OR age=55')->select()); ...
- 浅析SQL查询语句未显式指定排序方式,无法保证同样的查询每次排序结果都一致的原因
本文出处:http://www.cnblogs.com/wy123/p/6189100.html 标题有点拗口,来源于一个开发人员遇到的实际问题 先抛出问题:一个查询没有明确指定排序方式,那么,第二次 ...
- 64位环境中使用SQL查询excel的方式解决
--64位环境中使用SQL查询excel的方式 环境: OS:Windows Server 2008 R2 Enterprise MSSQL:Microsoft SQL Server 2008 R2 ...
- Hibernate的四种查询方式(主键查询,HQL查询,Criteria查询,本地sql查询)和修改和添加
Hibernate的添加,修改,查询(三种查询方式)的方法: 案例演示: 1:第一步,导包,老生常谈了都是,省略: 2:第二步,创建数据库和数据表,表结构如下所示: 3:第三步创建实体类User.ja ...
随机推荐
- JavaScript方法
1.hasOwnProperty:是用来判断一个对象是否有你给出名称的属性或对象.不过需要注意的是,此方法无法检查该对象的原型链中是否具有该属性,该属性必须是对象本身的一个成员.isPrototype ...
- OSSFS将OSS bucket 挂载到本地文件系统及注意事项
OSSFS将OSS bucket 挂载到本地文件系统及注意事项 下载ossfs安装包 wget http://docs-aliyun.cn-hangzhou.oss.aliyun-inc.com/as ...
- MysqlWorkbench连接远程数据
- php中并发读写文件冲突的解决方案
在这里提供4种高并发读写文件的方案,各有优点,可以根据自己的情况解决php并发读写文件冲突的问题. 对于日IP不高或者说并发数不是很大的应用,一般不用考虑这些!用一般的文件操作方法完全没有问题.但如果 ...
- 改写js原装的alert样式
1.将下面的js代码单独到一个js文件中,然后在页面中引用 AlertDialog.js //改写js原装的alert样式 var t; var timeclose = 0; var showBack ...
- 第二章 编写与设置Servlet
2.1 第一个Servlet package cc.openhome; import javax.servlet.ServletException; import javax.servlet.http ...
- 文本切割软件Replace Pioneer
工作中遇到一些大文本,或者一些文件需要在特定的行切割开的.Replace Pioneer正好用于此的软件. 把一个文本切分不同文本的步骤: 1先把文本数据放到打开
- form.submit(回调函数)——引用jq-form.js
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...
- 从Eclipse迁移到Android Studio碰到的问题记录
背景: 1. 一直在做.NET的开发,工作之余,学习了一下Android开发,写了一些Demo,当时用的Eclipse开发工具:这两天,刚好项目不是很忙,就打算把之前写的Demo,迁移到Android ...
- UVA 10780 Again Prime No Time.(数学)
给定两个整数m和n,求最大的k使得m^k是n!的约数 对m质因子分解,然后使用勒让德定理求得n!包含的质数p的阶数,min(b[i] / a[i])即为结果k, 若为0无解 #include<c ...