ThinkPHP 5.数据库基本操作
2015-07-03 20:14
706 查看
新增
普通新增
$User = M("User"); // 实例化User对象 $data['name'] = 'ThinkPHP'; $data['email'] = 'ThinkPHP@gmail.com'; $User->add($data);
连续操作
$User = M("User"); // 实例化User对象 $data['name'] = 'ThinkPHP'; $data['email'] = 'ThinkPHP@gmail.com'; $User->data($data)->add();
使用Create
$User = M("User"); // 实例化User对象 // 根据表单提交的POST数据创建数据对象 $User->create(); $User->add(); // 根据条件保存修改的数据
批量插入数据
$User->addAll($data)
读取
select方法
$User = M("User"); // 实例化User对象 // 查找status值为1的用户数据 以创建时间排序 返回10条数据 $list = $User->where('status=1')->order('create_time')->limit(10)->select();
数组作为查询条件
$User = M("User"); // 实例化User对象 $condition['name'] = 'thinkphp'; $condition['status'] = 1; // 把查询条件传入查询方法 $User->where($condition)->select();
变更多个条件逻辑关系
$User = M("User"); // 实例化User对象 $condition['name'] = 'thinkphp'; $condition['account'] = 'thinkphp'; $condition['_logic'] = 'OR'; // 把查询条件传入查询方法 $User->where($condition)->select();
对象方式查询
$User = M("User"); // 实例化User对象 // 定义查询条件 $condition = new stdClass(); $condition->name = 'thinkphp'; $condition->status= 1; $User->where($condition)->select();
表达式查询
$User = M("User"); // 实例化User对象 // 要修改的数据对象属性赋值 $data['name'] = 'ThinkPHP'; $data['score'] = array('exp','score+1');// 用户的积分加1 $User->where('id=5')->save($data); // 根据条件保存修改的数据
快捷or查询
$User = M("User"); // 实例化User对象 $map['name|title'] = 'thinkphp'; // 把查询条件传入查询方法 $User->where($map)->select();
快捷多字段and查询
$User = M("User"); // 实例化User对象 $map['status&title'] =array('1','thinkphp','_multi'=>true); // 把查询条件传入查询方法 $User->where($map)->select();
区间查询
$map['id'] = array(array('gt',1),array('lt',10)) ;
find方法
$User = M("User"); // 实例化User对象 // 查找status值为1name值为think的用户数据 $User->where('status=1 AND name="think"')->find();
限定field
$User = M("User"); // 实例化User对象 // 获取ID为3的用户的昵称 $nickname = $User->where('id=3')->getField('nickname');
返回一个字段组成的数组
$this->getField('id',true); // 获取id数组
多个字段返回关联数组
$User = M("User"); // 实例化User对象 // 获取所有用户的ID和昵称列表 $list = $User->getField('id,nickname');
限定返回数量
$this->getField('id,name',5); // 限制返回5条记录
left join
$Model->join(' work ON artist.id = work.artist_id')->join('card ON artist.card_id = card.id')->select(); $Model->join('RIGHT JOIN work ON artist.id = work.artist_id')->select();
更多查询方法可以看这里:
http://doc.thinkphp.cn/manual/query.html
更新
条件选择后更新
$User = M("User"); // 实例化User对象 // 要修改的数据对象属性赋值 $data['name'] = 'ThinkPHP'; $data['email'] = 'ThinkPHP@gmail.com'; $User->where('id=5')->save($data); // 根据条件保存修改的数据
连贯操作
$User = M("User"); // 实例化User对象 // 要修改的数据对象属性赋值 $data['name'] = 'ThinkPHP'; $data['email'] = 'ThinkPHP@gmail.com'; //更新时间字段 $data['time']=date("Y-m-d H:i:s", time()); $User->where('id=5')->data($data)->save(); // 根据条件保存修改的数据
更新特定字段
$User = M("User"); // 实例化User对象 // 更改用户的name值 $User-> where('id=5')->setField('name','ThinkPHP');
更新多个字段
$User = M("User"); // 实例化User对象 // 更改用户的name和email的值 $data = array('name'=>'ThinkPHP','email'=>'ThinkPHP@gmail.com'); $User-> where('id=5')->setField($data);
递增递减
$User = M("User"); // 实例化User对象 $User->where('id=5')->setInc('score',3); // 用户的积分加3 $User->where('id=5')->setInc('score'); // 用户的积分加1 $User->where('id=5')->setDec('score',5); // 用户的积分减5 $User->where('id=5')->setDec('score'); // 用户的积分减1
删除
条件删除
$User = M("User"); // 实例化User对象 $User->where('id=5')->delete(); // 删除id为5的用户数据 $User->where('status=0')->delete(); // 删除所有状态为0的用户数据
限定删除数量
$User->where('status=0')->order('create_time')->limit('5')->delete();
事务
启动事务: $User->startTrans(); 提交事务: $User->commit(); 事务回滚: $User->rollback();
本文内容来源:
http://doc.thinkphp.cn/manual/curd.html
http://doc.thinkphp.cn/manual/continuous_operation.html
相关文章推荐
- ThinkPHP 4.使用Session
- PHP 中 Failed to load resource: the server responded with a status of 500 (Internal Server Error)
- php使用face++实现一个简单的人脸识别系统
- WindowManager.LayoutParams(上)
- ZeroMQ + libevent in PHP
- php遍历多维数组改变数组的值
- ThinkPHP3.2创建view并调用view
- PHP 报告分拣和生产理念
- ecshop安装出现问题集合(php版本偏高)
- PHP如何过滤这样的空白字符?
- php中的json_encode函数
- PHP基本语法以及和Java的区别
- php缓存技术(减少数据库服务器压力)
- yii2-更改默认显示的通用主页
- json在PHP中应用技巧
- 在PHP中使用Mysqli操作数据库
- redhat 6.2 搭建zend framework 开发环境
- PHP 上传apk, 解析apk ,以及写入文件到apk包
- php获取结果集的几个方法
- PHP 实现页面静态化