TP-----CURD

 create()创建数据----整理数据

  在数据库添加等操作之前,我们首先需要对数据进行创建。何为数据创建,就是接受提
交过来的数据,比如表单提交的 POST(默认)数据。接受到数据后,还可以对数据进行有
效的验证、完成、生成等工作。

值得注意的是:

  这里 create()方法就是数据创建,数据的结果就是提交的 POST 数据的键值对。
特别注意的是:提交过来的字段和数据表字段是对应的,否则无法解析。

手动创建数据---即使是手动创建的数据也得与表字段对应,否则无法被解析

 //通过数组手工获取数据,覆盖提交的
$user = M('User');
$data['user'] = $_POST['user'];
$data['email'] = $_POST['email'];
$data['date'] = date('Y-m-d H:i:s'); //和数据表对应,否则无效
var_dump($user->create($data));

利用对象来覆盖数据

 //通过对象手工获取数据,覆盖提交的
$user = M('User');
$data = w new \stdClass();
$data->user = $_POST['user'];
$data->email = $_POST['email'];
$data->date = date('Y-m-d H:i:s');

更改默认POST的方式,为GET

 //默认是$_POST,传递$_GET修改
$user = M('User');
var_dump($user->create($_GET));

提高:

create()方法可以传递第二个参数, 将要操作的模式, 有两种: Model::MODEL_INSERT
和 Model::MODEL_UPDATE,即新增和修改。当没有指定的时候,系统会根据数据源是否包
含主键来自动判断,如果包含主键,则就是修改操作。

 //设置将要新增操作
$user = M('User');
var_dump($user->create($_POST, Model:: MODEL_INSERT ));

create()方法的内部工作分为 9 步:
1.获取数据源(默认是 POST) ;
2.验证数据合法性(非数据或对象会过滤) ,失败则返回 false;
3.检查字段映射;
4.判断数据状态(新增还是修改) ;
5.数据自动验证,失败则返回 false;
6.表单令牌验证,失败则返回 false;
7.表单数据赋值(过滤非法字段和字符串处理) ;
8.数据自动完成;
9.生成数据对象(保存在内存) 。

create()方法可以配合连贯操作配合数据创建,支持的连贯操作有:
1.field,用于定义合法的字段;
2.validate,用于数据自动验证;
3.auto,用于数据自动完成;
4.token,用于令牌验证。

 //限制可操作的字段
$user = M('User');
var_dump($user->field('user')->create());
//在模型类里限制字段
s class UserModel s extends Model {
d protected $insertFields = 'user';
d protected $updateFields = 'user';
}

数据写入-----add(),返回ID

 //新增一条数据
$user = M('User');
$data['user'] = '李炎恢';
$data['email'] = 'yc60.com@gmail.com';
$data['date'] = date('Y-m-d H:i:s');
$user->add($data);
//结合create()方法
$user = M('User');
$data = $user->create();
$data['date'] = date('Y-m-d H:i:s');
$user->add($data);

add()方法支持的连贯操作有:
1.table,定义数据表名称;
2.data,指定要写入的数据对象;
3.field,定义要写入的字段;
4.relation,关联查询;
5.validate,数据自动验证;
6.auto,数据自动完成;
7.filter,数据过滤;
8.scope*,命名范围;
9.bind,数据绑定操作;
10.token,令牌验证;
11.comment,SQL 注释;

 //使用data连贯方法
$user = M('User');
$data = $user->create();
$data['date'] = date('Y-m-d H:i:s');
$user->data($data)->add();
//data连贯方法 支持字符串、数组、对象
$user = M('User');
$data = 'user=星矢&mail=xinshi@qq.com&date='.date('Y-m-d H:i:s');
$user->data($data)->add();

数据读取

主要有: select()--显示所有的数据

     find()--显示所有数据中的第一条

    getFeild()--根据字段获取数据

支持17连贯操作,前边已经介绍过

1.where,查询或更新条件;
2.table,要操作的数据表名称;
3.alias,数据表别名;
4.field,查询字段;

5.order,结果排序;
6.group,查询分组;
7.having,分组再查询;
8.join,多表链接查询;
9.union,合并 SELECT;
10.distinct,取唯一值;
11.lock,锁;
12.cache,缓存;
13.relation,关联查询;
14.result,数据转换;
15.scope,命名范围;
16.bind,数据绑定操作;
17.comment,SQL 注释。

 //显示默认第一条数据
