一、快捷查询

快捷查询方式是一种多字段查询的简化写法,在多个字段之间用'|'隔开表示OR,用'&'
隔开表示 AND。

1.不同字段相同查询条件

在  Home/controller/UserController.class.php   中插入

//使用相同查询条件
$user = M('User');
$map['user|email'] = '蜡笔小新'; //'|'换成'&'变成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 还要对应'蜡笔小新'的情况。而且,这设置要在放在数组最后。

如果不加 '_multi'=> true 这行语句,则在调试中为:

//支持使用表达式结合快捷查询
$user = M('User');
$map['id&user'] = array( array('gt', 0),'蜡笔小新','_multi'=> true);
var_dump($user->where($map)->select());

其中 array('gt', 0) 在上一篇已经讲过了,是指大于0的数据,即id大于0的数据都符合条件

二、区间查询

ThinkPHP 支持对某个字段的区间查询。

//区间查询
$user = M('User');
$map['id'] = array( array('gt', 1), array('lt', 4));
var_dump($user->where($map)->select());

即为符合id大于1且小于4的数据

//第三个参数设置逻辑OR
$user = M('User');
$map['id'] = array( array('gt', 1), array('lt', 4), 'OR');
var_dump($user->where($map)->select());

这是符合id大于1或者id小于4的数据。

三、组合查询

组合查询是基于索引数组查询方式的一个扩展性查询,添加了字符串查询(_string)、复
合查询(_complex)、请求字符串查询(_query),由于采用的是索引数组,重复的会被覆盖。

1、字符串查询(_string)

//字符串查询(_string)
$user = M('User');
$map['id'] = array('eq', 1);
$map['_string'] ='user="蜡笔小新" AND email="xiaoxin@163.com"';
var_dump($user->where($map)->select());

这时浏览器中调试的SQL查询方式为:

看到查询语句中的user和email都没有类似单引号``(键盘上1的左边的那个符号),这样的查询方式不大安全;

2、请求字符串查询(_query)

//请求字符串查询(_query)
$user = M('User');
$map['id'] = array('eq', 1);
$map['_query'] ='user=蜡笔小新&email=xiaoxin@163.com&_logic=OR';
var_dump($user->where($map)->select());

这样的方式比较好用,也可以叫URL查询方式,只用&符号就可以,也不用添加单引号,且SQL的查询方式为:

可以看到这时候查询的语句中user和email都加上了``,这样的查询方式也比较安全。

另外说明一点的就是

$user =  M('User');
$map['id']=array('eq',1);
$map['id']=2;
var_dump($user->where($map)->select());

这时,SQL查询的就只有id=2的数据了,  $map['id']=2;  会将  $map['id']=array('eq',1);  覆盖掉

3、复合查询(_complex)

$user =  M('User');
$map['id']=array('eq',1);
$where['id']=2;
$map['_complex']=$where;
var_dump($user->where($map)->select());

这里新添加了一个数组$where,第2中方法中也说了   $map['id']=2;  会将 $map['id']=array('eq',1); 覆盖掉

使用复合查询后,对应的SQL查询语句为:

这时默认的连接符是AND,如果想换成或,则添加一条语句 $map['_logic']='OR'; 即可

四、统计查询

查询有多少条目

$user =  M('User');
var_dump($user->count());

这时SQL查询语句为:

然后查询数据库中某一个名字下有多少条数据

首先我们的数据库是这样的

然后我们单独查询email下有多少条:

$user =  M('User');
var_dump($user->count('email'));

查询后显示的结果为 string(1) "4"  这时我们手动添加一条数据

首先我们把email设置为可以为空,如下图所示

然后添加一条数据,这时email栏不添加任何数据,添加后如下图所示

这时,再查询email的有多少条时,显示的为 string(1) "4"  ,我们给user为'李艳辉'的email添加为'yanhui@163.com',再查询,则显示为 string(1) "5"

也就是字段总条数,遇到NULL不统计。

下面是查询数据库的一些其他的信息

var_dump($user->max('id'));  查询id的最大值

var_dump($user->min('id')); 查询id的最小值

var_dump($user->avg('id')); 查询id的平均值

var_dump($user->sum('id')); 查询id的总值

五、动态查询

借助 PHP5 语言的特性,ThinkPHP 实现了动态查询。

1.getBy 动态查询

$user =  M('User');
var_dump($user->getByEmail('xiaoxin@163.com'));

直接查询email为xiaoxin@163.com的数据

也可以使用 var_dump($user->getByUser('蜡笔小新')); 来获得该条目的数据

也就是getBy后面接的必须是建立的数据表中的名字

2、getFieldBy 动态查询

//通过user得到相对应id值
$user = M('User');
var_dump($user->getFieldByUser('路飞', 'id'));

这时,将id改为email,也可得到eamil的值,但是getFieldByUser中第一个参数必须是user对应的名字。

同样的 getFieldByUser 也可以换成 getFieldByid 等,然后括号内第一个参数为id对应的值,后面一个参数是查询的建立的数据表中的名字。

六、SQL查询

ThinkPHP支持原生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'));

