存档&改造【05】通过视图实现多表联查&理清级联层级关系&对字段的唯一约束

在之前的列表展示中,只是粗略地将数据展示出来,但是其中的关系并没有真正理解,而后续无论是字段内容展示效果也好,级联筛选也好,都离不开理解其中关系这一步。

PDManer中的数据模型关系图能很好地帮助理清其中的连接和关系,

设备关系图

操作设置关系图

介于关系表太多,将有效字段通过多表连接的视图串联起来就能方便很多了,

sql 复制代码
-- 地图-区域视图
select * from fnd_maps_areas_asso_v;

-- 查区域
SELECT DISTINCT MAP_AREA_X_NAME AS AREA_NAEM,MAP_AREA_X_ID AS AREA_ID
FROM FND_MAPS_AREAS_ASSO_V
WHERE TENANT_ID = 2 AND FAB_ID =2
ORDER BY MAP_AREA_X_ID ASC;

-- 查产线
SELECT DISTINCT MAP_AREA_Y_NAME AS LINE_NAME ,MAP_AREA_Y_ID AS LINE_ID
FROM FND_MAPS_AREAS_ASSO_V
WHERE TENANT_ID = :USERTENANT AND FAB_ID =:FAB_ID
ORDER BY MAP_AREA_Y_ID ASC;

查到的区域ID和对应NAME

应用到程序中

【待解决的情况】厂区都能找到,但是区域和产线找不到

区别在于FAB_ID是在FND_FAB表上查到的,而AREA_NAEM、AREA_ID、LINE_NAME、 LINE_ID是在视图FND_MAPS_AREAS_ASSO_V上查到的。

【问题记录】ERR-1002 在应用程序 "277" 中未找到项 "FAB_ID" 的项 ID

查看会话发现是FAB_ID未传参到查询中

我悟了:因为新增还未保存,所以此时通过FAB_ID为条件筛选查区域和产线当然查不到了,但是从已有数据中查为什么还是没有啊???

【问题解决】破案了,除了查询语句要加上关系,级联值列表也要加上父列

成功了

同理使事件大小类也适用

但是使用原生新增是出现报错

【错误记录】ORA-01400: 无法将 NULL 插入 ("YWJA"."CODE_DEVICE"."TENANT_ID")

【问题原因】租户没有设置默认值
【解决方案】给租户设置默认值

项"TENANT_ID"→【默认值】→【类型】表达式→ 【PL/SQL表达式】:USERTENANT

这样就可以新增了。

【待解决的问题】保持DEVICE_CODE的唯一性,要做校验

明明在提交后设置了校验,但是完全没发挥作用,编码居然可以重复

【问题解决】在对应表DDL(数据定义语言)新增唯一约束

create unique index CODE_DEVICE_DEVICE_CODE_UINDEX on CODE_DEVICE (DEVICE_CODE)

效果展示:

相关推荐
火山上的企鹅12 小时前
Codex实战:APP远程升级服务搭建(三)后台管理页面(APK 上传、版本管理、多应用页签)
服务器·网络·数据库·oracle·qgc
放下华子我只抽RuiKe51 天前
FastAPI 全栈后端(三):数据库与 ORM
前端·数据库·react.js·oracle·性能优化·前端框架·fastapi
oyyanghh1 天前
从Cursor到TRAE的三周vibe coding体验对比
数据库·oracle
Bert.Cai1 天前
Oracle CONCAT函数详解
数据库·oracle
tiancaijiben1 天前
阿里云云备份(Cloud Backup)全量对接与使用指南
数据库·oracle
李白的天不白1 天前
数据库的CEUD
数据库·sql·oracle
山峰哥1 天前
从全表扫描到覆盖索引:我是怎么干掉慢查询的
数据库·sql·oracle·性能优化·编辑器·深度优先
睡不醒男孩0308232 天前
自建 Prometheus+Grafana 与 CLUP 深度监控 PG 集群有什么区别?
数据库·oracle
德迅云安全-小潘2 天前
网站遭遇SQL注入攻击?应急处置、漏洞修复与长效防御完整方案
网络·sql·oracle
swordbob2 天前
MySQL和Oracle关于读未提交的区别
数据库·mysql·oracle