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

    检查数据库数据字段命名规范与合法性的脚本

    做为一名开发DBA,最重要的renweu是经常要检查开发人员或建模人员对数据库的命名规范是否严谨,下文中将主要介绍一个检查数据库数据字段命名规范与合法性的脚本,仅供大家参考。

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

    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

    http://tech.ddvip.com/2008-11/122628077790713.html

  • 相关阅读:
    C++ 线程的创建、挂起、唤醒和结束 &&&& 利用waitForSingleObject 函数陷入死锁的问题解决
    接收数据界面卡顿-----待整理
    vs2012 在调试或运行的过程中不能加断点
    matlab 学习笔记
    周立功USBCAN-II 上位机开发(MFC)
    vs添加静态链接库+添加动态链接库+添加头文件目录
    Go 面试每天一篇(第 2 天)
    http 协议
    Samba配置
    svn checkout 单个文件
  • 原文地址:https://www.cnblogs.com/emanlee/p/1513472.html
Copyright © 2011-2022 走看看