注意:本节是ThinkPhp框架对数据操作的核心处理部分
大家还是在这里看清楚可以将其剪切放到代码编辑器中查看
本章节给大家着重介绍模型的:
一、普通查询方式 、 二、表达式查询方式 、 三、区间查询 、 四、统计查询 、 五、SQL直接查询
回顾初步模型的-“增删改查”:
// 直接连接数据库,但是得先去配置文件中配置下才行
class IndexAction extends Action {
//对数据库的 增删改查 操作(简称:CURD)
一:增 -C Create $m->add()$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);