图灵程序设计丛书

SQL编程风格

Joe Celko (作者) 米全喜 (译者)
终止销售
本书针对数据库的设计与编程提出了一系列规则和建议,内容涵盖命名规范、代码版式、键的设计、数据编码方案、编码风格、视图和存储过程的使用以及SQL 中的思考方式和一些试探法等多方面。这些规则都给出了原理说明和例外情况,并列举了大量示例。通过阅读本书,读者可以加深对SQL 思维方式的理解,改善SQL 编程风格,并编写出可读性强、可移植且易于维护的SQL 代码。此外,书中的规则对于公司内部制定编程规范也具有很好的借鉴作用。
本书适合数据库管理人员和开发人员阅读,也可作为高等院校计算机专业师生的参考教材。

输入优惠码:新春特急

电子书每单满200减80,可以用到除夕夜哦,祝大家happy hacking 一整年!

纸书停发:2月3日~26日

纸质书
¥39.00

其他购买方式?

出版信息

  • 书  名SQL编程风格
  • 系列书名图灵程序设计丛书
  • 执行编辑关于本书的内容有任何问题,请联系 傅志红
  • 出版日期2008-08-28
  • 书  号978-7-115-18582-2
  • 定  价39.00 元
  • 页  数208
  • 开  本16开
  • 出版状态终止销售
  • 原书名Joe Celko's SQL Programming Style
  • 原书号978-0-12-088797-2

同系列书

  • HTTP权威指南

    David Gourley   Brian Totty   Marjorie Sayer   Sailu Reddy   Anshu Aggarwal   陈涓   赵振平   译

    本书是HTTP及其相关核心Web技术方面的权威著作,主要介绍了Web应用程序是如何工作的,核心的因特网协议如何...

  • JavaScript高级程序设计(第3版)

    Nicholas C.Zakas   李松峰   曹力   译

    本书是JavaScript超级畅销书的新版。ECMAScript 5 和HTML5在标准之争中双双胜出,使大量...

  • 计算机科学的基础

    Al Aho   Jeff Ullman   傅尔也   译

    本书全面而详细地阐述了计算机科学的理论基础,从抽象概念的机械化到各种数据模型的建立,用算法、数据抽象等核心思想...

  • Java技术手册(第6版)

    Benjamin J Evans   David Flanagan   安道   译

    通过学习本书,你将能够: 掌握最新的语言细节,包括Java 8的变化 使用基本的Java句法学习面向对...

  • 机器学习实战

    Peter Harrington   李锐   李鹏   曲亚东   王斌   译

    机器学习是人工智能研究领域中一个极其重要的研究方向,在现今的大数据时代背景下,捕获数据并从中萃取有价值的信息或...

本书特色

世界级大师的SQL编程规范
讲述如何编写标准、高效、易于维护的SQL代码
教你像优秀的SQL程序员那样思考

目录

