一. 连贯入门

查找到 id 为 1,2,3,4 中按照创建时间的倒序的前两位。

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

1、连贯操作入门

$user = M('User');
var_dump($user->where('id in (1,2,3,4)')->order('date DESC')->limit(2)->select());

得到的SQL查询语句为

PS:这里的 where、order 和 limit 方法都是连贯操作方法,所以它们都能返回$user本身,
可以互换位置。而 select 方法不是连贯方法,需要放在最后,用以显示数据集。

2、数组操作

$user = M('User');
var_dump($user->select( array('where'=>'id in (1,2,3,4)', 'limit'=>'2','order'=>'date DESC')));

或者是

$user = M('User');
var_dump($user->select(array('where'=>array('id'=>array('neq','1')),'order'=>'date DESC','limit'=>'2')));

二. 连贯方法

1.where
where 方法支持字符串条件、数组条件(推荐用法)和多次调用

//字符串方式
$user = M('User');
var_dump($user->where('id=1')->select());

//索引数组方式
$user = M('User');
$map['id'] = 1;
var_dump($user->where($map)->select());

$user = M('User');
$map['id'] = array('eq', 1);
var_dump($user->where($map)->where('user="蜡笔小新"')->select());

2.order
order 用于对结果集排序。

//倒序
$user = M('User');
$map['id'] = array('eq', 1);
var_dump($user->order('id desc')->select()); //正序默认或 ASC

//第二排序
var_dump($user->order('id desc,email desc')->select());
PS:先按 id 倒序,再按 email 倒序

这个用法在这个数据库里是没有什么意义的,但是如果是在比较成绩的时候就可以使用了,比如将id换成语文成绩,email换成数学成绩,

当语文成绩是一样的时候,那这时候就比较数学成绩了,这时候才用到两个排序的功能。

//数组形式防止字段和mysql关键字冲突
$user = M('User');
$map['id'] = array('eq', 1);
var_dump($user->order( array('id'=>'DESC'))->select());

使用数组的形式就是能够在SQL查询的时候在user等字段上加上``符号,更安全。

3.feild
feild 方法可以返回或操作字段,可以用于查询和写入操作。

只显示id和user两个字段
$user = M('User');
var_dump($user->field('id, user')->select());

使用SQL函数和别名

$user = M('User');
var_dump($user->field('SUM(id) as nihao, user')->select());

其中 'SUM(id) as nihao 中的nihao为设置的别名,在浏览器中显示为

使用数组参数结合SQL函数

$user = M('User');
var_dump($user->field( array('id','LEFT(user,3)'=>'left_user'))->select());

这时只显示user中数据的前三个字

并且其中的 left_user 也是设置的别名,在SQL查询语句中为:

获取所有字段

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

4.limit
limit 方法主要用于指定查询和操作的数量。

限制结果集数量

$user = M('User');
var_dump($user->limit(2)->select());

分页查询

$user = M('User');
var_dump($user->limit(0,2)->select());

5.page
page 方法完全用于分页查询。

$user = M('User');
var_dump($user->page(1,2)->select()); //第一个1是页码数,第二个2是条数

6.table
table 方法用于数据表操作,主要是切换数据表或多表操作。

切换数据表

$user = M('User');
var_dump($user->table('think_info')->select());

获取简化表名

$user = M('User');
var_dump($user->table('__USER__')->select());

注意的是,因为数据表名为think_user,所以这里是__USER__,即USER两边都是两个下划线,且必须大写,这里的USER是数据表的后缀名

多表查询

$user = M('User');
var_dump($user->field('a.id,b.id')->table('__USER__ a,__INFO__ b')->select());

也就是获得两个数据表中的id,在浏览器中为

在SQL查询语句中为

多表查询,使用数组形式避免关键字冲突

$user = M('User');
var_dump($user->field('a.id,b.id')->table( array('think_user'=>'a',
'think_info'=>'b'))->select());

这时,即为查询的数据表加上``符号。

alias 用于设置数据表别名

$user = M('User');
var_dump($user->alias('a')->select());

不使用别名的时候:

使用别名的时候

都没有了``符号,也不知道是用来干嘛的

