1、alias 用于设置数据表别名

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

这时在SQL中的查询语句为

需要注意的是如果将anothername 中的another 和name中加空格,这样是有问题的。就无法连接数据库了。

2、group 方法通常用于对结合函数统计的结果集分组。

$user = M('User');
var_dump($user->field('user,max(id)')->group('id')->select());

这时是按group里的id来分组,相同的id的则会在一起,如果是group('email'),则会根据email相同的分在一组,这时可能不是email所有的都会相同

但是按email第一个匹配的分在一块。这里的 field('user,max(id)') 是只取数据库里的user和id,其他的不显示

SQL语句为 SELECT `user`,max(id) FROM `think_user` GROUP BY id

3、having 方法一般用于配合 group 方法完成从分组的结果中再筛选数据。

$user = M('User');
var_dump($user->field('user,max(id)')->group('id')->having('id>2')->select());

从group分好组后,就开始筛选组里大于2的显示出来

SQL语句为 SELECT `user`,max(id) FROM `think_user` GROUP BY id HAVING id>2

4、distinct方法用于返回唯一不同的值

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

这时如果是相同的值就不会再显示出来

5、cache 用于查询缓存操作

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

PS:第一次查询数据库,第二次查询相同的内容直接调用缓存,不用再查询数据库。

三、命名范围

命名范围其实就是将 SQL 语句封装在模型定义类里,而不在控制器里。这样的分层操
作有利于代码的可读性,避免开发人员在写 CURD 操作时出现问题。架构人员只要在命名范
围内合理的规划即可,类似于架构师架构了接口,让开发人员面向接口开发一样。

要使用命名范围,第一步要定义属性:

在 Home/Model/UserModel.class.php 里插入以下代码:

<?php
namespace Home\Model;
use Think\Model; class UserModel extends Model {
protected $_scope = array( //$_scope是固定的,不可更改
'sql1' => array(
'where'=>array('id'=>1),
),
'sql2' =>array(
'order'=>array('date'=>'DESC'),
'limit'=> 2,
),
'default'=>array(
'where'=>array('id'=>2)
),
); }

然后在 Home/controller/UserController.class.php 中调用,需要注意的是,调用的时候scope也是不能改变的。

1.

$user = D('User');
var_dump($user->scope('sql1')->select());

这时得到的SQL查询语句为: SELECT * FROM `think_user` WHERE ( `id` = 1 )

2.

var_dump($user->scope('sql2')->select());

得到的SQL查询语句为: SELECT * FROM `think_user` ORDER BY `date` DESC LIMIT 2

3、

var_dump($user->scope('sql2')->scope('sql1')->select());

得到的SQL语句为:

SELECT * FROM `think_user` WHERE ( `id` = 1 ) ORDER BY `date` DESC LIMIT 2

4.

var_dump($user->scope()->select());

得到的SQL语句为: SELECT * FROM `think_user` WHERE ( `id` = 2 )

这时调用的default数组,也就是在调用scope()里面不需要填入参数

5.

var_dump($user->scope('sql2',array('limit'=>4))->select());

在调用时改变原来sql2的数组的条件,也可以改变全部的

6.

var_dump($user->scope(array('where'=>array('id'=>1),'order'=>'date desc','limit'=>4))->select());

这时是直接写入参数,不调用类里面的参数

7.

var_dump($user->sql1()->select());

这里是把写在类里的数组直接当作方法来调用,效果和调用sql1是一样的。

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

  1. SQL 连贯操作 [1]

    一. 连贯入门 查找到 id 为 1,2,3,4 中按照创建时间的倒序的前两位. 在 Home/controller/UserController.class.php 下插入 1.连贯操作入门 $us ...

  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. LINUX下SYN FLOOD攻击及LINUX下SYN攻防简述

    LINUX下SYN攻防战如下 (一)SYN攻击原理 SYN攻击属于DOS攻击的一种,它利用TCP协议缺陷,通过发送大量的半连接请求,耗费服务器CPU和内存资源.SYN攻击聊了能影响主机外,还可以危害路 ...

  2. THUPC2018 城市地铁规划

    $n$ 个点,你可以随意连成一棵树,一个点的贡献为 $F(度数) \space mod \space 59393$ ,$F$ 为给定多项式函数,不超过 $10$ 次 求这 $n$ 个点的最大贡献,和最 ...

  3. UVA - 11916 Emoogle Grid (组合计数+离散对数)

    假如有这样一道题目:要给一个M行N列的网格涂上K种颜色,其中有B个格子不用涂色,其他每个格子涂一种颜色,同一列中的上下两个相邻格子不能涂相同颜色.给出M,N,K和B个格子的位置,求出涂色方案总数除以1 ...

  4. HihoCoder1445 重复旋律5(后缀自动机)

    重复旋律5 时间限制:10000ms 单点时限:2000ms 内存限制:512MB 描述 小Hi平时的一大兴趣爱好就是演奏钢琴.我们知道一个音乐旋律被表示为一段数构成的数列. 现在小Hi想知道一部作品 ...

  5. andriod&linux&c函数原型

    1.dlopen 功能:打开一个动态链接库,并返回动态链接库的句柄 包含头文件: #include <dlfcn.h> 函数定义: void * dlopen( const char * ...

  6. Linux 命令行监视显卡使用情况

    本文由Suzzz原创,发布于 http://www.cnblogs.com/Suzzz/p/4106581.html ,转载请保留此声明. 在使用GPU做计算,比如跑 Deep Learning代码的 ...

  7. loj 2542 随机游走 —— 最值反演+树上期望DP+fmt

    题目:https://loj.ac/problem/2542 因为走到所有点的期望就是所有点期望的最大值,所以先最值反演一下,问题变成从根走到一个点集任意一点就停止的期望值: 设 \( f[x] \) ...

  8. 序章:为什么学习使用kotlin、及kotlin的一些碎碎念

    为什么使用kotlin? 当然是因为项目目前的开发语言是kotlin啊! 一方面是想能够尽快适应项目,另一方面,kotlin这门语言独特的语法,确实很吸引我,也让我意识到java代码在某些程度上的繁琐 ...

  9. hihoCoder#1122(二分图最大匹配之匈牙利算法)

    时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 上一回我们已经将所有有问题的相亲情况表剔除了,那么接下来要做的就是安排相亲了.因为过年时间并不是很长,所以姑姑希望能够尽可 ...

  10. struts2获得需要的文件或者访问路径

    在struts2中,上传文件的时候遇到一个很好用但是失效的方法,找到如下替代.并且测试了一下request可以得到的相关路径. 得到request对象: HttpServletRequest requ ...