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

简介: 原文: ThinkPHP 的模型使用详细介绍--模型的核心(七) 注意:本节是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);

目录
相关文章
|
4月前
|
机器学习/深度学习 数据可视化 PyTorch
PyTorch基础之模型保存与重载模块、可视化模块讲解(附源码)
PyTorch基础之模型保存与重载模块、可视化模块讲解(附源码)
46 1
|
6天前
|
机器学习/深度学习 PyTorch 算法框架/工具
PyTorch中的自定义层与模块开发
【4月更文挑战第18天】PyTorch教程:通过继承`nn.Module`创建自定义层和模块。自定义层需实现`__init__`(初始化参数)和`forward`(前向传播逻辑)方法。示例代码展示了一个简单的`CustomLinear`层和包含该层及ReLU激活的`CustomModule`。自定义模块可组合多个层,如`SimpleNet`模型中使用两个`CustomModule`。这使得构建满足特定需求的复杂神经网络成为可能。
|
4月前
|
机器学习/深度学习 传感器 算法
PyTorch基础之优化器模块、训练和测试模块讲解(附源码)
PyTorch基础之优化器模块、训练和测试模块讲解(附源码)
67 0
|
11月前
|
数据采集 算法 数据可视化
MMdetection框架速成系列 第03部分:简述整体构建细节与模块+训练测试模块流程剖析+深入解析代码模块与核心实现
按照抽象到具体方式,从多个层次进行训练和测试流程深入解析,从最抽象层讲起,到最后核心代码实现,希望帮助大家更容易理解 MMDetection 开源框架整体构建细节
506 0
|
XML JSON 数据格式
gin框架学习-模型绑定和验证
对绑定解析到结构体上的参数,自定义验证功能。比如我们想name不为空的同时,不能为admin的时候,就无法 binding 现成的方法。
225 0
gin框架学习-模型绑定和验证
|
SQL NoSQL PHP
Thinkphp中模型的正确使用方式,ORM的思想概念
对象-关系映射(OBJECT-RELATIONAL MAPPING,简称ORM) 这是在面向对象编程发展过程中演变出来的一种思想、行为概念。 主要用途是:把对象模型表示的对象映射到基于sql的关系模型数据库结构中去。 当改变这个对象自身的属性或者调用该对象的方法时,相对应的是执行某些sql语句。 这样子编写代码的人员就可以更好地编写业务逻辑,而非重复地编写增删改查sql语句。
192 0
|
运维 安全 JavaScript
DEMO 模型 -- 成为更好的开发者
DEMO 模型 -- 成为更好的开发者
143 0
|
JavaScript vr&ar 开发者
综合案例(controller层编写) | 学习笔记
快速学习综合案例(controller层编写)。
107 0
|
关系型数据库 MySQL 数据库连接
ThinkPHP数据库查询之模型深度解(2)
ThinkPHP数据库查询之模型深度解
147 0
ThinkPHP数据库查询之模型深度解(2)
|
SQL PHP 数据库
ThinkPHP数据库查询之模型深度解(1)
ThinkPHP数据库查询之模型深度解
119 0
ThinkPHP数据库查询之模型深度解(1)