原文:ThinkPHP 的模型使用详细介绍--模型的核心(七)

注意:本节是ThinkPhp框架对数据操作的核心处理部分

大家还是在这里看清楚可以将其剪切放到代码编辑器中查看

本章节给大家着重介绍模型的:

一、普通查询方式    、 二、表达式查询方式 、 三、区间查询      、  四、统计查询  、    五、SQL直接查询

回顾初步模型的-“增删改查”:

// 直接连接数据库,但是得先去配置文件中配置下才行

class IndexAction extends Action {

public function addDB(){

//对应数据库的表 ,一定要对应数据库的表名  大小没关系

$user =new Model('Leyangjun');

//$user = M('Leyangjun');  //等同上面的new Model()

$arr = $user ->select();

var_dump($arr);

}

}

//对数据库的 增删改查   操作(简称:CURD)

一:增 -C Create $m->add()

$m=new Model('User');

$m=M('User');

$m->字段名='值'; //$user->name='yangjun';

$m->add(); //返回值是新增的id号



二:删 -D Delete $m->delete()

$m=M('User');

$m->delete(2);               //删除id为2的数据,如果不写2,就会删除全部数据

$count = $m->where('id=2')->delete(); //与上面效果相同,也是删除id为2的数据

//返回值是受影响行数

if($count >0){

$this->success("数据删除成功!");

}else{

} $this->error("数据删除失败!"); 

三:改 -U Update $m->save()

$m=M('User');

$data['id']=1;

$data['name']='leyangjun';  //将id=1的name值改成leyangjun

$m->save($data);  //返回值是受影响行数



四:查 -R Read   $m->select()

$m=new Model('User');  ==   $m=M('User');

1:select

$m->select();
//获取所有数据,以数组形式返回

2:find

$m->find($id);//获取单条数据 默认取的是id=1的数据,想取第二条find(2)

3:getField(字段名)//获取一个具体的字段值

$arr = $m->getField('name'); //获取一个具体的字段值,默认读取的是第一条的name

$arr=$m->where('id=2')->getField('username'); //连贯操作,取id=2对应字段为“username”的值

下面对模型的详细介绍:

一、普通查询方式

a、字符串 (不推荐使用,因为:只要是字符串值,不加单引号会报错查不到数据)

$arr=$m->where("sex=0 and username='gege'")->find();  //取一条



b、数组(推荐使用,标准)

$data['sex']=0;

$data['username']='gege';

$arr=$m->where($data)->find();

=>注意:这种方式默认条件是and的关系,如果使用or关系,需要添加数组值

$data['sex']=0;

$data['username']='gege';

$data['_logic']='or';//要想查询条件是OR的条件,一定要加这个





$data['id']=array(2,3,4,'or'); //查id=2 or id=3 or id=4

$arr = $user->where($data)->select();

二、表达式查询方式

//默认是and  name='lekey' or name='viplekey' or name='leyangjun'

//$data['name']=array('lekey','viplekey','leyangjun','or'); 

$data['id']=array('lt',6);   //查询id大于6  ==>注意不区分大小写

$arr=$m->where($data)->select();

EQ 等于     

NEQ不等于

GT 大于

EGT大于等于

LT 小于

ELT小于等于

LIKE 模糊查询

$data['username']=array('like','%yang');

$arr=$m->where($data)->select();

NOTLIKE //like的取反

$data['username']=array('notlike','%ge%'); //notlike中间没有空格

$arr=$m->where($data)->select();





注意:如果一个字段要匹配多个通配符

$data['username']=array('like',array('%ge%','%2%','%五%'),'and');//如果没有第三个值,默认关系是or关系

$arr=$m->where($data)->select();

BETWEEN

$data['id']=array('between',array(5,7));

$arr=$m->where($data)->select();

//SELECT * FROM `tp_user` WHERE ( (`id` BETWEEN 5 AND 7 ) )

$data['id']=array('not between',array(5,7));//注意,not 和 between中间一定要有空格

$arr=$m->where($data)->select();

IN

$data['id']=array('in',array(4,6,7));

$arr=$m->where($data)->select();

//SELECT * FROM `tp_user` WHERE ( `id` IN (4,6,7) )





$data['id']=array('not in',array(4,6,7));

$arr=$m->where($data)->select();

//SELECT * FROM `tp_user` WHERE ( `id` NOT IN (4,6,7) )





三、区间查询

$data['id']=array(array('gt',4),array('lt',10));//默认关系是 and 的关系

//SELECT * FROM `tp_user` WHERE ( (`id` > 4) AND (`id` < 10) ) 





$data['id']=array(array('gt',4),array('lt',10),'or') //关系就是or的关系





$data['name']=array(array('like','%2%'),array('like','%五%'),'leyangjun','or');

//SELECT * FROM 'TP_USER' WHERE (('username' LIKE '%2%') OR ('username' LIKE '%五%') OR ('USERNAME' ='leyangjun'));

四、统计查询

count //获取个数

$user = new Model('Leyangjun');

$total = $user->count();

/*带条件统计

//$data['name'] = 'leyangjun';

//$total = $user->where($data)->count(); */

echo $total;exit;

max   //获取最大数

min   //获取最小数

avg   //获取平均数

sum   //获取总和



五、SQL直接查询

一种、query 主要数处理(“读取”)数据的

成功返回数据的结果集

失败返回boolean false

$m=M();  //M()空的mode对象就行

$result=$m->query("select *  from t_user where id >50");

var_dump($result);

二种、execute 用于(“更新和写入”)操作

成功返回影响行数

失败返回boolean false

$m=M();