SQL 连贯操作 [1]的更多相关文章

  1. SQL 连贯操作 [2]

    1.alias 用于设置数据表别名 $user = M('User'); var_dump($user->alias('anothername')->select()); 这时在SQL中的 ...

  2. 一对一关联查询时使用relation连贯操作查询后,调用getLastSql()方法输出的sql语句

    如题: 一对一关联查询时使用relation连贯操作查询后,调用getLastSql()方法输出的sql语句不是一条关联查询语句. 例如: $list = $db->relation(true) ...

  3. ci连贯操作的limit两个参数和sql是相反的

    ci连贯操作的limit两个参数和sql是相反的 db->where("name =",'mary')->ge() name后面要有个空格否则报错当为一个字段 -> ...

  4. ThinkPhp 3.2 数据的连贯操作

    ThinkPHP模型基础类提供的连贯操作方法(也有些框架称之为链式操作),可以有效的提高数据存取的代码清晰度和开发效率,并且支持所有的CURD操作. 使用也比较简单, 假如我们现在要查询一个User表 ...

  5. thinkPHP--SQL连贯操作

    一.连贯入门 连贯操作使用起来非常简单,比如查找到 id 为 1,2,3,4 中按照创建时间的倒序的前两 位. //连贯操作入门 $user = M('User'); var_dump($user-& ...

  6. 【转】PHP实现连贯操作

    [第一种方案 __call] 我们在使用一些框架(如ThinkPHP)编码的时候,常用到这样的代码. M('User')->where(array('id'=>1))->field( ...

  7. Laravel框架数据库CURD操作、连贯操作

    这篇文章主要介绍了Laravel框架数据库CURD操作.连贯操作.链式操作总结,本文包含大量数据库操作常用方法,需要的朋友可以参考下 一.Selects 检索表中的所有行 $users = DB::t ...

  8. Laravel框架数据库CURD操作、连贯操作总结

    这篇文章主要介绍了Laravel框架数据库CURD操作.连贯操作.链式操作总结,本文包含大量数据库操作常用方法,需要的朋友可以参考下 一.Selects 检索表中的所有行 复制代码代码如下: $use ...

  9. ThinkPHP第十八天(Widget类的使用,连贯操作where IN用法,缓存S函数使用)

    1.Widget类的使用方法: 第一步:在Action同级目录中新建Widget文件夹(独立分组需要自己建立) 第二步:根据不同功能在Widget文件夹中建立不同的Widget类,如热门文章HotWi ...

随机推荐

  1. Java源码阅读的真实体会(一种学习思路)【转】

    Java源码阅读的真实体会(一种学习思路)   刚才在论坛不经意间,看到有关源码阅读的帖子.回想自己前几年,阅读源码那种兴奋和成就感(1),不禁又有一种激动. 源码阅读,我觉得最核心有三点:技术基础+ ...

  2. Node.js 常用工具 (util.inherits)

    util 是一个Node.js 核心模块,提供常用函数的集合,用于弥补核心JavaScript 的功能 过于精简的不足. util.inherits util.inherits(constructor ...

  3. IDEA部署和导入guns

    1.使用idea进行open -> guns-parent2.修改数据源: 目标:guns-admin\src\main\resources\application.yml 修改内容: 2.1 ...

  4. redis有序集合的使用

    Redis 有序集合(sorted set) Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员. 不同的是每个元素都会关联一个double类型的分数.redis正是通过 ...

  5. 【LeetCode】025. Reverse Nodes in k-Group

    Given a linked list, reverse the nodes of a linked list k at a time and return its modified list. k  ...

  6. java 实现拖动文件到窗口功能

    package tuo; import java.awt.BorderLayout; import java.awt.Color; import java.awt.datatransfer.DataF ...

  7. C++语言对C的增强(1)——实用性、变量检测、struct类型、C++中所有变量和函数都必须有类型、bool类型、三目运算符

    1.“实用性”增强 C语言中的变量都必须在作用域开始的位置定义,C++中更强调语言的“实用性”,所有的变量都可以在需要使用时再定义. 2.变量检测加强 在C语言中,重复定义多个同名的全局变量是合法的: ...

  8. Tomcat反带和集群

    Nginx|Apache反带用户请求到Tomcat LNMT: client -->http --> nginx --> reverse_proxy --> http --&g ...

  9. 第三篇 ubuntu下,mysql 的root用户密码忘了怎么办?

    好长一段时间没有使用ubuntu了,今天进来玩玩,结果连mysql的root用户密码都忘记了.就上网找了一下,发现如下解决办法,试了一下,可行!记录在此,环境问题,是需要注意的. Ubuntu Ser ...

  10. MySQL最新版本 MySQL5.7.11 批量自动化一键式安装(转)

    --背景云端 以前都喜欢了源码安装MySQL,总觉得源码是高大上的事情,不过源码也需要时间,特别是make的时候,如果磁盘和cpu差的话,时间很长很长,在虚拟机上安装mysql尤其甚慢了. 现在业务发 ...