ThinkPHP 的模型使用详细介绍--模型的核心(七)
原文: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 的模型使用详细介绍--模型的核心(七)的更多相关文章
- CSS盒模型属性详细介绍
一.概述 CSS盒模型是定义元素周围的间隔.尺寸.外边距.边框以及文本内容和边框之间内边距的一组属性的集合. 示例代码: <!DOCTYPE html> <html lang=&qu ...
- Django框架详细介绍---模型---ORM
一.概述 ORM(Object Relational Mapping),全称:对象关系映射,简单的说就是通过创建类.实例化出对象的方法,使得类.对象.对象的属性能够和数据库中的表.记录.字段意义对应. ...
- ios开发——实用技术篇&Pist转模型详细介绍
Pist转模型详细介绍 关于Plist转模型在iOS开发中是非常常见的,每开一一个项目或者实现一个功能都要用到它,所以今天就给大家讲讲Plist怎么转成模型数据, 前提:必须有一个Plist文件或者通 ...
- 模型汇总24 - 深度学习中Attention Mechanism详细介绍:原理、分类及应用
模型汇总24 - 深度学习中Attention Mechanism详细介绍:原理.分类及应用 lqfarmer 深度学习研究员.欢迎扫描头像二维码,获取更多精彩内容. 946 人赞同了该文章 Atte ...
- C++11 并发指南七(C++11 内存模型一:介绍)
第六章主要介绍了 C++11 中的原子类型及其相关的API,原子类型的大多数 API 都需要程序员提供一个 std::memory_order(可译为内存序,访存顺序) 的枚举类型值作为参数,比如:a ...
- ThinkPHP页面跳转、Ajax技巧详细介绍(十八)
原文:ThinkPHP页面跳转.Ajax技巧详细介绍(十八) ThinkPHP页面跳转.Ajax技巧详细介绍 一.页面跳转 $this->success('查询成功',U('User/test' ...
- ThinkPHP使用分组详细介绍(十七)
原文:ThinkPHP使用分组详细介绍(十七) 使用分组(模块分组) *就是将多个项目合并到一个项目/应用去(就是Home.Admin) ---分组不分组看自己的建立项目习惯,个人习惯用根目录配置生成 ...
- thinkPHP 空模块和空操作、前置操作和后置操作 详细介绍(十四)
原文:thinkPHP 空模块和空操作.前置操作和后置操作 详细介绍(十四) 本章节:介绍 TP 空模块和空操作.前置操作和后置操作 详细介绍 一.空模块和空操作 1.空操作 function _em ...
- thinkPHP 模板中的语法知识 详细介绍(十二)
原文:thinkPHP 模板中的语法知识 详细介绍(十二) 本章节:介绍模板中的语法,详细的语法介绍 一.导入CSS和JS文件 ==>记住常量的是大写 1.css link .js sc ...
随机推荐
- splinter python浏览器自动化操作,模拟浏览器的行为
Splinter可以非常棒的模拟浏览器的行为,Splinter提供了丰富的API,可以获取页面的信息判断当前的行为所产生的结果 最近在研究网站自动登录的问题,涉及到需要实现浏览器自动化操作,网上有 ...
- JS乘法口诀表(一行代码)
(function(c){for(i=1;i<=9;i++){var s='';for(j=1;j<=i;j++){s+=i+'X'+j+'='+i*j+'\t';}c.debug(s); ...
- UVA 10815 Andy's First Dictionary(字符处理)
Andy, 8, has a dream - he wants to produce his very own dictionary. This is not an easy task for him ...
- Swift - 使用MapKit显示地图,并在地图上做标记
通过使用MapKit可以将地图嵌入到视图中,MapKit框架除了可以显示地图,还支持在地图上做标记. 1,通过mapType属性,可以设置地图的显示类型 MKMapType.Standard :标准地 ...
- hdu 3874 Necklace(线段树)
这道题目和我之前做过的一道3xian大牛出的题目很像,不过总的来说还是要简单一点儿. 计算区间内的值的时候如果两个值相等,只能计算其中一个. 这道题需要将所有的问题输入之后再计算,首先,对所有问题的右 ...
- Delphi - SEH研究
技术交流,DH讲解. 前几天一个朋友在弄游戏外挂想带NP调试,就像自己来捕获游戏的异常.好像就要用到SEH这方面的知识.一起研究了一下,这里看下研究 和 在网上找的资料吧.SEH就是Structure ...
- How to retreive raw post data from HttpServletRequest in java
public static String getPostData(HttpServletRequest req) { StringBuilder sb = new StringBuilder(); t ...
- Poj 3771 hdu 3405
poj 3771 http://poj.org/problem?id=3771 wiki Prim http://zh.wikipedia.org/wiki/%E6%99%AE%E6%9E%97%E5 ...
- Android中ListView.getCount()与ListView.getChildCount()区别和OnScrollListener()各个参数的区别
istView.getCount()(实际上是 AdapterView.getCount()) 返回的是其 Adapter.getCount() 返回的值.也就是“所包含的 Item 总个数”. Li ...
- windows查看某个端口被谁占用
XAMPP Error: Apache shutdown unexpectedly. 解决思路 我建议首先 运行在cmd中运行 (安装目录)apache/bin/httpd.exe 无法启动apach ...