ThinkPHP5的模型是一种对象-关系映射(Object / Relation Mapping ,简称 ORM)的封装,并且提供了简洁的ActiveRecord实现。一般来说,每个数据表会和一个“模型”对应。

ThinkPHP5 模型类和Db类的区别主要在于对象的封装,Db类的查询默认返回的是数组(或者集合),而模型类返回的是当前的模型对象实例(或者集合),模型是比Db类更高级的数据支持模型关联、模型事件。

ThinkPHP5 模型属性$table 不再是包含表前缀的表名;$name则是包含表前缀的表名。

一般来说,模型的属性名 就是对应的数据表的字段名。

Model模型类

· protected  $name; //包含表前缀的数据表

· protected  $table; //不包含表前缀的数据表,使用的时候要加上表前缀

如: protected  $table = ‘tp_admin_user’;

模型类 的public类型属性 就是对应的表的字段名。如果给模型类的属性不对应字段名的话,会报错。

$user = new User; // User为模型类

$user->user_name = ‘admin’; // user表 user_name 字段

$user->password = md5(‘123456’); // user表 password 字段

$user[‘user_name’]  等同  $user->username;

疑惑:如果此时使用save()方法,会是修改 还是 什么情况?

$user->save(); //此时为新增!!!

因为当 $user对象没有给定 主键的时候,此时为新增; 如果给定主键,此时为修改!

另外一种新增数据为 模型::create();

那么问题来了,什么时候使用save() 或 create()呢?

·新增数据

由此可见,当实例化模型的时候,使用 save() 或 saveAll() 方法进行添加。

如果使用 模型类, 就使用 XXModel::create(); 进行添加

$user = new User; // User为模型类

此时$user->save($data)  或  User::create($data);   两者返回的还是模型的实例化对象,不同的是User模型类create()后 返回的是 新new的对象而已。

--------------------------------------------

批量新增数据

实际操作的时候,是执行了多条的insert into 数据。并非真的一次性插入。


查询

· getBy字段名();  查询对应的单条查询,字段名第一个字母要大写!

如: 查询 level_id字段的值为4的这条信息

$user->getByLevelId(4);

如:查询 name 字段的值为 admin的这条信息

$user->getByName(‘admin’);

$user = new User; //User 为模型类

$user->getBy字段名(‘值’); //返回当前 字段名= 值 的这条信息.

$user->getData(); //可以将单条信息 转换为 数组

注意:getBy字段名(),  如果字段名有”_”, 同样将首字母和_后的首字母转为大写!!!

·get() 可查询主键 或 非主键

如:查询主键为1的单条信息

$user->get(1);

如:表没有主键,可使用数组来传递查询

$data = [‘name’=>’site_name’];

$user->get($data); //查询没有主键的 单条数据

或 使用 where为追加条件

$map = ['level_id'=>2];

$result3 = $model->where($map)->find();


更改

 

$user = new User; //User为模型类

$user->save($data,  $where条件);

Model::update($dasta, $where条件);

上面讲过,如果没有给定主键 此时 $user->save(); 为新增,如果当表中没有主键怎么办?

$user->isUpdate(true)->save();  //强制为更新操作

以下内容为知识扩展,不要拿到实战中,否则潜在问题会困扰很久!!

还有一种情况是  $user = User::get(1); $data = [.. ...]; 如果没有给定主键,是新增吗?

答案是修改!!!  因为$user 是 User::get(1)返回的对象,1就是主键,所以此时为修改,并非进行新增操作!!!

问题又来了,如果我现在就想把$user->save($data);  为新增,该怎么操作?

答: $user->主键 = NULL;  再 $user->isUpdate(false)->save($data); 此时为新增操作。

问题又来了,新增后的数据信息,除了主键,$data中不存在的信息,则是复制User::get(1)默认的数据!!!!! 这招太坑

最好使用 Model::create() 或 干脆直接new Model 再save(),一般不建议使用 User::get(1) 这种直接返回实例化的对象 再进行CURD;


删除操作

Model::destory(主键id);

如: User::destroy(33); // 删除主键33的单条信息

对象->where(条件)->delete();

如:  $user->where(‘id =5 ’)->delete(); //删除主键5的单条信息

学习模型总结:

·新增数据

·批量新增

·查询数据

·数据列表

·更新数据

·删除数据

小技巧总结:

·获取模型类对应表的字段名, new 模型类,再使用 属性进行相关操作

如:   $user = new User; //User为模型类

$user->user_name 与  $user[‘user_name’] 等同!!

因为基类Mode类 implements \ArrayAccess , 可以将属性当成数组的形式来访问。

·数据表存在“_”的问题

如果数据表存在下划线,将下划线去掉,模型的名字首字母大写。

如: tp_admin_user,  对应的模型名 AdminUser .

·如果数据表 与 当前模型名称不一致,怎么办?

在模型类内  protected $name =”要关联的表名”;

如: tp_admin_user,    User模型   protected $name = ‘user’;

·模型类 或 模型对象 get() 或 find() 查询后的结果 怎么转成数组?

通过 getData()方法,

如:  $result = $user->find(1);  $result->getData();

·模型类 或 模型对象 all() 或 select() 查询后的结果 怎么转数组?

