返回顶部
首页 > 资讯 > 数据库 >SQL语句规范有哪些
  • 920
分享到

SQL语句规范有哪些

2024-04-02 19:04:59 920人浏览 八月长安
摘要

这篇文章将为大家详细讲解有关sql语句规范有哪些,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。书写风格1. 语句关键字应全部使用小写。2. 引用字符时应使用

这篇文章将为大家详细讲解有关sql语句规范有哪些,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

书写风格

1. 语句关键字应全部使用小写。

2. 引用字符时应使用单引号。如:update testable set idcol=’abcd’。

3. 连接符或运算符or、in、and、=、<=、>=, +,- 等前后宜加上一个空格。否则容易导致以下类似问题。例如在语句select a–b from table中,a,b均为变量,拼写该语句时,如果a = 6,b = -3,则语句变为select 6--3 from table。--被视为SQL的注释,结果语句报错。

4. 不得使用“select * from …”语法,必须标明字段名。即select col1, col2,… from tablea where …

5. 严禁使用“insert into table_name values (?,?,……)”语法,统一使用“insert into table_name (col1,col2,……) values (?,?,…...)”。

6. SQL语句包含多表连接时,必须加上表的别名,对每个字段的使用都要带上表别名。

select a.col1, a.col2, b.col3 from tablea a, tableb b where a.col4=b.col5

7. 应避免显式或隐含的类型转换。例如在where子句中numeric型和int型的列的比较。

8. 在子查询中前后必须加上括号。

select col1, col2 from tablea where col3 in ( select col4 from tableb where col4>0)

9. 执行SQL时一次应只执行一条,如果多条语句则应分开执行,但必须保持在一个事务中。不得一次执行通过分号等分开的多条语句,这样处理不清晰。

10. 如果能采用or代替,则不宜使用in 语句。in语句中的元素不得超过500个,如果超过,则应拆分为多条SQL语句。严禁使用xx in(‘’,’’….) or xx in(‘’,’’,’’)。

11. or连接条件不得超过 500,超过时应拆分为多条语句。

性能优化

1. 查询时应尽量减少多余数据的读取,通过使用where子句来减少返回的记录数。

2. 如果在语句中有not in(in)操作,应尽量用not exists(exists)来代替。特别对大数据量的两者检索速度有很明显的区别。

3. 不宜使用外连接。外连接效率低。

4. 一条SQL语句中不宜使用3层以上的嵌套查询。如果超过,则应在Java等应用服务器程序中处理。

5. 一条SQL语句中不得从4个及以上表中同时取数。仅作关联或过滤条件而不涉及取数的表不参与表个数计算;如果必须关联4个或4个以上表,应在Java等应用服务器程序中处理。

6. 应尽量避免使用order by和group by排序操作,如必须使用排序操作,尽量建立在有索引的列上。因为大量的排序操作影响系统性能。

7. 对索引列的比较,应尽量避免使用not 或 !=,可拆分为几个条件。因为“not”和“!=”不会使用索引。如col1 是索引列,条件col1 !=0 可以拆分为col1 >0 or col2 <0。

8. 应尽量将数据库函数、计算表达式写在逻辑操作符右边。因为这些对列的操作会将导致表扫描,影响性能。

9. 在where子句中,如果有多个过滤条件,应将索引列或过滤记录数最多的条件放在前面。

10. 能用连接方式实现的功能,不得用子查询。例如:select name from customer where customerId in ( select customerId from order where money > 1000)。 应该用如下语句代替:select name from customer inner join order on customer.customerId = order.customerId where order.money > 100。或 select name from customer where exists ( select 1 from order where money > 1000 and customer.customerId = order.customerId) <这里需要注意:使用exists的效率依赖于匹配度,inner join效率比较稳定>

11. 多表关联查询时,写法可遵循以下原则,这样做有利于建立索引,提高查询效率。格式如下:select sum (t1.je) from table1 t1, table2 t2, table3 t3 where (t1的等值条件(=)) and (t1的非等值条件) and (t2与t1的关联条件) and (t2的等值条件) and (t2的非等值条件) and (t3与t2的关联条件) and (t3的等值条件) and (t3的非等值条件)。

跨数据库支持

1. 对于跨数据库Java应用程序的VO映射数据库的数据格式建议:
1) 整型字段:字段设置保存为Integer或者Long
2) 数字型字段:若需要使用小数2位以上的精确计算,读取、插入、更新使用BigDecimal类型
3) 字符型字段:读取为String,并保存为String,插入或者更新为String 4) 时间字段:读取为String,插入或者更新时的时间格式使用中间件统一处理。

2. 字符串连接应使用“||”符号,而不应使用“+”。“+”是SQLServer语法,oracle和DB2支持“||”,Hibernate转化为SQLServer时,会自动将“||”转为“+”。

3. 通配符不能使用‘[a-c]%’这种形式。应写成如:

select col1, col2 from table_name where col1 like ‘[a]%’ OR col1 like ‘[b]%’ OR col1 like ‘[c]%’

4. 截取字符串长度函数应使用substr,起始位置为1表示从头开始。因为db2中substr起点为1,0会报错;在SqlServer数据库中使用的是substring需要进行转换。

