[20180312]不好的数据结构设计3.txt
--//上个星期提到一种不好的数据结构设计.今天在提到一种:
--//就是本来一行保存的信息,变成竖着保存,涉及一些安全信息,通过例子来说明:
1.环境:
SCOTT@book> @ &r/ver1
PORT_STRING VERSION BANNER
------------------------------ -------------- --------------------------------------------------------------------------------
x86_64/Linux 2.4.xx 11.2.0.4.0 Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
2.例子:
SCOTT@book> @ &r/desc emp
Name Null? Type
---------- -------- ----------------------------
1 EMPNO NOT NULL NUMBER(4)
2 ENAME VARCHAR2(10)
3 JOB VARCHAR2(9)
4 MGR NUMBER(4)
5 HIREDATE DATE
6 SAL NUMBER(7,2)
7 COMM NUMBER(7,2)
8 DEPTNO NUMBER(2)
--//使用UNPIVOT
SELECT empno, column_name, VALUE
FROM emp t UNPIVOT (VALUE FOR COLUMN_NAME IN (ename, job, TO_CHAR(mgr) ))
where empno=7369;
*
ERROR at line 2:
ORA-00917: missing comma
--//报错,因为类型不一致.
WITH a
AS (SELECT EMPNO
,ENAME
,JOB
,TO_CHAR (MGR) mgr
,TO_CHAR (HIREDATE, 'yyyy-mm-dd hh24:mi:ss') hiredate
,TO_CHAR (SAL) sal
,TO_CHAR (COMM) comm
,TO_CHAR (DEPTNO) deptno
FROM emp
WHERE empno = 7369)
SELECT empno, column_name, VALUE
FROM a t UNPIVOT (VALUE
FOR COLUMN_NAME
IN (ename, job, Mgr, hiredate, sal, comm, deptno));
EMPNO COLUMN_NAME VALUE
----- ----------- -------------------
7369 ENAME SMITH
7369 JOB CLERK
7369 MGR 7902
7369 HIREDATE 1980-12-17 00:00:00
7369 SAL 800
7369 DEPTNO 20
6 rows selected.
--//信息按照以上显示格式来保存,真不知道开发如何思考,这样设计将原来多表的数据变成1个表.
--//还导致另外一个问题,就是value只能选择字符类型来统一保存.
--//得到的所谓好处就是字段可以无限增加...
--//这样还导致的结果如何统计分析,哎,围绕这样表结构如何查询比如deptno=10,sal>=1000的那些记录.
--//我曾经在itpub问过这样表结构设计,才想起来在tom的<Oracle高效设计>书中提到这样的设计.
--//讨论链接:http://www.itpub.net/thread-1849887-1-1.html
--//这种设计叫EAV(Entity–attribute–value model).在链接
--//https://en.wikipedia.org/wiki/Entity%E2%80%93attribute%E2%80%93value_model提到.
--//总之这种设计有许多限制,不能乱用.至少我没看到这样设计的先进性.