zoukankan      html  css  js  c++  java
  • 检查数据库数据字段命名规范与合法性的脚本

    --检查不符合数据库命名规范的字段名

    Select TABLE_NAME,COLUMN_NAME,DATA_TYPE

    From user_tab_columns

    Where column_name In --(Select keyword From v$reserved_words)

    ('ACCESS','ADD','ALL','ALTER','AND','ANY','AS','ASC','AUDIT',

    'BETWEEN','BY','CHAR','CHECK','CLUSTER',

    'COLUMN','COMMENT','COMPRESS','CONNECT','CREATE','CURRENT',

    'DATE','DECIMAL','DEFAULT','DELETE',

    'DESC','DISTINCT','DROP','ELSE','EXCLUSIVE','EXISTS','FILE',

    'FLOAT','FOR','FROM','GRANT','GROUP',

    'HAVING','IDENTIFIED','IMMEDIATE','IN','INCREMENT','INDEX',

    'INITIAL','INSERT','INTEGER','INTERSECT',

    'INTO','IS','LEVEL','LIKE','LOCK','LONG','MAXEXTENTS','MINUS',

    'MLSLABEL','MODE','MODIFY','NOAUDIT',

    'NOCOMPRESS','NOT','NOWAIT','NULL','NUMBER','OF','OFFLINE','ON',

    'ONLINE','OPTION','OR','ORDER',

    'PCTFREE','PRIOR','PRIVILEGES','PUBLIC','RAW','RENAME','RESOURCE',

    'REVOKE','ROW','ROWID','ROWNUM',

    'ROWS','SELECT','SESSION','SET','SHARE','SIZE','SMALLINT','START',

    'SUCCESSFUL','SYNONYM','SYSDATE',

    'TABLE','THEN','TO','TRIGGER','UID','UNION','UNIQUE','UPDATE',

    'USER','VALIDATE','valueS','VARCHAR',

    'VARCHAR2','VIEW','WHENEVER','WHERE','WITH')

    Or column_name Like '% %'

     

    --检查数据库中相同名字不同类型的字段名

    select a.column_name,a.data_type,b.data_type From

    (select distinct column_name,data_type from

    all_tab_columns Where TABLE_NAME Like 'T%') a,

    (select distinct column_name,data_type from

    all_tab_columns Where TABLE_NAME Like 'T%') b

    where a.column_name=b.column_name and a.data_type<>b.data_type

     

    --检查数据库中相同名字相同类型不同长度的字段名

    select a.column_name,a.data_type,b.data_type,

    a.data_length,b.data_length From

    (select distinct column_name,data_type,

    data_length from all_tab_columns Where TABLE_NAME Like 'T%') a,

    (select distinct column_name,data_type,

    data_length from all_tab_columns Where TABLE_NAME Like 'T%') b

    where a.column_name=b.column_name and a.data_type=b.data_type And A.DATA_LENGTH<>B.DATA_LENGTH

  • 相关阅读:
    NO 3 ,人生苦短,我学python之python 元祖tuple魔法
    NO 2,人生苦短,我学python之python 列表list的魔法
    NO 1,人生苦短,我学python之python 字符串的魔法
    几种常见登录验证的方式总结
    Spring Boot 解决跨域问题的 3 种方案
    浅析VO、DTO、DO、PO的概念、区别和用处
    对于分库分表的入门理解
    在项目启动后执行某段功能代码
    jna编程学习
    RabbitMQ详解
  • 原文地址:https://www.cnblogs.com/Byrd/p/2051709.html
Copyright © 2011-2022 走看看