5. 不得通过select percent n和select top n限制查询结果集的记录数。

6. join 与on 必须严格匹配,严禁出现没有on的join。

7. join…on 后面不宜使用or,如果使用则需将or的范围用( )括起来。

8. 不得使用select into 的格式。Select into是SQL Server特有语法,因为Oracle和DB2不支持。

9. 应将Null值与空字符串(长度为零的字符串)视为不同。虽然Oracle视Null与空字符串为相同,但DB2和SQL Server却视为不同。

关于SQL语句规范有哪些就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

您可能感兴趣的文档:

--结束END--

本文标题: SQL语句规范有哪些

本文链接: https://lsjlt.com/news/56101.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • SQL语句规范有哪些
    这篇文章将为大家详细讲解有关SQL语句规范有哪些,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。书写风格1. 语句关键字应全部使用小写。2. 引用字符时应使用...
    99+
    2024-04-02
  • sql规范有哪些
    这篇文章主要为大家展示了“sql规范有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“sql规范有哪些”这篇文章吧。看到itpub的微信发的,搬运一下,应该不...
    99+
    2024-04-02
  • SQL语句规范的写法
    SQL语句规范的写法【199cloud-艾娜】 1. 语句关键字应全部使用小写。 2. 引用字符时应使用单引号。如:update testable set idcol=’abcd’。 3. ...
    99+
    2024-04-02
  • SQL书写规范有哪些
    本篇文章给大家分享的是有关SQL书写规范有哪些,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一.如何使用高效的索引1.索引的作用?举个例子来说...
    99+
    2024-04-02
  • C#语言规范有哪些
    这篇文章主要讲解了“C#语言规范有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C#语言规范有哪些”吧!C#语言规范——注释规范a)文件头部注释【规则1-1】文件都包含文件头,要说明文件...
    99+
    2023-06-17
  • 有哪些SQL语句
    这篇文章主要讲解了“有哪些SQL语句”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“有哪些SQL语句”吧!select 子句主要决定了从表中取出的列...
    99+
    2024-04-02
  • sql语句都有哪些
    这篇文章将为大家详细讲解有关sql语句都有哪些,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Windows中运行cmd的Sqlplus中设置每行显示的数据长...
    99+
    2024-04-02
  • C#语言命名规范有哪些
    C#语言命名规范有哪些,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。a)类【规则1-1】使用Pascal规则命名类名,即首字母要大写。【规则1-2】使用能够反映类功能的名词或名...
    99+
    2023-06-17
  • CSS有哪些规范
    这篇文章主要介绍“CSS有哪些规范”,在日常操作中,相信很多人在CSS有哪些规范问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”CSS有哪些规范”的疑惑有所帮助!接下来,请跟着...
    99+
    2024-04-02
  • HTML规范有哪些
    本篇内容主要讲解“HTML规范有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“HTML规范有哪些”吧!HTML 规范缩进统一两个空格缩进命名规范class ...
    99+
    2024-04-02
  • Redis规范有哪些
    这篇“Redis规范有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Redis规范有哪些”文章吧。redis 功能强大,...
    99+
    2023-06-27
  • codereview规范有哪些
    Code Review的规范可以有很多,这里列举一些常见的规范: 代码风格一致性:确保代码使用统一的缩进风格、命名规范、空格使用、...
    99+
    2023-10-21
    codereview
  • SQL开发规范中的有哪些误区
    这篇文章主要介绍“SQL开发规范中的有哪些误区”,在日常操作中,相信很多人在SQL开发规范中的有哪些误区问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”SQL开发规范中的有哪些...
    99+
    2024-04-02
  • HTML5 语义化结构规范有哪些
    这篇文章将为大家详细讲解有关HTML5 语义化结构规范有哪些,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。 HTML结构更加清晰...
    99+
    2024-04-02
  • Bootstrap CSS语法编码规范有哪些
    这篇文章主要讲解了“Bootstrap CSS语法编码规范有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Bootstrap CSS语法编码规范有哪些”...
    99+
    2024-04-02
  • 常用SQL语句有哪些
    这篇文章将为大家详细讲解有关常用SQL语句有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。说明:以下五十个语句都按照测试数据进行过测试,最好每次只单独运行一个语句。问...
    99+
    2024-04-02
  • sql注入语句有哪些
    sql注入语句有:返回的是连接的数据库名:and db_name()>0获取连接用户名:and user>0将数据库备份到Web目录下面:;backup database 数据库名 to disk='c:\inetpub\wwwroot\1...
    99+
    2024-04-02
  • MySQL中sql语句有哪些
    小编给大家分享一下MySQL中sql语句有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!以下两个表格做讲解SELECTSELECT &quo...
    99+
    2023-06-29
  • python赋值语句规则有哪些
    Python赋值语句的规则如下:1. 单个赋值语句:- 变量名 = 值- 例:x = 52. 多个赋值语句:- 多个变量名 = 多个...
    99+
    2023-09-13
    python
  • HTTP中有哪些规范
    这篇文章给大家介绍HTTP中有哪些规范,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1.RefererHTTP 标准把 Referrer 写成 Referer(少些了一个 r),可以说...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作