ThinkPHP CURD特性

C
m=new Model(‘User’);m=M(‘User’);
m->字段名=值m->add();
返回值是新增的id号
U
m=M(‘User’);data[‘id’]=1;
data[‘username’]=’ztz2′;m->save(data); 返回值是受影响行数
D
m=M(‘User’);
m->delete(2); //删除id为2的数据m->where(‘id=2’)->delete(); //与上面效果相同,也是删除id为2的数据,返回值是受影响行数
R
m=new Model(‘User’);m=M(‘User’);
select
m->select();//获取所有数据,以数组形式返回
find
m->find(id);//获取单条数据
getField(字段名)//获取一个具体的字段值
arr=m->where(‘id=2’)->getField(‘username’);
Count 获取个数
m=M(‘User’);
date[‘username’]=’abc’;c=m->where(date)->count();
max //获取最大数
min //获取最小数
avg //获取平均数
sum //获取总和

连贯操作

1.where 帮助我们设置查询条件
2.order 对结果进行排序
arr=m->order(‘id desc’)->select();
arr=m->order(array(‘id’=>’desc’,’sex’=>’asc’))->select();
3.limit 限制结果
limit(2,5)
limit(‘2,5’)
limit(10)//limit(0,10)
4.field 设置查询字段
field(‘username as name,id’)
field(array(‘username’=>’name’,’id’)
field(‘id’,true) //获取除了id以外的所有字段
5.table
6.group
7.having

补充
alias 用于给当前数据表定义别名 字符串
page 用于查询分页(内部会转换成limit) 字符串和数字
join* 用于对查询的join支持 字符串和数组
union* 用于对查询的union支持 字符串、数组和对象
distinct 用于查询的distinct支持 布尔值
lock 用于数据库的锁机制 布尔值
cache 用于查询缓存 支持多个参数(以后在缓存部分再详细描述)
relation 用于关联查询(需要关联模型扩展支持) 字符串
validate 用于数据自动验证 数组
auto 用于数据自动完成 数组
filter 用于数据过滤 字符串
scope* 用于命名范围 字符串、数组

==================数据库设置====================

         'DB_TYPE'=>'mysql',   //设置数据库类型
         'DB_HOST'=>'localhost',//设置主机
         'DB_NAME'=>'thinkphp',//设置数据库名
         'DB_USER'=>'root',    //设置用户名
         'DB_PWD'=>'',        //设置密码
         'DB_PORT'=>'3306',   //设置端口号
         'DB_PREFIX'=>'tp_',  //设置表前缀

也可以使用DSN方法进行配置

         'DB_DSN'=>'mysql://root:@localhost:3306/thinkphp',   *如果两种方式同时存在,以DSN方式为优先

查询方式

普通查询方式
a、字符串
arr=m->where(“sex=0 and username=’abc'”)->find();
b、数组
data[‘sex’]=0;data[‘username’]=’abc’;
arr=m->where(data)->find();
注意:这种方式默认是and的关系,如果使用or关系,需要添加数组值
data[‘sex’]=0;
data[‘username’]=’gege’;data[‘_logic’]=’or’;

表达式查询方式
EQ 等于
data[‘id’]=array(‘eq’,6);arr=m->where(data)->select();
NEQ 不等于
GT 大于
EGT 大于等于
LT 小于
ELT 小于等于
LIKE 模糊查询
data[‘username’]=array(‘like’,’%ge’);arr=m->where(data)->select();
NOTLIKE (notlike中间没有空格)
data[‘username’]=array(‘notlike’,’%ge%’);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’,’%五%’),’gege’,’or’);

直接查询
a、query 主要数处理读取数据的
成功返回数据的结果集
失败返回boolean false
m=M();result=m->query(“select * from t_user where id >50”);
var_dump(
result);
b、execute 用于更新个写入操作
成功返回影响行数
失败返回boolean false
m=M();result=$m->execute(“insert into t_user(username) values(‘ztz3’)”);
var_dump($result);