当前位置:首页 > 编程技术 > 正文内容

TP6.0 一对一模型关联 hasOne

yc8881年前 (2023-01-26)编程技术282

本文测试关联方法都采用预载入查询

  1. $data = User::with('profile')->select();
  2. halt($data->toArray());

1. 创建数据表


  1. -- 用户表
  2. DROP TABLE IF EXISTS `user`;
  3. CREATE TABLE `user` (
  4. `id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '用户id',
  5. `username` varchar(255) NOT NULL COMMENT '用户名',
  6. `password` char(32) DEFAULT NULL COMMENT '登陆密码',
  7. PRIMARY KEY (`id`) USING BTREE
  8. ) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8 COMMENT='用户表';
  9. INSERT INTO `user` VALUES (1, 'liang', 'e10adc3949ba59abbe56e057f20f883e');
  10. INSERT INTO `user` VALUES (2, 'zhangsan', 'e10adc3949ba59abbe56e057f20f883e');
  11. INSERT INTO `user` VALUES (3, 'laowang', 'e10adc3949ba59abbe56e057f20f883e');
  12. INSERT INTO `user` VALUES (4, 'wangwu', 'e10adc3949ba59abbe56e057f20f883e');
  13. INSERT INTO `user` VALUES (5, 'xiaosun', 'e10adc3949ba59abbe56e057f20f883e');
  14. -- 用户资料表
  15. DROP TABLE IF EXISTS `profile`;
  16. CREATE TABLE `profile` (
  17. `user_id` int(11) DEFAULT NULL COMMENT '用户id',
  18. `age` tinyint(4) DEFAULT NULL COMMENT '年龄',
  19. `mobile` bigint(20) DEFAULT NULL COMMENT '手机号',
  20. `gender` char(1) DEFAULT NULL COMMENT '性别'
  21. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用户资料表';
  22. INSERT INTO `profile` VALUES (1, 20, 12305, '男');
  23. INSERT INTO `profile` VALUES (2, 30, 10086, '女');
  24. INSERT INTO `profile` VALUES (5, 40, 10010, '男');

2. 用户模型定义一对一关联方法


  1. public function profile()
  2. {
  3. // hasOne('关联模型类名', '外键', '主键');
  4. // 用户资料表的外键字段 user_id, 默认为当前模型名 + _id
  5. // 用户表的主键字段 id, 默认为当前模型主键 $pk 属性的值
  6. return $this->hasOne(Profile::class, 'user_id', 'id');
  7. }

3. 一对一关联支持额外的方法


一、bind():绑定关联表的属性到父模型属性

  1. public function profile()
  2. {
  3. return $this->hasOne(Profile::class, 'user_id', 'id')
  4. // bind(['字段', '别名' => '字段'])
  5. ->bind(['age', 'new_mobile' => 'mobile']);
  6. }

二、其他方法

  1. public function profile()
  2. {
  3. return $this->hasOne(Profile::class, 'user_id', 'id')
  4. // 追加获取器
  5. ->append(['checked'])
  6. // 隐藏关联表的属性
  7. ->hidden(['age']);
  8. }

本站发布的内容若侵犯到您的权益,请邮件联系站长删除,我们将及时处理!


从您进入本站开始,已表示您已同意接受本站【免责声明】中的一切条款!


本站大部分下载资源收集于网络,不保证其完整性以及安全性,请下载后自行研究。


本站资源仅供学习和交流使用,版权归原作者所有,请勿商业运营、违法使用和传播!请在下载后24小时之内自觉删除。


若作商业用途,请购买正版,由于未及时购买和付费发生的侵权行为,使用者自行承担,概与本站无关。


本文链接:https://www.10zhan.com/biancheng/10437.html

分享给朋友:

“TP6.0 一对一模型关联 hasOne” 的相关文章

【说站】laravel实现自定义404页面并给页面传值

【说站】laravel实现自定义404页面并给页面传值

以 laravel5.8 为例,虽然有自带的404页面,但太简单,我们更希望能自定义404页面,将用户留在站点。实现的方式很简单,将自定义的视图文件命名为 404.blade.php,并放到 reso...

【说站】Thymeleaf报错Error resolving template “XXX”

【说站】Thymeleaf报错Error resolving template “XXX”

修改了一下开源项目的目录结构访问突然报错Error resolving template “XXX”可能原因有如下三种:第一种可能:原因:在使用springboot的过程中,如果使用thymeleaf...

【说站】用一句话就可以去除宝塔面板操作上的二次验证

【说站】用一句话就可以去除宝塔面板操作上的二次验证

用过宝塔的朋友应该都会发现,现在宝塔面板有些鸡肋的功能,删除文件、删除数据库、删除站点等操作都需要做计算题!不仅加了几秒的延时等待,还无法跳过!这时候就会有朋友在想,如何去除宝塔面板的二次验证,此篇文...

【说站】Centos8.0如何配置静态IP详解及永久关闭防火墙

【说站】Centos8.0如何配置静态IP详解及永久关闭防火墙

这篇文章主要介绍了详解Centos8 配置静态IP的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来学习一下!1. 查看自己的网关地址点击虚...

【说站】电脑安装MySQL时出现starting the server失败原因及解决方案

【说站】电脑安装MySQL时出现starting the server失败原因及解决方案

今天在安装MySQL时出现starting the server失败,经过查询分析得出以下结论,记录一下操作步骤。原因分析:如果电脑是第一次安装MySQL,一般不会出现这样的报错。如下图所示。star...

【说站】Java从resources读取文件内容的方法有哪些

【说站】Java从resources读取文件内容的方法有哪些

本文主要介绍的是java读取resource目录下文件的方法,比如这是你的src目录的结构├── main│ ├── java│ │ └── ...