SQL查询语句 [2]的更多相关文章

  1. sql查询语句如何解析成分页查询?

    我们公司主要mysql存储数据,因此也封装了比较好用mysql通用方法,然后,我们做大量接口,在处理分页查询接口,没有很好分查询方法.sql查询 语句如何解析成“分页查询”和“总统计”两条语句.可能, ...

  2. 15个初学者必看的基础SQL查询语句

    本文由码农网 – 小峰原创翻译,转载请看清文末的转载要求,欢迎参与我们的付费投稿计划! 本文将分享15个初学者必看的基础SQL查询语句,都很基础,但是你不一定都会,所以好好看看吧. 1.创建表和数据插 ...

  3. SQL查询语句去除重复行

    1.存在两条完全相同的纪录 这是最简单的一种情况,用关键字distinct就可以去掉 select distinct * from table(表名) where (条件) 2.存在部分字段相同的纪录 ...

  4. WordPress 常用数据库SQL查询语句大全

    在使用WordPress的过程中,我们少不了要对数据库进行修改操作,比如,更换域名.修改附件目录.批量修改文章内容等等.这个时候,使用SQL查询语句可以大大简化我们的工作量. 关于如何操作SQL查询语 ...

  5. (转)经典SQL查询语句大全

    (转)经典SQL查询语句大全 一.基础1.说明:创建数据库CREATE DATABASE database-name2.说明:删除数据库drop database dbname3.说明:备份sql s ...

  6. 转: 从Mysql某一表中随机读取n条数据的SQL查询语句

    若要在i ≤ R ≤ j 这个范围得到一个随机整数R ,需要用到表达式 FLOOR(i + RAND() * (j – i + 1)).例如, 若要在7 到 12 的范围(包括7和12)内得到一个随机 ...

  7. 经典SQL查询语句大全

    一.基础1.说明:创建数据库CREATE DATABASE database-name2.说明:删除数据库drop database dbname3.说明:备份sql server--- 创建 备份数 ...

  8. oracle中sql查询语句的执行顺序

    查询语句的处理过程主要包含3个阶段:编译.执行.提取数据(sql查询语句的处理主要是由用户进程和服务器进程完成的,其他进程辅助配合) 一.编译parse 在进行编译时服务器进程会将sql语句的正文放入 ...

  9. SQL查询语句分类

    SQL查询语句有多种,下面总结下.首先先建三张表用于后面的实验 -- 学生表,记录学生信息 CREATE TABLE student( sno ), sname ), ssex ENUM('男','女 ...

  10. 浅谈SQL优化入门:1、SQL查询语句的执行顺序

    1.SQL查询语句的执行顺序 (7) SELECT (8) DISTINCT <select_list> (1) FROM <left_table> (3) <join_ ...

随机推荐

  1. 时间服务器: NTP 服务器及客户端搭建

    时间服务器: NTP 服务器及客户端搭建 一. NTP 服务器的安装与设定 1. NTP 服务器的安装与设定前言 2. 所需软件与软件结构 3. 主要配置文件 ntp.conf 的处理 4. NTP ...

  2. Hive mapreduce SQL实现原理——SQL最终分解为MR任务,而group by在MR里和单词统计MR没有区别了

    转自:http://blog.csdn.net/sn_zzy/article/details/43446027 SQL转化为MapReduce的过程 了解了MapReduce实现SQL基本操作之后,我 ...

  3. Linux内核主要由哪几部分组成?每部分的作用?

    . Linux内核主要由哪几部分组成?每部分的作用? 参考答案:  Linux内核主要由五个子系统组成:进程调度,内存管理,虚拟文件系统,网络接口,进程间通信.  进程调度(SCHED):控制进程对C ...

  4. jira 从数据库 切换到mysql

    通过JIRA管理员登录,进入“管理员页面”,“系统”--“导入&导出”,以XML格式备份数据. 在MySQL中创建Schema,命名为jira 关闭JIRA服务 备份一下JIRA的安装目录和数 ...

  5. k-means算法的优缺点以及改进

    大家接触的第一个聚类方法,十有八九都是K-means聚类啦.该算法十分容易理解,也很容易实现.其实几乎所有的机器学习和数据挖掘算法都有其优点和缺点.那么K-means的缺点是什么呢? 总结为下: (1 ...

  6. New Year and Counting Cards

    Your friend has n cards. You know that each card has a lowercase English letter on one side and a di ...

  7. jacksi(比较实用的工具批处理)

    批处理类别: 国产软件 批处理语言: 简体中文 授权方式: 免费软件 运行环境: Windows平台 警告:运行BAT源码是一种危险的动作,如果你不熟悉,请不要尝试! 这里分享的是用bat写的比较实用 ...

  8. angularJs 指令的封装

    首先 指令的应用场景: 1:使你的html更具语义化,不需要深入研究代码就可以知道页面的大概逻辑. 2:抽象出一个自定义组件,在其他的地方进行重用. 一:directive的定义及其使用方法: 下面是 ...

  9. Redis Sentinel(哨兵)主从高可用方案

    环境搭建 三台服务器: 192.168.126.100(master) 192.168.126.110(slaver) 192.168.126.120(slaver) 拷贝192.168.126.10 ...

  10. 怎么让eclipse调试的时候不进入 class文件中去

    Eclipse -> Window ->Preferences ->Java ->Debug "Suspend execution on uncaught excep ...