66 lines
4.3 KiB
Java
66 lines
4.3 KiB
Java
-- MES 设备对应部位:建表 + 菜单 + 按钮 + 租户 admin 授权(可整文件一次执行)
|
||
-- 权限前缀:mes:mes_xsl_equip_part_mapping:*
|
||
-- 数据由设备点检配置保存后自动生成,列表无手工新增
|
||
-- Flyway:V3.9.2_123__mes_xsl_equip_part_mapping.sql
|
||
SET NAMES utf8mb4;
|
||
|
||
CREATE TABLE IF NOT EXISTS `mes_xsl_equip_part_mapping` (
|
||
`id` varchar(32) NOT NULL COMMENT '主键',
|
||
`equipment_ledger_id` varchar(32) NOT NULL COMMENT '设备台账主键 mes_xsl_equipment_ledger.id',
|
||
`equipment_name` varchar(500) NOT NULL COMMENT '设备名称',
|
||
`machine_code` varchar(500) DEFAULT NULL COMMENT '机台代号(设备编号冗余)',
|
||
`equipment_part_id` varchar(32) NOT NULL COMMENT '设备大部位主键 mes_xsl_equipment_part.id',
|
||
`equipment_part_name` varchar(500) DEFAULT NULL COMMENT '设备大部位名称',
|
||
`part_code` varchar(500) DEFAULT NULL COMMENT '大部位代码',
|
||
`equipment_sub_part_id` varchar(32) NOT NULL COMMENT '设备小部位主键 mes_xsl_equipment_sub_part.id',
|
||
`equipment_sub_part_name` varchar(500) DEFAULT NULL COMMENT '设备小部位名称',
|
||
`sub_part_code` varchar(500) DEFAULT NULL COMMENT '小部位代码',
|
||
`tenant_id` int DEFAULT NULL COMMENT '租户',
|
||
`sys_org_code` varchar(64) DEFAULT NULL COMMENT '部门',
|
||
`create_by` varchar(32) DEFAULT NULL COMMENT '创建人',
|
||
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
|
||
`update_by` varchar(32) DEFAULT NULL COMMENT '更新人',
|
||
`update_time` datetime DEFAULT NULL COMMENT '更新时间',
|
||
`del_flag` int DEFAULT '0' COMMENT '删除标记(0正常1删除)',
|
||
PRIMARY KEY (`id`),
|
||
UNIQUE KEY `uk_mepm_ledger_part_sub` (`equipment_ledger_id`, `equipment_part_id`, `equipment_sub_part_id`),
|
||
KEY `idx_mepm_tenant_equip_name` (`tenant_id`, `equipment_name`)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='MES设备对应部位';
|
||
|
||
SET @mes_tenant_id = 1002;
|
||
|
||
SET @mes_equip_pid = (
|
||
SELECT `id` FROM `sys_permission`
|
||
WHERE `del_flag` = 0 AND `menu_type` = 0 AND `name` = '设备管理'
|
||
LIMIT 1
|
||
);
|
||
SET @mes_equip_pid = IFNULL(@mes_equip_pid, '1860000000000000133');
|
||
|
||
INSERT INTO `sys_permission`(`id`, `parent_id`, `name`, `url`, `component`, `component_name`, `menu_type`, `perms`, `perms_type`, `sort_no`, `is_route`, `is_leaf`, `hidden`, `status`, `del_flag`, `keep_alive`, `internal_or_external`, `create_by`, `create_time`)
|
||
VALUES ('1860000000000000215', @mes_equip_pid, '设备对应部位', '/xslmes/mesXslEquipPartMapping', 'xslmes/mesXslEquipPartMapping/MesXslEquipPartMappingList', 'MesXslEquipPartMappingList', 1, NULL, '1', 14, 1, 0, 0, '1', 0, 1, 0, 'admin', NOW())
|
||
ON DUPLICATE KEY UPDATE
|
||
`parent_id` = VALUES(`parent_id`), `name` = VALUES(`name`), `url` = VALUES(`url`), `component` = VALUES(`component`), `component_name` = VALUES(`component_name`),
|
||
`menu_type` = VALUES(`menu_type`), `perms` = VALUES(`perms`), `perms_type` = VALUES(`perms_type`), `sort_no` = VALUES(`sort_no`),
|
||
`is_route` = VALUES(`is_route`), `is_leaf` = VALUES(`is_leaf`), `hidden` = VALUES(`hidden`), `status` = VALUES(`status`), `del_flag` = VALUES(`del_flag`),
|
||
`keep_alive` = VALUES(`keep_alive`), `internal_or_external` = VALUES(`internal_or_external`), `icon` = 'ant-design:apartment-outlined';
|
||
|
||
UPDATE `sys_permission` SET `icon` = 'ant-design:apartment-outlined' WHERE `id` = '1860000000000000215' AND `del_flag` = 0;
|
||
|
||
INSERT INTO `sys_permission`(`id`, `parent_id`, `name`, `menu_type`, `perms`, `perms_type`, `status`, `del_flag`, `create_by`, `create_time`) VALUES
|
||
('1860000000000000216', '1860000000000000215', '导出', 2, 'mes:mes_xsl_equip_part_mapping:exportXls', '1', '1', 0, 'admin', NOW())
|
||
ON DUPLICATE KEY UPDATE
|
||
`parent_id` = VALUES(`parent_id`), `name` = VALUES(`name`), `menu_type` = VALUES(`menu_type`), `perms` = VALUES(`perms`), `perms_type` = VALUES(`perms_type`),
|
||
`status` = VALUES(`status`), `del_flag` = VALUES(`del_flag`);
|
||
|
||
INSERT INTO `sys_role_permission`(`id`, `role_id`, `permission_id`, `operate_date`, `operate_ip`)
|
||
SELECT REPLACE(UUID(), '-', ''), r.`id`, p.`id`, NOW(), '127.0.0.1'
|
||
FROM `sys_role` r
|
||
CROSS JOIN `sys_permission` p
|
||
WHERE r.`tenant_id` = @mes_tenant_id
|
||
AND r.`role_code` = 'admin'
|
||
AND p.`id` IN ('1860000000000000215', '1860000000000000216')
|
||
AND NOT EXISTS (
|
||
SELECT 1 FROM `sys_role_permission` rp
|
||
WHERE rp.`role_id` = r.`id` AND rp.`permission_id` = p.`id`
|
||
);
|