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()); 
时间: 2024-11-08 06:06:32

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

SQL 连贯操作 [2]

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)')-

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

如题: 一对一关联查询时使用relation连贯操作查询后,调用getLastSql()方法输出的sql语句不是一条关联查询语句. 例如: $list = $db->relation(true)->where($where)->order('blogid desc')->limit($Page->firstRow.','.$Page->listRows)->select(); $sql = $db->getLastSql(); 输出的sql语句为: SELE

关于php如何连贯操作类方法(以数据库为例)

关于php如何连贯操作类方法(以数据库为例) 1.下面是我写好的关于mysqli操作数据库的一些常用方法,大神请掠过 1 <?php 2 3 class Db 4 { 5 static private $config = [ 6 'datahost' => '', // 主机名 7 'dataname' => '', // 数据库名 8 'username' => '', // 用户名 9 'password' => '', // 用户密码 10 'charset' =>

第 39 章 ThinkPHP--SQL 连贯操作

本节课,我们将学习 ThinkPHP 模型基础类提供的连贯操作,通过连贯操作可以有效的 提供数据存取的代码清晰度和开发效率,并且支持所有的 CURD 操作. 一.连贯入门 连贯操作使用起来非常简单,比如查找到 id 为 1,2,3,4 中按照创建时间的倒序的前两 位. //连贯操作入门 $user = M('User'); var_dump($user->where('id in (1,2,3,4)')->order('date DESC')->limit(2)->select()

php连贯操作实现

我们在使用一些框架(如ThinkPHP)编码的时候,常用到这样的代码. M('User')->where(array('id'=>1))->field('name')->select(); 这样不仅有利于编码,而且也能让人"心情愉悦"呢.好了,不多说了.让我们看看如何实现的吧? <?php //数据库操作基类[PS:主要功能连贯功能实现] class Db{ //此属性定义要实现连贯操作的方法名 public $sql = array( "fie

TP访问数据库 和 连贯操作

<?php namespace Admin\Controller; use Think\Controller; class MainController extends Controller { public function showList() { echo "hello"; } public function test() { //数据访问 //造模型对象 $nation = D("Nation"); //查询 //$a = $nation->se

ThinkPHP教程_PHP框架之ThinkPHP(八)【CRUD与连贯操作】

一.CRUD ThinkPHP提供了灵活和方便的数据库操作方法,其中最基本的就是CRUD四个操作,只有掌握了最基本的CRUD操作,才能更好的运用更多实用的数据库操作方法 CRUD操作通常与连贯操作配合 1.创建操作 使用add()方法或addAll()方法 ·add()方法 可以直接传入要插入的数据,而且会在插入之前会过滤掉数据表中不存在的字段以及非法的数据类型(例如对象.数组等非标量数据).若当前表有主键自动增长并且插入记录成功的话,则返回所插入记录主键值 如果在执行add()操作之前已经创建

【转】PHP实现连贯操作

[第一种方案 __call] 我们在使用一些框架(如ThinkPHP)编码的时候,常用到这样的代码. M('User')->where(array('id'=>1))->field('name')->select(); 这样不仅有利于编码,而且也能让人"心情愉悦"呢.好了,不多说了.让我们看看如何实现的吧? <?php //数据库操作基类[PS:主要功能连贯功能实现] class Db{ //此属性定义要实现连贯操作的方法名 public $sql = a

PHP类连贯操作的实现方法

PHP中的连贯操作看起来的确很酷,也非常的方便代码的阅读,当然了必须是在OOP中用才行,在过程化的程序中,就没有必要用这种方法了.有实现这个方法的有用_CALL来实现的,而我下面写的这个例子,则不是用_call的,大家可以扩展一下吧. 下面写的这个SQL语句组合类,主要是用于学习的,如果有同学想拿去用,请再完善一下. /* * SQL语句组合实例类,始发文章web开发笔记 * www.chhua.com * 学习用,非专业类 * */ class sql{ private $sql=array(