实际操作中看如下案例
文章分类表:
CREATE TABLE `case_category` (`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键id',`name` varchar(50) DEFAULT NULL COMMENT '分类名称',`num` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '分类排序',`status` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '分类状态(0=隐藏,1=显示)',`create_time` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '创建时间',`update_time` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',PRIMARY KEY (`id`) ) ENGINE=MyISAM AUTO_INCREMENT=7 DEFAULT CHARSET=utf8 COMMENT='展厅展馆案例分类表';
文章案例表:
CREATE TABLE `cases` (`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键id',`cover` varchar(255) DEFAULT NULL COMMENT '封面图片',`title` varchar(255) DEFAULT NULL COMMENT '标题',`title_en` varchar(255) DEFAULT NULL COMMENT '标题英文翻译',`author` varchar(50) DEFAULT NULL COMMENT '作者',`address` varchar(255) DEFAULT NULL COMMENT '地址',`address_en` varchar(255) DEFAULT NULL COMMENT '地址英文翻译',`area` varchar(50) DEFAULT NULL COMMENT '面积',`area_en` varchar(50) DEFAULT NULL COMMENT '面积英文翻译',`content` text COMMENT '内容',`case_category_id` bigint(20) DEFAULT NULL COMMENT '案例分类关联id',`status` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '状态(0=隐藏,1=显示)',`create_time` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '创建时间',`update_time` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',PRIMARY KEY (`id`) ) ENGINE=MyISAM AUTO_INCREMENT=25 DEFAULT CHARSET=utf8 COMMENT='展厅展馆案例表';
需求:查询文章列表以及分类详细信息
创建两个模型层:CasesModel、CaseCategoryModel,然后在文章模型层写进行查询操作:
主要查询的是案例,所以在案例的模型层写查询代码,又因为案例表只有关联id,所以hasone的关联要放在案例表模型中:
with(['cases_category'])->select();}/*** 展厅展馆案例分类表关联*/public function casesCategory(){return $this->hasOne(CaseCategoryModel::class,'id','case_category_id');} }
这样查询的结果是:
如果要查询指定字段,那么可以可以改成如下:
/*** 展厅展馆案例分类表关联*/public function casesCategory(){return $this->hasOne(CaseCategoryModel::class,'id','case_category_id')->bind(['name','cid'=>'id']);}
这样的话,查询结果是如下的结构:
上一篇:【15.罗马数字转整数】
下一篇:uniapp怎么引入vant