$user = M('User');
var_dump($user->find()); //可以传递数字参数,AR 模式
//显示默认所有数据
$user = M('User');
var_dump($user->select()); //可以传递数组形式的 SQL
//获取第一条user字段的值
$user = M('User');
var_dump($user->getField('user'));
//获取所有user字段的值
$user = M('User');
var_dump($user->getField('user', true));
//传递多个字段,获取所有
$user = M('User');
var_dump($user->getField('user,email'));
//没有分隔符和select相同,id冒号分隔
$user = M('User');
var_dump($user->getField('id,user,email',':'));
//限制2条数据
$user = M('User');
var_dump($user->getField('id,user,email',2));

数据更新---save()--修改,setField()--设置某一个值,setInc()--累加,setDec()--累减

数据更新的 save()方法支持的连贯方法有:
1.where,查询或更新条件;
2.table,要操作的数据表名称;
3.alias,数据表别名;
4.field,查询字段;
5.order,结果排序;
6.lock,锁;
7.relation,关联查询;
8.scope,命名范围;
9.bind,数据绑定操作;
10.comment,SQL 注释。

 //修改第一条数据
$user = M('User');
$data['user'] = '蜡笔大新';
$data['email'] = 'daxin@qq.com';
$map['id'] = 1;
$user->where($map)->save($data); //成功后返回 1,否则 0
//默认主键为条件
$user = M('User');
$data['id'] = 1;
$data['user'] = '蜡笔小新';
$data['email'] = 'xiaoxin@163.com';
$user->save($data);
//结合create()
$user = M('User');
$user->create(); //POST必须包含主键
$user->save();
//修改某一个值
$user = M('User');
$map['id'] = 1;
$user->where($map)->setField('user', '蜡笔大新');
//统计累计,累加累减
$user = M('User');
$map['id'] = 1;
$user->where($map)->setInc('count',1); //累加,setDec 累减

数据删除----delete()

delete()方法支持的连贯操作有:
1.where,查询或更新条件;
2.table,要操作的数据表名称;
3.alias,数据表别名;
4.order,结果排序;
5.lock,锁;
6.relation,关联查询;
7.scope,命名范围;
8.bind,数据绑定操作;
9.comment,SQL 注释。

 //直接删除主键(id=17)
$user = M('User');
$user->delete(17);
//根据ID来删除
$user = M('User');
$map['id'] = 16;
$user->where($map)->delete();
//批量删除多个
$user = M('User');
$user->delete('1,3,5');
//删除count为0且按时间倒序的前五个
$user = M('User');
$map['count'] = 0;
$user->where($map)->order(array('date'=>'DESC'))->limit(5)->delete();
//删除所有数据,谨慎
$user = M('User');
echo $user->where('1')->delete();

ActiveReocrd模式  AR模式,只有对比才能深刻的理解,这种方法很方便

 //添加一条数据
$user = M('User');
$user->user = '火影忍者';
$user->email = 'huoyin@qq.com';
$user->date = date('Y-m-d H:i:s');
$user->add();
//结合create
$user = M('User');
$user->create();
$user->date = date('Y-m-d H:i:s');
$user->add();
//找到主键为4的值
$user = M('User');
var_dump($user->find(4));
//查找user=蜡笔小新的记录
$user = M('User');
var_dump($user->getByUser('蜡笔小新'));
//输出user
o echo $user->user;
//通过主键查询多个
$user = M('User');
var_dump($user->select('1,2,3'));
//修改一条数据
$user = M('User');
$user->find(1);
$user->user = '蜡笔老新';
$user->save();
//删除当前找到的数据
$user = M('User');
$user->find(11);
$user->delete();
//删除主键为10的数据
$user = M('User');
$user->delete(10);
//删除主键为10,11的数据
$user = M('User');
$user->delete('10,11');

字段映射---一般情况不用,直接对应就行

 //字段映射可以将表单里的 name 名称对应到数据表里的字段,这样防止系统
//自动屏蔽掉
//不对应的 POST 值。
//字段映射
d protected $_map = array(
'xingming'=>'user',
'youxiang'=>'email',
);
//字段映射获取
$user = D('User');
var_dump($user->create());