第1章 名称与数据元素    1
1.1 名称    2
1.1.1 注意名称长度    2
1.1.2 在名称中避免使用所有特殊字符    3
1.1.3 避免使用引号分隔标识符    4
1.1.4 实施大写规则以避免大小写区分问题    5
1.2 遵循ISO-11179标准命名规范    6
1.2.1 SQL的ISO-11179    7
1.2.2 抽象级别    8
1.2.3 避免使用描述性前缀    9
1.2.4 制定标准化的后缀    11
1.2.5 表和视图名称应当是遵循业界标准的、集合、类或复数名称    13
1.2.6 相关名基本上也要遵循与其他名称相同的命名规则    14
1.2.7 关系表名应当是常用描述术语    15
1.2.8 元数据模式访问对象的名称可以包含结构信息    16
1.3 命名数据元素时遇到的问题    16
1.3.1 避免模糊名称    16
1.3.2 避免名称在不同的地方改变    17
1.3.3 不要使用专有暴露的物理定位符    19
第2章 字体、标点和间距    21
2.1 版式与代码    21
2.1.1 名称中只使用大小写字母、数字和下划线    23
2.1.2 列名、参数和变量等标量小写    23
2.1.3 模式对象名首字母大写    23
2.1.4 保留字大写    24
2.1.5 避免使用驼峰命名法    26
2.2 单词间距    27
2.3 遵循规范标点规则    27
2.4 使用完全保留字    29
2.5 如果在使用的SQL产品中有标准保留字,就不要使用专有保留字    30
2.6 如果有标准语句,就不要使用专有语句    31
2.7 疏排版面的隔空白道和垂直间距    33
2.8 缩进    34
2.9 使用行间距将语句分组    35
第3章 数据定义语言    37
3.1 将默认值放到合适的地方    37
3.2 默认值的类型应当与列的类型相同    38
3.3 不要使用专有数据类型    38
3.4 将PRIMARY KEY声明放在CREATE TABLE语句的开头    40
3.5 将列按照逻辑顺序排列并按照逻辑组聚合    40
3.6 将参考约束和操作在数据类型下面缩进    41
3.7 在产品代码中为约束命名    41
3.8 将CHECK()约束放在所检查的内容附近    42
3.8.1 对数值考虑使用范围约束    42
3.8.2 对于字符值考虑使用LIKE和SIMILAR TO约束    43
3.8.3 时间值是有长短的    43
3.8.4 避免使用REAL和FLOAT数据类型    43
3.9 将多列约束尽可能靠近这些列    43
3.10 将表级别的CHECK()约束放到表声明的最后    44
3.11 对多表约束使用CREATE ASSERTION    44
3.12 使CHECK()约束的目的唯一    45
3.13 每个表都必须有键才能称为表    45
3.13.1 自动编号不是关系型键    47
3.13.2 文件不是表    47
3.13.3 键的属性    49
3.14 不要分割属性    56
3.14.1 分割为多个表    56
3.14.2 分割为多个列    56
3.14.3 分割为多个行    58
3.15 不要对RDBMS使用面向对象的设计    59
3.15.1 表不是对象实例    60
3.15.2 对RDBMS不要使用EAV设计    61
第4章 尺度与测量    63
4.1 测度论    63
4.1.1 范围与颗粒度    65
4.1.2 范围    65
4.1.3 颗粒度、准确度和精度    65
4.2 尺度类型    66
4.2.1 名义尺度    66
4.2.2 种类尺度    67
4.2.3 绝对尺度    67
4.2.4 顺序尺度    68
4.2.5 级别尺度    69
4.2.6 间距尺度    69
4.2.7 比例尺度    69
4.3 使用尺度    70
4.4 尺度转换    71
4.5 导出单位    72
4.6 标点与标准单位    73
4.7 在数据库中使用尺度的一般准则    74
第5章 数据编码方案    77
5.1 不好的编码方案    77
5.2 编码方案类型    80
5.2.1 枚举编码    80
5.2.2 测量编码    80
5.2.3 缩写编码    81
5.2.4 算法编码    81
5.2.5 层次编码    82
5.2.6 向量编码    83
5.2.7 拼接编码    84
5.3 设计编码方案的一般准则    85
5.3.1 现有的编码标准    85
5.3.2 允许扩展    85
5.3.3 使用显式的丢失值避免NULL    86
5.3.4 为终端用户转换编码    86
5.3.5 在数据库中保存编码    89
5.4 多字符集    90
第6章 编码选择    91
6.1 选择标准构造,不要选择专有构造    92
6.1.1 使用标准OUTER JOIN语法    93
6.1.2 中缀INNER JOIN和CORSS JOIN语法是可选的,但是很好用    97
6.1.3 使用ISO时间语法    98
6.1.4 使用标准和可移植的函数    99
6.2 选择紧凑格式,不要选择松散格式    99
6.2.1 避免使用多余的括号    100
6.2.2 使用CASE系列表达式    101
6.2.3 避免使用冗余表达式    103
6.2.4 寻找紧凑格式    104
6.3 使用注释    107
6.3.1 存储过程    108
6.3.2 控制语句注释    108
6.3.3 对子句的注释    109
6.4 避免优化器提示    109
6.5 触发器的优先级不应当高于DRI操作    109
6.6 使用SQL存储过程    111
6.7 避免在数据库中使用用户定义函数和扩展    112
6.7.1 多语言问题    112
6.7.2 可移植性问题    113
6.7.3 优化问题    113
6.8 避免使用过度的辅助索引    113
6.9 避免使用关联子查询    114
6.10 避免使用UNION    115
6.11 测试SQL    118
6.11.1 测试NULL所有可能的组合    118
6.11.2 检查并测试所有的CHECK()约束    118
6.11.3 注意字符列    118
6.11.4 测试大小    119
第7章 如何使用视图    121
7.1 视图的命名规范与表一样    123
7.2 视图提供行和列级别的安全性    124
7.3 视图确保了有效访问路径    125
7.4 视图对用户隐藏了复杂性    125
7.5 视图确保了正确的数据派生    127
7.6 视图将表和/或列重新命名    127
7.7 视图实施复杂的完整性约束    127
7.8 可更新的视图    130
7.8.1 WITH CHECK OPTION子句    130
7.8.2 INSTEAD OF触发器    131
7.9 每个视图都要有创建的原因    131
7.10 避免视图的数量快速增长    132
7.11 将视图与基表同步    132
7.12 不恰当地使用视图    133
7.12.1 用于域支持的视图    133
7.12.2 单个解决方案的视图    134
7.12.3 不要为每个基表都创建视图    135
7.13 学习使用物化的视图    135
第8章 如何编写存储过程    137
8.1 大多数SQL 4GL都不是用于应用程序的    138
8.2 基本软件工程    138
8.2.1 内聚    139
8.2.2 耦合    140
8.3 使用传统的结构化编程    141
8.4 避免可移植性问题    143
8.4.1 避免创建临时表    143
8.4.2 避免使用游标    144
8.4.3 面向集合的构造优于过程化代码    146
8.5 标量与结构化参数的对比    151
8.6 避免使用动态SQL    152
8.6.1 性能    152
8.6.2 SQL注入    153
第9章 试探法    155
9.1 将规格说明表达为清晰的语句    156
9.2 在名词的后面加上“……的集合”    156
9.3 从问题语句中删除行为动词    157
9.4 仍然可以使用存根    157
9.5 不要担心数据的显示    160
9.6 第一次尝试需要特别处理    160
9.6.1 不要舍不得扔掉你对DDL的第一次尝试    161
9.6.2 保存你对DML的第一次尝试    161
9.7 不要以方框和箭头的方式思考    162
9.8 画圆圈和集合图    162
9.9 学习方言    163
9.10 假设WHERE子句是“巨型变形虫”    163
9.11 使用新闻组和因特网    164
第10章 以SQL的方式思考    165
10.1 不好的SQL编程方式与过程化语言    166
10.2 把列当作字段思考    170
10.3 以过程化而不是说明性的方式思考    172
10.4 模式应该看起来像输入格式    174
附录A 资源    177
附录B 参考文献    183
索引    187
暂无评论!
合作: 威尼斯人官网 赌球技巧 新葡京娱乐场