`
yudio
  • 浏览: 9960 次
  • 性别: Icon_minigender_1
  • 来自: 福州
最近访客 更多访客>>
社区版块
存档分类
最新评论

SQL开发规范

阅读更多
当前保险项目的SQL开发规范.

>>SQL开发的一般流程<<
表结构->索引->历史数据->目标->SQL书写思路->开发->调试
    在进行程序开发前,不要急于马上编码,要先研究表结构,特别要研究表内历史数据和表内数据的填写方式,在动手之前还必须事先研究表的索引,如索引不足应先加索引再开发,这样可减少所开发程序的错误率和运行性能问题,提高其适应性。

>>常用数据库工具及限制使用技术<<
   数据库相关工具:
   为需要写SQL的开发人员提供方便的、图形化的客户端软件,可以用来执行SQL,看到表结构、索引等等,如TOAD, PL/SQL Develop软件。
   限制使用:
   这里说的限制使用是指如果能有其他的技术途径,就不要使用如下的Oracle技术,包括:DBLink, Trigger,用Java编写的存储过程等内容;

>>禁止使用的SQL语句<<
1.严格禁止跨物理数据库关联查询,无论表内记录数多少。
如:查统计系统业务员工号以及其对应的统计机构代码
	select a.empno, b.deptno 
		from remotedb@onhdrb:empno a , statistics@onhdrb:tjywbm b 
		where a.deptno=b.ywbm;

2.严格禁止3个表(含3个表)以上的关联查询,无论表内记录数多少。
select  	processtype, ds_process.ds_process_id, ds_process.createperson,
            ds_process.startdatetime, dsb_apply.dsb_apply_id, ds_activity.executeorg,
    	ds_activity.step
from ds_activity, ds_process, dsb_apply 
where   	ds_process.ds_process_id=dsb_apply.ds_process_id and
    	ds_process.processtype=3 and ds_process.nextactivitytype=2 and
    	ds_process.createperson=3394 and
    	ds_activity.ds_activity_id=ds_process.ds_activity_id order by
    	dsb_apply.dsb_apply_id desc

以上语句严格禁止,只要有一表超过100万记录,一般10分钟内查询出的可能性不大。性能与表间书写次序有很大关系。
3.严格禁止两表均超过5000条以上记录的两个表的关联查询。
   两表均超过5000条以上记录的关联表查询要填定<<关联SQL语句编写审批表>>,经审批同意才能按审批同意的语句使用(关联字段也需建立在索引基础上)。
   性能分析表明,选择一个好的表联接顺序是非常重要的:
   当在WHERE子句中有多个表联接时,WHERE子句中排在最后的表应当是返回行数可能最少的表,有过滤条件的子句应放在WHERE子句中的最后。
4.关于事务提交的处理方法
   提交事务原则上应在后台程序进行,严格禁止C/S结构、B/S结构类系统在前台处理程序中提交离散性、等待性事务。由于长事务容易造成数据库死锁,所以事务开始与事务结束之间,应集中编写,一次性提交,且禁止有select语句存在。(但可以有开发工具本身的不引起数据库操作的函数和语句,也可有PB自身的自动提交功能)。

>>不建议使用的SQL语句<<
1.关于多用户并发抢占唯一流水号的处理 多用户并发抢号机制建议采用“共享-抢占-重试”的方式进行,不建议采用“抢点-锁定-解锁”的方式进行。

2. 关于统计程序“抽取”语句与“推送”语句的处理。
      原则上不建议采用向源表采用正向“抽取“数据的方式,而应采取通过一次扫描源表向多个目的表”推送“填写数据的方式来开发统计、汇总类程序,可有效提高运行效率

3. 大量的排序操作影响系统性能,所以尽量减少order by,group by,distinct等排序操作;如必须使用排序操作,排序应建立在有索引的列上.同时不建议使用关联查询的多字段排序.

4. 不建议使用SELECT *:SELECT语句中应写出要选择的全部列名,增强语句可读性,避免不必要的选择;SELECT * 增加了对所有字段的依赖,当表增加了字段后,有可能发生错误;此外还可能增加了数据的流量,查询了一些实际不需要的字段;

5. SQL语句中除字符串中必须大写的内容外,全部小写,包括关键字,因为大小写结合需要 输入大写字母速度慢。(相同的SQL语句是在SQL缓冲区中读取,SQL分析器不用对SQL语句重新分析产生执行计划,系统响应时间大大减少)。

>>索引的使用<<
   1.隐式转换导致索引失效.这一点应当引起重视.也是开发中经常会犯的错误.
由于表的字段tu_mdn定义为varchar2(20),但在查询时把该字段作为number类型以where条件传给Oracle,这样会导致索引失效.
错误的例子:select * from test where tu_mdn=13333333333;
正确的例子:select * from test where tu_mdn='13333333333';
   2. 对索引列进行运算导致索引失效,我所指的对索引列进行运算包括(+,-,*,/,! 等)
错误的例子:select * from test where id-1=9;
正确的例子:select * from test where id=10;
   3. 使用Oracle内部函数导致索引失效.对于这样情况应当创建基于函数的索引.
      错误的例子:select * from test where round(id)=10; 说明,此时id的索引已经不起作用了
      正确的例子:首先建立函数索引,create index test_id_fbi_idx on test(round(id));然后 select * from test where round(id)=10; 这时函数索引起作用了
   4. 以下使用会使索引失效,应避免使用;
a. 使用 <> 、not in 、not exist、!=
b. like "%_" 百分号在前(可采用在建立索引时用reverse(columnName)这种方法处理)
            c. 单独引用复合索引里非第一位置的索引列.应总是使用索引的第一个列,如果索引是建立在多个列上, 只有在它的第一个列被where子句引用时,优化器才会选择使用该索引。
d. 字符型字段为数字时在where条件里不添加引号.
e. 当变量采用的是times变量,而表的字段采用的是date变量时.或相反情况。
    5. 不要将空的变量值直接与比较运算符(符号)比较。
   如果变量可能为空,应使用 IS NULL 或 IS NOT NULL 进行比较,或者使用 ISNULL 函数。
    6. 不要在 SQL 代码中使用双引号。
  因为字符常量使用单引号。如果没有必要限定对象名称,可以使用(非 ANSI SQL 标准)括号将名称括起来。
    7. 将索引所在表空间和数据所在表空间分别设于不同的磁盘chunk上,有助于提高索引查询的效率。
    8. Oracle默认使用的基于代价的SQL优化器(CBO)非常依赖于统计信息,一旦统计信息不正常,会导致数据库查询时不使用索引或使用错误的索引。
     一般来说,Oracle的自动任务里面会包含更新统计信息的语句,但如果表数据发生了比较大的变化(超过20%),可以考虑立即手动更新统计信息,例如:analyze table abc compute statistics,但注意,更新统计信息比较耗费系统资源,建议在系统空闲时执行。
    9. Oracle在进行一次查询时,一般对一个表只会使用一个索引.
     因此,有时候过多的索引可能导致Oracle使用错误的索引,降低查询效率。例如某表有索引1(Policyno)和索引2(classcode),如果查询条件为 policyno = ‘xx’ and classcode = ‘xx’,则系统有可能会使用索引2,相较于使用索引1,查询效率明显降低。
    10. 优先且尽可能使用分区索引。
分享到:
评论

相关推荐

    MySQL SQL开发规范

    MySQL SQL开发规范知识点解析: 1. 代码规范:在MySQL中,CR的前后分别需要加上use xxx; begin; commit;的命令,其中xxx为数据库的schema名。这主要是为了区分不同数据库的操作,提高代码的清晰度和可维护性。 2. ...

    HIVE-SQL开发规范.docx

    总结,Hive SQL开发规范强调了正确选择数据类型、合理设计表结构、优化查询性能以及遵循安全原则的重要性。理解并遵循这些规范,将帮助开发者写出高效、稳定的Hive查询,实现大数据分析的目标。

    IBM的sql开发规范

    【IBM的SQL开发规范】是IBM为SQL编程制定的一系列最佳实践和标准,旨在提高代码的可读性、性能和安全性。以下是对这些规范的详细解释: 1. **SQL书写规范**: - **全部使用大写字母**:这是因为Oracle在解析SQL时...

    HIVE-SQL开发规范.zip

    《HIVE-SQL开发规范》文档的出现,旨在为Java开发者提供一套标准的Hive SQL编程准则,确保数据处理的高效、稳定与可维护性。Hive是基于Hadoop的数据仓库工具,它允许用户使用SQL语法来查询分布式存储的数据。在大...

    SQL开发规范.pdf

    SQL开发规范.pdf

    SQL开发规范文档.doc

    SQL开发规范文档.doc

    SQL审核与开发规范

    - **SQL开发规范**:定义标准的SQL编写规则,确保查询高效、安全。 - **PL/SQL开发规范**:对于更复杂的逻辑处理,提供指导原则。 - **绑定变量**:强调使用绑定变量以提升性能并避免SQL注入攻击。 ##### 2. ...

    DBA对Oracle SQL编写规范的总结

    在Oracle数据库开发过程中,遵循一套标准化的SQL编写规范对于提升代码质量、增强可读性和可维护性至关重要。本文档由一位经验丰富的数据库管理员(DBA)撰写,旨在总结一系列最佳实践,帮助开发人员在编写SQL语句时...

    Oracle SQL编写规范

    Oracle SQL编写规范 Oracle SQL编写规范是指在编写SQL语句时的一些基本原则和方法,旨在提高SQL语句的执行效率和可读性。以下是Oracle SQL编写规范的详细解释: 1. 尽量用索引,特别在从大量数据中返回小部分数据...

    hive常用的开发规范

    【Hive 开发规范】 Hive 是一个基于 Hadoop 的数据仓库工具,它允许通过类 SQL 的查询语言(HQL)来访问存储在 HDFS 上的大数据集。以下是一些常用的 Hive 开发规范: 1. **数据开发规范** - **Hive 数据目录...

    Oracle 开发DBA SQL编写规范

    ### Oracle开发DBA SQL编写规范 #### 1. 引言 本文档旨在为Oracle数据库开发者提供一套标准化的SQL及PL/SQL编写指南,通过规范化SQL及PL/SQL的编写方式,提高代码的可读性、可维护性和执行效率。本规范适用于所有...

    Flink_SQL开发指南_cn_zh-CN.pdf

    根据提供的文件信息,这份文档是关于阿里云实时计算平台的Flink SQL开发指南。Flink是一个开源的流处理框架,用于对无界和有界数据流进行状态计算。文档内容涵盖了法律声明、通用约定、数据存储、作业开发、作业调试...

    MS SQLSERVER数据库开发规范.docx

    MS SQL Server 数据库开发规范 MS SQL Server 数据库开发规范是为了规范数据库的设计、开发和维护,确保数据库的可靠性、安全性和可维护性。该规范涵盖了数据库、表、视图、字段等数据库对象的命名规范,以及 T-SQL...

    SQL规范化查询语句练习题

    SQL规范化查询语句是数据库设计和管理中的核心技能,它涉及到如何有效地组织数据,避免数据冗余和不一致性。在数据库领域,规范化的查询语句是优化数据存储和提高查询效率的关键。本练习题旨在帮助你深入理解并熟练...

    sql代码开发规范文档

    sql代码开发规范文档

    开发规范详细文档

    遵循SQL开发规范,可以提高代码的安全性和效率: 1. 使用参数化查询或存储过程,防止SQL注入攻击。 2. 保持查询的简洁和高效,避免复杂的子查询和不必要的数据操作。 3. 避免在SQL语句中硬编码值,使用变量代替,...

    数据库设计开发规范-阿里.pdf

    以上内容总结了《数据库设计开发规范-阿里.pdf》的主要知识点,包括了数据库的整体设计规范、数据库对象设计规范以及SQL开发规范等方面的内容。这些规范对于提升数据库的性能、安全性和可维护性都非常重要,值得深入...

Global site tag (gtag.js) - Google Analytics