tp5 商城模型id详情接口

1:创建模型

 

 2:定义关联模型

复制代码
<?php

namespace app\common\model;

use think\Model;
use traits\model\SoftDelete;
class TypeModel extends Model
{
    use SoftDelete;
    //链接pyg商品类型表
    protected $table = 'pyg_type';//    进行和规格模型关联,1对多
    public function spec()
    {
        return $this->hasMany('Spec', 'type_id', 'id');
    }
//    进行和属性模型进行关联
    public function attribute()
    {
        return $this->hasMany('Attribute', 'type_id', 'id');

    }
复制代码

3:定义规格名称和规格值   规格名和规格值一对多

复制代码
<?php

namespace app\common\model;

use think\Model;
use traits\model\SoftDelete;
class Spec extends Model
{
    //
    use SoftDelete;
    protected $table = 'pyg_spec';
    //关联规格和规格值  一个规格对应多个规格值
    public function specValue()
    {
        return $this->hasMany('SpecValue', 'spec_id', 'id');
    }
复制代码

4:控制器代码:

复制代码
    public function read($id)
    {
        //商品模型详情
//        验证参数
        if (!intval($id)) {
            return json(['code' => 500, 'message' => 'id参数不正确']);
        }
//       数据库处理
        $res = TypeModel::with('spec,attribute,spec.specValue')->find(16);
//        print_r(collection($res)->toArray());
        return json(['code' => 200, 'message' => '商品详情展示', 'data' => $res]);
    }
复制代码

5:路由:

//商品模型列表展示
Route::get('index','task/type/index');

6:效果图

 

posted @   王越666  阅读(90)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示