掌握Thinkphp3.2.0----CURD的更多相关文章

  1. yii2.0 curd操作

    $customer=new Customer();//插入操作 $customer->name='小熊'; $customer->save(); //修改操作 $model=Custome ...

  2. yii2.0 curd操作数据写法

    一.执行原生sql查询,创建yii\db\Command         insert(),update(),delete()直接构建,相应的sql语句 查: 1.查询一条 \Yii::$app-&g ...

  3. YII 1.0 常用CURD写法

    <?php //yii1.0 curd简单写法 //查询 Yii::app()->db->createCommand($sql)->queryAll();//查询所有行数据 ​ ...

  4. 掌握Thinkphp3.2.0----模型初步

    1.为什么要学习框架?框架是什么? 简单的说就是为了简单,提高开发的效率.至于什么是框架(一种规范),现在的我还不是很理解,容后再议. 学习框架最重要的就是遵循,按照开发者的意图来使用该框架. 2.t ...

  5. 使用mybatis plus自动生成controller、service、dao、mapper、entity代码

    官网:http://mp.baomidou.com(这个项目不仅仅可以用于代码生成,还有分页等其他功能,是对mybatis的一层封装) 要求:基于sql自动生成domain.controller.se ...

  6. 【LeetCode】1041. Robot Bounded In Circle 解题报告(Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 找规律 日期 题目地址:https://leetco ...

  7. ZAM 3D 制作简单的3D字幕 流程(二)

    原地址:http://www.cnblogs.com/yk250/p/5663907.html 文中表述仅为本人理解,若有偏差和错误请指正! 接着 ZAM 3D 制作简单的3D字幕 流程(一) .本篇 ...

  8. ZAM 3D 制作3D动画字幕 用于Xaml导出

    原地址-> http://www.cnblogs.com/yk250/p/5662788.html 介绍:对经常使用Blend做动画的人来说,ZAM 3D 也很好上手,专业制作3D素材的XAML ...

  9. 微信小程序省市区选择器对接数据库

    前言,小程序本身是带有地区选着器的(网站:https://mp.weixin.qq.com/debug/wxadoc/dev/component/picker.html),由于自己开发的程序的数据是很 ...

  10. osg编译日志

    1>------ 已启动全部重新生成: 项目: ZERO_CHECK, 配置: Debug x64 ------1> Checking Build System1> CMake do ...

随机推荐

  1. java13

    1:登录注册案例(理解) 2:Set集合(理解) (1)Set集合的特点 无序,唯一 (2)HashSet集合(掌握) A:底层数据结构是哈希表(是一个元素为链表的数组) B:哈希表底层依赖两个方法: ...

  2. iOS 向客户发送xcarchive文件(整理中)

    由于安全的原因,客户不会把app的 distribution provisioning profile给开发者的,但是可以给一个development provisioning profile.这种情 ...

  3. 昨天开发引入的两个错误--Parcelable

    以下的代码有两处明显的错误,一不小心就会写出如下错误的代码,其中第2个问题调试起来很麻烦: 1 public class AddedBannerInfo implements Parcelable { ...

  4. iOS 多线程

    一 多线程基础 1.进程:进程就是系统中正在运行的应用程序.每个进程是相互独立的且都运行在各自受保护的运行空间内. 比如同时打开迅雷.Xcode,系统就会分别启动2个进程. 2.线程:进程在执行任务是 ...

  5. NHibernate3快速上手教程FluentNHibernate配置与DBHelper

    很多学习NHibernate的新手很容易卡在配置文件这一关,正所谓万事开头难,上手后再配合官方文档就比较容易了. 网上关于配置文件的资料非常多,但由于版本的问题,许多老的教程中都没有明确指出类库的版本 ...

  6. 对oracle数据库Blob字段的操作

    java实体类 定义类型 byte[] private byte[] str_blob hibernate映射文件类型oracle.sql.BLOB <property name="s ...

  7. 无废话ExtJs 入门教程二十一[继承:Extend]

    无废话ExtJs 入门教程二十一[继承:Extend] extjs技术交流,欢迎加群(201926085) 在开发中,我们在使用视图组件时,经常要设置宽度,高度,标题等属性.而这些属性可以通过“继承” ...

  8. ENode 1.0 - Saga的思想与实现

    开源地址:https://github.com/tangxuehua/enode 因为enode框架的思想是,一次修改只能新建或修改一个聚合根:那么,如果一个用户请求要涉及多个聚合根的新建或修改该怎么 ...

  9. HTML5+CSS3+Jquery实现纯手工的垂直时光轴【附源码】

    前言 由于工作中需要,系统中需要记录不同时间发生的事件,为了提升用户体验,决定用时光轴来实现.[据说这个东西挺火的,QQ空间和FB都在用...] 这个时光轴是在 三生石上 这位博主的时光轴基础上修改的 ...

  10. DevExpress的GridControl的实时加载数据解决方案(取代分页)

    http://blog.csdn.net/educast/article/details/4769457 evExpress是一套第三方控件 其中有类似DataGridView的控件 今天把针对Dev ...