[20180312]不好的数据结构设计3.txt

简介: [20180312]不好的数据结构设计3.txt --//上个星期提到一种不好的数据结构设计.今天在提到一种: --//就是本来一行保存的信息,变成竖着保存,涉及一些安全信息,通过例子来说明: 1.

[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提到.
--//总之这种设计有许多限制,不能乱用.至少我没看到这样设计的先进性.

目录
相关文章
|
存储 算法 NoSQL
第八章 查找【数据结构】3
第八章 查找【数据结构】3
71 0
|
6月前
|
存储 算法 前端开发
第八章 查找【数据结构】【精致版】
第八章 查找【数据结构】【精致版】
74 0
|
6月前
|
算法
第九章 排序【数据结构】【精致版】
第九章 排序【数据结构】【精致版】
65 0
|
11月前
|
存储 安全 Java
【C++】引用之带你“消除”C语言版数据结构教材的一些困惑(虽然是C++的内容,但是强烈建议正在学习数据结构的同学点进来看看)
【C++】引用之带你“消除”C语言版数据结构教材的一些困惑(虽然是C++的内容,但是强烈建议正在学习数据结构的同学点进来看看)
70 0
|
存储 算法 前端开发
第八章 查找【数据结构】1
第八章 查找【数据结构】1
87 0
|
存储 算法 Serverless
第八章 查找【数据结构】2
第八章 查找【数据结构】2
80 0
|
算法 C++
C++基础代码--20余种数据结构和算法的实现
C++基础代码--20余种数据结构和算法的实现
182 0
|
机器学习/深度学习 算法 搜索推荐
【数据结构】时间复杂度(详细解释,例子分析,易错分析,图文并茂)
【数据结构】时间复杂度(详细解释,例子分析,易错分析,图文并茂)
459 0
数据结构7-回顾与补充
数据结构7-回顾与补充
57 0
数据结构7-回顾与补充
|
算法 Java 程序员
如何写出高性能代码(一)善用算法和数据结构
同一份逻辑,不同人的实现的代码性能会出现数量级的差异; 同一份代码,你可能微调几个字符或者某行代码的顺序,就会有数倍的性能提升;同一份代码,也可能在不同处理器上运行也会有几倍的性能差异;十倍程序员不是只存在于传说中,可能在我们的周围也比比皆是。十倍体现在程序员的方法面面,而代码性能却是其中最直观的一面。
133 0
如何写出高性能代码(一)善用算法和数据结构
下一篇
无影云桌面