thinkphp 5.1 对数据库查出来的字段进行预处理

2023-12-02 15:44

本文主要是介绍thinkphp 5.1 对数据库查出来的字段进行预处理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

比如数据库的设计是下面这样子:

我想展示的是这个样子:

前端可以处理。

Think PHP的处理方式:

定义属性   :

$this->customize = '任意值';//这里的之没有作用
<?phpnamespace app\hs\controller\shop;use app\daogou\model\Goods;
use app\hs\controller\Common;
use app\hs\traits\Curd;
use think\App;class Lists extends Common
{use Curd;public function __construct(App $app = null){parent::__construct($app);$this->model = new Goods();$this->alias = 'good';$this->join = ['user', 'user.id = good.user_id'];$this->field = 'good.*,username';$this->customize = 'status_txt';//        $good = $this->model->find();
//        dump($good);
//        $good->status_txt = '1112312';
//        dump($good);
//        dump($good->getData("price"));
//        die;}
}

在model 中定义 getXxxxAttr(){}  查询数据库会调用这个函数。对查出来的数据进行预处理

   public function getStatusTxtAttr($v,$data){//状态(-1:下架,1:上架,2:交易中)$status = [-1=>"下架",1=>"上架",2=>"交易中"];if(array_key_exists('status',$data)){return array_key_exists($data['status'],$status) ? $status[$data['status']] : $data['status'];}return '';}

<?phpnamespace app\daogou\model;use app\common\model\TimeModel;class Goods extends TimeModel
{protected $table = 'dg_goods';protected $type = ['type_params'=>'json',];//type_params://      type = 1 : [['coin_id'=>1,'award'=>"0.80000000"],……]//      type = 2 : ['max_number'=>10,'winner'=>1]//      type = 3 : nullpublic function user(){return $this->hasOne('user','user_id','id')->bind(['username']);}public function getStatusTxtAttr($v,$data){//状态(-1:下架,1:上架,2:交易中)$status = [-1=>"下架",1=>"上架",2=>"交易中"];if(array_key_exists('status',$data)){return array_key_exists($data['status'],$status) ? $status[$data['status']] : $data['status'];}return '';}public function getPriceAttr($v){return delZero($v);}
}

这篇关于thinkphp 5.1 对数据库查出来的字段进行预处理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/445896

相关文章

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

C#使用SQLite进行大数据量高效处理的代码示例

《C#使用SQLite进行大数据量高效处理的代码示例》在软件开发中,高效处理大数据量是一个常见且具有挑战性的任务,SQLite因其零配置、嵌入式、跨平台的特性,成为许多开发者的首选数据库,本文将深入探... 目录前言准备工作数据实体核心技术批量插入:从乌龟到猎豹的蜕变分页查询:加载百万数据异步处理:拒绝界面

Python使用自带的base64库进行base64编码和解码

《Python使用自带的base64库进行base64编码和解码》在Python中,处理数据的编码和解码是数据传输和存储中非常普遍的需求,其中,Base64是一种常用的编码方案,本文我将详细介绍如何使... 目录引言使用python的base64库进行编码和解码编码函数解码函数Base64编码的应用场景注意

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

Java进行文件格式校验的方案详解

《Java进行文件格式校验的方案详解》这篇文章主要为大家详细介绍了Java中进行文件格式校验的相关方案,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、背景异常现象原因排查用户的无心之过二、解决方案Magandroidic Number判断主流检测库对比Tika的使用区分zip

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

mysql数据库重置表主键id的实现

《mysql数据库重置表主键id的实现》在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,本文主要介绍了mysql数据库重置表主键id的实现,具有一定的参考价值,感兴趣的可以了... 目录关键语法演示案例在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,当我们

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

Spring Boot 整合 MyBatis 连接数据库及常见问题

《SpringBoot整合MyBatis连接数据库及常见问题》MyBatis是一个优秀的持久层框架,支持定制化SQL、存储过程以及高级映射,下面详细介绍如何在SpringBoot项目中整合My... 目录一、基本配置1. 添加依赖2. 配置数据库连接二、项目结构三、核心组件实现(示例)1. 实体类2. Ma