$result=$m->execute("insert into t_user(`username`) values('leyangjun')");

var_dump($result);

ThinkPHP 的模型使用详细介绍--模型的核心(七)的更多相关文章

  1. CSS盒模型属性详细介绍

    一.概述 CSS盒模型是定义元素周围的间隔.尺寸.外边距.边框以及文本内容和边框之间内边距的一组属性的集合. 示例代码: <!DOCTYPE html> <html lang=&qu ...

  2. Django框架详细介绍---模型---ORM

    一.概述 ORM(Object Relational Mapping),全称:对象关系映射,简单的说就是通过创建类.实例化出对象的方法,使得类.对象.对象的属性能够和数据库中的表.记录.字段意义对应. ...

  3. ios开发——实用技术篇&Pist转模型详细介绍

    Pist转模型详细介绍 关于Plist转模型在iOS开发中是非常常见的,每开一一个项目或者实现一个功能都要用到它,所以今天就给大家讲讲Plist怎么转成模型数据, 前提:必须有一个Plist文件或者通 ...

  4. 模型汇总24 - 深度学习中Attention Mechanism详细介绍:原理、分类及应用

    模型汇总24 - 深度学习中Attention Mechanism详细介绍:原理.分类及应用 lqfarmer 深度学习研究员.欢迎扫描头像二维码,获取更多精彩内容. 946 人赞同了该文章 Atte ...

  5. C++11 并发指南七(C++11 内存模型一:介绍)

    第六章主要介绍了 C++11 中的原子类型及其相关的API,原子类型的大多数 API 都需要程序员提供一个 std::memory_order(可译为内存序,访存顺序) 的枚举类型值作为参数,比如:a ...

  6. ThinkPHP页面跳转、Ajax技巧详细介绍(十八)

    原文:ThinkPHP页面跳转.Ajax技巧详细介绍(十八) ThinkPHP页面跳转.Ajax技巧详细介绍 一.页面跳转 $this->success('查询成功',U('User/test' ...

  7. ThinkPHP使用分组详细介绍(十七)

    原文:ThinkPHP使用分组详细介绍(十七) 使用分组(模块分组) *就是将多个项目合并到一个项目/应用去(就是Home.Admin) ---分组不分组看自己的建立项目习惯,个人习惯用根目录配置生成 ...

  8. thinkPHP 空模块和空操作、前置操作和后置操作 详细介绍(十四)

    原文:thinkPHP 空模块和空操作.前置操作和后置操作 详细介绍(十四) 本章节:介绍 TP 空模块和空操作.前置操作和后置操作 详细介绍 一.空模块和空操作 1.空操作 function _em ...

  9. thinkPHP 模板中的语法知识 详细介绍(十二)

    原文:thinkPHP 模板中的语法知识 详细介绍(十二) 本章节:介绍模板中的语法,详细的语法介绍 一.导入CSS和JS文件    ==>记住常量的是大写 1.css link .js  sc ...

随机推荐

  1. 枚举+搜索 hdu-4431-Mahjong

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4431 题目大意: 给一副牌,求出所有能糊的牌. 解题思路: 枚举每一张牌,看能不能糊. 因为一共只有 ...

  2. 娓娓道来c指针 (0)c语言的梦魇:c指针

    (0)c语言的梦魇:c指针 序 c语言中有一个重点:c指针.它也是一个难点.当然,这是一句废话:重点往往也是难点.在c标准中,对指针的定义是这种: 指针的类型是derived from其他类型,也就是 ...

  3. NEC协议

    注意: 用示波器在接收头抓的电平看起来和NEC协议刚好相反, 那是因为:HS0038B 这个红外一体化接收头,当收到有载波的信号的时候,会输出一个低电平,空闲的时候会输出高电平. 具体情况,具体分析. ...

  4. Hauntbox:用于控制你的自己主动化、电子创意家居的开源硬件盒子

    Hauntbox 是一个开源硬件控制器,能够满足用随意传感器和控制器建立复杂的.自己主动化的萦绕在心头的电子项目. 它不须要焊接或者预先学什么知识.是全然可控制.并与Arduino插板兼容. 无需编程 ...

  5. PHP $_SERVER

    $_SERVER 是一个包括了诸如头信息(header).路径(path).以及脚本位置(script locations)等等信息的数组.这个数组中的项目由 Web server创建.不能保证每一个 ...

  6. ASC(22)H(大数+推公式)

    High Speed Trains Time Limit: 4000/2000MS (Java/Others)Memory Limit: 128000/64000KB (Java/Others) Su ...

  7. PEM文件格式具体解析

    PEM文件格式存档 Author:Roson sun sunxiao@tomonline-inc.com Time:2006-4-11 1.  描写叙述: Openssl使用PEM(RFC 1421- ...

  8. oncreate 测量尺寸

    在android中,在oncreate里面只是将布局信息设置好,并没有进行布局,因此是没法进行测量view或者屏幕的长高,可以通过下面的observer来观察,当view布局完成之后会回调下面的两个接 ...

  9. linux下C/C++IDE比较——Code::Blocks

    工欲善其事,必先利其器.用了这么久的linux,现在比较主流的几个C/C++的IDE基本已都用过了,现在来对他们做一下简单的比较. 1.VIM首先要说的是VIM.我认为,VIM只是一个编辑器,不能算是 ...

  10. Servlet的学习之Request请求对象(1)

    在本篇中开始对Servlet中的HttpServletRequest请求对象进行学习,请求对象同响应对象一样,我们可以根据该对象中的方法获取例如请求行,请求头和请求实体数据的方法. 在本篇中先对Htt ...