SQL 连贯操作 [1]
一. 连贯入门
查找到 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]的更多相关文章
- SQL 连贯操作 [2]
1.alias 用于设置数据表别名 $user = M('User'); var_dump($user->alias('anothername')->select()); 这时在SQL中的 ...
- 一对一关联查询时使用relation连贯操作查询后,调用getLastSql()方法输出的sql语句
如题: 一对一关联查询时使用relation连贯操作查询后,调用getLastSql()方法输出的sql语句不是一条关联查询语句. 例如: $list = $db->relation(true) ...
- ci连贯操作的limit两个参数和sql是相反的
ci连贯操作的limit两个参数和sql是相反的 db->where("name =",'mary')->ge() name后面要有个空格否则报错当为一个字段 -> ...
- ThinkPhp 3.2 数据的连贯操作
ThinkPHP模型基础类提供的连贯操作方法(也有些框架称之为链式操作),可以有效的提高数据存取的代码清晰度和开发效率,并且支持所有的CURD操作. 使用也比较简单, 假如我们现在要查询一个User表 ...
- thinkPHP--SQL连贯操作
一.连贯入门 连贯操作使用起来非常简单,比如查找到 id 为 1,2,3,4 中按照创建时间的倒序的前两 位. //连贯操作入门 $user = M('User'); var_dump($user-& ...
- 【转】PHP实现连贯操作
[第一种方案 __call] 我们在使用一些框架(如ThinkPHP)编码的时候,常用到这样的代码. M('User')->where(array('id'=>1))->field( ...
- Laravel框架数据库CURD操作、连贯操作
这篇文章主要介绍了Laravel框架数据库CURD操作.连贯操作.链式操作总结,本文包含大量数据库操作常用方法,需要的朋友可以参考下 一.Selects 检索表中的所有行 $users = DB::t ...
- Laravel框架数据库CURD操作、连贯操作总结
这篇文章主要介绍了Laravel框架数据库CURD操作.连贯操作.链式操作总结,本文包含大量数据库操作常用方法,需要的朋友可以参考下 一.Selects 检索表中的所有行 复制代码代码如下: $use ...
- ThinkPHP第十八天(Widget类的使用,连贯操作where IN用法,缓存S函数使用)
1.Widget类的使用方法: 第一步:在Action同级目录中新建Widget文件夹(独立分组需要自己建立) 第二步:根据不同功能在Widget文件夹中建立不同的Widget类,如热门文章HotWi ...
随机推荐
- poj2396有源汇上下界可行流
题意:给一些约束条件,要求算能否有可行流,ps:刚开始输入的是每一列和,那么就建一条上下界相同的边,这样满流的时候就一定能保证流量相同了,还有0是该列(行)对另一行每个点都要满足约束条件 解法:先按无 ...
- Nat123域名设置使用
可以设自己的域名映射到内网ip: http://www.nat123.com/Pages_18_294.jsp 暂时还没学习使用,先保存一下
- https页面 和 http请求的问题
(1)强制升级http 静态资源地址为https地址 https页面中不能使用http请求,http页面中可以使用https请求. 关于在https 页面有一些http的请求,可以在<head& ...
- 自定义php(NON-CORE WORDPRESS FILE) 引用 wordpress
在文件头头添加下面代码,实现此页面可以调用wordpress的内置方法 <?php $parse_uri = explode ( 'wp-content', $_SERVER ['SCRIPT_ ...
- UVA - 1603 Square Destroyer (DLX可重复覆盖+IDA*)
题目链接 给你一个n*n的由火柴组成的正方形网格,从中预先拿掉一些火柴,问至少还需要拿掉多少火柴才能破坏掉所有的正方形. 看到这道题,我第一反应就是——把每根火柴和它能破坏掉的正方形连边,不就是个裸的 ...
- N!的阶乘附带简单大整数类的输入输出(暂时没有深入的了解)
Given an integer N(0 ≤ N ≤ 10000), your task is to calculate N! 我的思路:就想着大整数类去了,才发现自己还不能很好的掌握,其实这是一个大 ...
- 横向排列两个多个div盒子的方法(CSS浮动清除float-clear/inline)/办法
最近在做一个div css切割,昨晚发现了长期以来一直无记录下来的问题!关于兼容IE跟FF的float属性.趁现在还清醒赶紧记下笔记先:一.并排在一行的两个div样式有这种情况:ie或者ff下对于子d ...
- python面向对象-我的理解
参考:博客 Vamei .廖雪峰 面向对象概念 面向对象完全可以按照自然界生物分类法来理解. 当然,它不会有自然界那么复杂. 因为我专业的关系,因此个人觉得微生物来举例很容易理解. 所有的微生物都具有 ...
- CF 85E Guard Towers——二分图染色
题目:http://codeforces.com/contest/85/problem/E 当然是二分.然后连一个图,染色判断是不是二分图即可.方案数就是2^(连通块个数). 别真的连边!不然时间空间 ...
- 修改windows文件的换行符
应用场景: 在办公中,有可能存在,某些命令脚本使用windows下的文本编辑器进行编写 当放到测试环境的Linux中时,运行报错 需要使用的软件:xxd hexdump dos2unix 1.运行w ...