此时查询的多条信息为 结果集!! 不能使用getData()一次性转数组,

可以使用foreach() 来逐条转为数组,但太麻烦!!!。

通过 collection(结果集)->toArray();

如: $result = $user->select();  $data = collection($result)->toArray();

TP5 模型CURD的更多相关文章

  1. TP5模型belongsTo和hasOne的区别

    在使用tp5模型的ORM的时候出现belongsTo和hasOne都有表示一对一的关系,但是二者并不相同.以下举例说明两者的区别: 首先有user表 字段 id name password字段 然后有 ...

  2. tp5模型事件回调函数中不能使用$this

    tp5模型事件回调函数中不能使用$this,使用会报错,涉及到数据库操作使用Db类,不能使用$this->save()之类的方式 如果回调函数中需要使用类内函数,需要将函数定义为static,通 ...

  3. TP5模型belongsTo和hasOne这两个方法的区别

    在使用tp5模型的ORM的时候出现belongsTo和hasOne都有表示一对一的关系,但是二者并不相同.以下举例说明两者的区别: 首先有user表 字段 id name password字段 然后有 ...

  4. TP5 模型类和Db类的使用区别

    原文:http://www.upwqy.com/details/3.html 总结 在控制器中  模型操作  get() 和 all()  只能单独使用来查询数据   想要链式操作查询数据 需要使用f ...

  5. TP5模型类关键字赋值

    在写项目过程中 开始的代码如下 $ms = new MStore(); $ms->userid = $userid; $ms->address = $mc->address; $ms ...

  6. TP5模型关联问题

    在使用模型关联时:假如有表   merchant商户表   m_store 店铺表  m_store_ref 商户店铺关联表  user 普通用户表 $mer = Merchant::with([ ' ...

  7. TP5 模型事务操作

    注意:数据只要涉及多表一致性操作,必须要开启数据库事务操作 ThinkPHP5 中模型层中使用事务: try{ $this->startTrans(); $this->data($orde ...

  8. tp5模型笔记---多对多

    关联模型 一对一:HAS_ONE  以及对应的BELONEGS_TO 一对多:HAS_MANY 以及相对的BELONGS_TO 多对多:BELONGS_TO_MANY 步骤: 第一:创建Users模型 ...

  9. tp5 模型关联,多表联查实用方法

    1.模型中建立关联关系 public function goods(){ return $this->belongsTo('app\common\model\goods\Goods', 'goo ...

随机推荐

  1. SpringMVC Bean Validation

    对于任何一个应用而言在客户端做的数据有效性验证都不是安全有效的,这时候就要求我们在开发的时候在服务端也对数据的有效性进行验证. SpringMVC 自身对数据在服务端的校验(Hibernate Val ...

  2. php正则表示中的元字符

    元字符 抛出问题: \d 代表匹配一个字符.而我现在想要匹配十个八个,任意多个数字肿么办? 这个时候我们就要用到元字符.在使用原子的时候,发现只能够匹配一个字符,可是要匹配多个字符就出现了问题.大理石 ...

  3. 洛谷 P3376 【模板】网络最大流 题解

    今天学了网络最大流,EK 和 Dinic 主要就是运用搜索求增广路,Dinic 相当于 EK 的优化,先用bfs求每个点的层数,再用dfs寻找并更新那条路径上的值. EK 算法 #include< ...

  4. S1_搭建分布式OpenStack集群_09 cinder 控制节点配置

    一.创建数据库创建数据库以及用户:# mysql -uroot -p12345678MariaDB [(none)]> CREATE DATABASE cinder;MariaDB [(none ...

  5. echo如何输出带颜色的文本

    本文链接:https://blog.csdn.net/qualcent/article/details/7106483 ######################################## ...

  6. 18-ESP8266 SDK开发基础入门篇--TCP 服务器 RTOS版,串口透传,TCP客户端控制LED

    https://www.cnblogs.com/yangfengwu/p/11112015.html 先规定一下协议 aa 55 02 01 F1 4C 控制LED点亮  F1 4C为CRC高位和低位 ...

  7. mac 下的 tree 命令 终端展示你的目录树结构

    相信很多使用过Linux的用户都用过tree命令,它可以像windows的文件管理器一样清楚明了的显示目录结构.mac 下使用 brew包管理工具安装 tree 前提:安装了homebrew(安装指令 ...

  8. bluestart

    # Add nano as default editorexport EDITOR=nanoexport PULSE_LATENCY_MSEC=60 alias ls='ls --color=auto ...

  9. MongoDB 表(集合) 创建删除、数据增删改查

    MongoDB 表(集合) 创建删除和增删改查数据 创建一个集合(emp) 在创建集合之前先使用use xxx,选择数据库,如果没有会创建(并不是真正的创建,只有在数据库里面保存集合数据之后才能够真正 ...

  10. 刷题记录:[CISCN2019 华北赛区 Day1 Web1]Dropbox

    目录 刷题记录:[CISCN2019 华北赛区 Day1 Web1]Dropbox 一.涉及知识点 1.任意文件下载 2.PHAR反序列化RCE 二.解题方法 刷题记录:[CISCN2019 华北赛区 ...