基于模块自定义扩展字段的后端逻辑实现(二)

目录

一:创建表

二:代码逻辑


上一节我们详细讲解了自定义扩展字段的逻辑实现和表的设计,这一节我们以一个具体例子演示下,如何实现一个订单模块的自定义扩展数据。

一:创建表

订单主表:

CREATE TABLE `t_order` (

`order_id` int NOT NULL AUTO_INCREMENT,

`order_no` char(20) NOT NULL AUTO_INCREMENT,

`create_user_id` int NOT NULL DEFAULT '0' COMMENT '创建人',

`create_time` int NOT NULL DEFAULT '0' COMMENT '添加时间',

`update_time` int NOT NULL DEFAULT '0' COMMENT '更新时间',

PRIMARY KEY (`order_id`) USING BTREE

) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='订单主表';

#订单扩展表,扩展的自定义字段主要存储在这张表

CREATE TABLE `t_order_extend` (

`id` int NOT NULL AUTO_INCREMENT,

`order_id` int NOT NULL DEFAULT '0' COMMENT '订单ID',

`create_time` int NOT NULL DEFAULT '0' COMMENT '添加时间',

`update_time` int NOT NULL DEFAULT '0' COMMENT '更新时间'

PRIMARY KEY (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='订单扩展表';

#订单表格数据,订单一对多的数据主要存储在这个表,比如商品

CREATE TABLE `t_order_list_extend` (

`id` int NOT NULL AUTO_INCREMENT,

`order_id` int NOT NULL DEFAULT '0' COMMENT '订单ID',

`create_time` int NOT NULL DEFAULT '0' COMMENT '添加时间',

`update_time` int NOT NULL DEFAULT '0' COMMENT '更新时间',

PRIMARY KEY (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='订单表格数据扩展表';

二:代码逻辑

创建自定义字段部分逻辑

$count = 1;//定义生成字段数量

//生成字段

for (i=0; i<count; i++) {

//生成字段名

list(fieldSign,num) = this-\>getFieldSign(request['types']);

fieldSignList\[\] = fieldSign;

}

//这里定义一个计数表,用于存储字段的数量,字段的命名以item1,item2,...的方式

fieldNum = ExtendFieldNumModel::where('extend_type', types)->value('extend_num', 1);

fieldSign = 'item_'.fieldNum;

fieldWhere = \[\['field_sign','=', fieldSign],['types','=',$types]];

if (ExtendField::where($fieldWhere)->value('field_id')) {

ExtendFieldNumModel::where('extend_type', $types)->inc('extend_num', 1)->update();

this-\>getFieldSign(types);

} else {

//字段计数

if ($fieldNum == 1) {

ExtendFieldNumModel::create(['extend_type' => types,'extend_num' =\> fieldNum + 1,

'create_time' => time(),'update_time' => time()]);

} else {

ExtendFieldNumModel::where('extend_type', types)-\>update(\['extend_num' =\> fieldNum + 1,

'update_time' => time()]);

}

}

return [fieldSign,fieldNum];

//插入字段到字段表

$data = [

'types' => $request['types'],

'field_name' => $request['field_name'],

'field_type' => $request['field_type'],

'default_value' => $request['default_value'] ?? '',

'is_unique' => $request['is_unique'] ?? 2,

'is_require' => $request['is_require'] ?? 2,

'create_time' => time(),

'update_time' => time()

];

data\['field_sign'\] = count(fieldSignList) == 1 ? fieldSignList\[0\] : implode(',', fieldSignList);

fieldId = (new ExtendField())-\>insertGetId(data);

//扩展表字段部分代码

case 'text':

sql\[\] = "ALTER TABLE \`" . table . "` ADD `" . fieldSign\[0\] . "\` VARCHAR(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL DEFAULT '' COMMENT '" . fieldName . "'";

break;

case 'textarea':

sql\[\] = "ALTER TABLE \`" . table . "` ADD `" . fieldSign\[0\] . "\` TEXT COMMENT '" . fieldName . "'";

break;

if ($sql) {

foreach (sql as sValue) {

resData = Db::execute(sValue);

if ($resData === false) {

return false;

}

}

return true;

}

这样我们就实现了,自定义订单模块的数据了,

相关推荐
czlczl200209257 分钟前
利用“延迟关联”优化 MySQL 巨量数据的深分页查询
数据库·mysql
REDcker23 分钟前
浏览器端Web程序性能分析与优化实战 DevTools指标与工程清单
开发语言·前端·javascript·vue·ecmascript·php·js
ACP广源盛1392462567343 分钟前
IX8024与科学大模型的碰撞@ACP#筑牢科研 AI 算力高速枢纽分享
运维·服务器·网络·数据库·人工智能·嵌入式硬件·电脑
Elastic 中国社区官方博客1 小时前
ES|QL METRICS_INFO 和 TS_INFO:为你的时间序列数据建立目录
大数据·数据库·elasticsearch·搜索引擎·信息可视化·全文检索
俺不要写代码1 小时前
数据库:函数
数据库·mysql
2401_882273721 小时前
如何在 CSS 中正确加载本地 JPG 背景图片
jvm·数据库·python
曹牧2 小时前
SQL:多个事务同时修改同一索引块
数据库·sql
aXin_ya2 小时前
微服务第八天 Sentinel 四种分布式事务模式
java·数据库·微服务
Ruci ALYS2 小时前
MySQL大小写敏感、MySQL设置字段大小写敏感
数据库·mysql
Lee川2 小时前
Prisma 实战指南:像搭积木一样设计古诗词数据库
前端·数据库·后端