因为增加非空列意味这表里面不能有数据,然后一定会出错。解决办法是
1.创建一个新的列(可以为空)
alter table table_name add column_name column_tpye ----增加列
2.给这个列中所有行赋一个值
update table_name set column_name=?
3.在SQLServer里面运用下面代码将报错
alter table table_name alter column column_name column_type not null---修改列
解决办法:
点击设计会弹出属性列表,然后设置相应属性列为非空,然后再运行3的代码,因为上诉语句要设置属性列非空,前提条件是原来属性列本身就是非空的,如果不加not null那么属性列会被更改为可为空,这在我们改变属性数据类型时非常关键。
可能的问题:
1.通过上述控制台更改属性列非空保存后可能会出现不允许修改的情况,可以通过下面步骤设置:
选择设计器,然后将下图中黑圈去除✔
最后再次保存就可以了,但如果不保存还是为空的话,3处的代码还是无效。
《SQL Server 2008查询性能优化》为你提供了处理查询性能所需要的工具。建立、维护数据库和数据库服务器可能是个困难的工作。当服务器的运行越来越慢时,这个工作就变得更加困难。来自用户的愤怒的电话以及站在你办公桌周围的管理人员都使你很不快活。在开发代码的同时,如果你花费时间和精力来开发一个性能故障排错的
方法
。那么你就能避免这种情况——至少可以快速而有效地做出反应。《SQL Server 2008查询性能优化》指出的性能要点之一是数据库随着用户和数据的日益增多而进行扩展的必要性。你需要理解性能低下的起因。以及识别并修复它们的
方法
。《SQL Server 2008查询性能优化》将帮助你:
使用性能监视器、SQL Trace以及动态管理视图和函数建立性能基线
理解一般系统中发生瓶颈的地方。以及解决瓶颈的
方法
识别常见性能问题以及对其快速处理的
方法
实施修复甚至预防性能问题的T-SQL最佳实践
《SQL Server 2008查询性能优化》不是理论书籍,它的目的是帮助你避免数据库出现性能低下的状况,它还能帮助你保住你的工作。
《SQL Server 2008查询性能优化》通过大量实例,详细介绍了SQL Server数据库系统优化的各种
方法
和技巧。内容涵盖了数据库应用系统中各种性能瓶颈的表现形式及其发生的根源和解决
方法
,从硬件瓶颈到查询、索引设计以及数据库管理等,贯穿了数据库系统知识的各个方面。最后以一个实际的工作负载将所有技巧联系起来,并且提供了“宝典”式的最佳实践
列
表。
《SQL Server 2008查询性能优化》适合于关心数据库应用系统性能的开发人员和数据库管理人员阅读。通过阅读《SQL Server 2008查询性能优化》,不仅可以学习到数据库性能管理的许多知识和技巧,还有助于养成良好的编程习惯,为实现高性能的数据库应用系统打下基础。
第1章 SQL查询性能调整 1
1.1 性能调整过程 2
1.1.1 核心过程 2
1.1.2 迭代过程 4
1.2 性能vs.价格 7
1.2.1 性能目标 7
1.2.2 “足够好”的调整 7
1.3 性能基线 8
1.4 工作的重点 9
1.5 SQL Server性能杀手 10
1.5.1 低质量的索引 10
1.5.2 不精确的统计 11
1.5.3 过多的阻塞和死锁 11
1.5.4 不基于数据集的操作 11
1.5.5 低质量的查询设计 12
1.5.6 低质量的数据库设计 12
1.5.7 过多的碎片 12
1.5.8 不可重用的执行计划 13
1.5.9 低质量的执行计划 13
1.5.10 频繁重编译计划 13
1.5.11 游标的错误使用 13
1.5.12 错误配置数据库日志 14
1.5.13 过多使用或者错误配置tempdb 14
1.6 小结 14
第2章 系统性能分析 15
2.1 性能监视器工具 15
2.2 动态管理视图 17
2.3 硬件资源瓶颈 18
2.3.1 识别瓶颈 18
2.3.2 瓶颈解决方案 19
2.4 内存瓶颈分析 19
2.4.1 SQL Server内存管理 20
2.4.2 Available Bytes 23
2.4.3 Pages/sec和Page Faults/sec计数器 23
2.4.4 Buffer Cache Hit Ratio 24
2.4.5 Page Life Expectancy 24
2.4.6 Checkpoint Pages/sec 24
2.4.7 Lazy writes/sec 24
2.4.8 Memory Grants Pending 25
2.4.9 Target Server Memory(KB)和Total Server Memory(KB) 25
2.5 内存瓶颈解决方案 25
2.5.1 优化应用程序工作负载 26
2.5.2 为SQL Server分配更多内存 27
2.5.3
增加
系统内存 27
2.5.4 更换32位处理器为64位处理器 27
2.5.5 启用3GB进程空间 28
2.5.6 在32位SQL Server中使用4GB以上内存 28
2.6 磁盘瓶颈分析 29
2.6.1 磁盘计数器 30
2.6.2 % Disk Time 30
2.6.3 Current Disk Queue Length 31
2.6.4 Disk Transfers/sec 31
2.6.5 Disk Bytes/sec 32
2.6.6 Avg. Disk Sec/Read和Avg. Disk Sec/Write 32
2.7 磁盘瓶颈解决方案 32
2.7.1 优化应用程序工作负载 33
2.7.2 使用更快的磁盘驱动器 33
2.7.3 使用一个RAID阵
列
33
2.7.4 使用SAN系统 35
2.7.5 恰当地对齐磁盘 35
2.7.6 使用电池后备的控制器缓存 36
2.7.7 添加系统内存 36
2.7.8 创建多个文件和文件组 36
2.7.9 将表和索引放在不同的磁盘上 39
2.7.10 将日志文件保存到独立的物理磁盘 39
2.7.11 表的分区 40
2.8 处理器瓶颈分析 40
2.8.1 % Processor Time 41
2.8.2 % Privileged Time 41
2.8.3 Processor Queue Length 42
2.8.4 Context Switches/sec 42
2.8.5 Batch Requests/sec 42
2.8.6 SQL Compilations/sec 42
2.8.7 SQL Recompilations/sec 43
2.9 处理器瓶颈解决方案 43
2.9.1 优化应用程序工作负载 43
2.9.2 消除过多的编译/重编译 43
2.9.3 使用更多或更快的处理器 44
2.9.4 使用大的二级(L2)/三级(L3)缓存 44
2.9.5 运行更高效的控制器/驱动程序 44
2.9.6 不运行不必要的软件 45
2.10 网络瓶颈分析 45
2.10.1 Bytes Total/sec 45
2.10.2 % Net Utilization 46
2.11 网络瓶颈解决方案 46
2.11.1 优化应用程序工作负载 46
2.11.2
增加
网络适配器 47
2.11.3 节制和避免中断 47
2.12 SQL Server总体性能 47
2.12.1 丢失索引 48
2.12.2 数据库阻塞 49
2.12.3 不可重用的执行计划 50
2.12.4 总体表现 50
2.13 创建一个基线 51
2.13.1 创建性能计数器的一个可重用
列
表 51
2.13.2 使用性能计数器
列
表创建一个计数器日志 54
2.13.3 最小化性能监视器开销 55
2.14 以基线为标准的系统状态分析 56
2.15 小结 57
第3章 SQL查询性能分析 58
3.1 SQL Profiler工具 58
3.1.1 Profiler跟踪 59
3.1.2 事件 60
3.1.3 数据
列
62
3.1.4 过滤器 64
3.1.5 跟踪模板 65
3.1.6 跟踪数据 65
3.2 跟踪的自动化 66
3.2.1 使用GUI捕捉跟踪 66
3.2.2 使用存储过程捕捉跟踪 67
3.3 结合跟踪和性能监视器输出 68
3.4 SQL Profiler建议 69
3.4.1 限制事件和数据
列
69
3.4.2 丢弃性能分析所用的启动事件 70
3.4.3 限制跟踪输出大小 70
3.4.4 避免在线数据
列
排序 71
3.4.5 远程运行Profiler 71
3.4.6 限制使用某些事件 71
3.5 没有Profiler情况下的查询性能度量 71
3.6 开销较大的查询 72
3.6.1 识别开销较大的查询 73
3.6.2 识别运行缓慢的查询 77
3.7 执行计划 78
3.7.1 分析查询执行计划 80
3.7.2 识别执行计划中开销较大的步骤 82
3.7.3 分析索引有效性 83
3.7.4 分析连接有效性 84
3.7.5 实际执行计划vs.估算执行计划 88
3.7.6 计划缓存 89
3.8 查询开销 90
3.8.1 客户统计 90
3.8.2 执行时间 91
3.8.3 STATISTICS IO 92
3.9 小结 94
第4章 索引分析 95
4.1 什么是索引 95
4.1.1 索引的好处 97
4.1.2 索引开销 98
4.2 索引设计建议 100
4.2.1 检查WHERE子句和连接条件
列
100
4.2.2 使用窄索引 102
4.2.3 检查
列
的唯一性 103
4.2.4 检查
列
数据类型 106
4.2.5 考虑
列
顺序 107
4.2.6 考虑索引类型 109
4.3 聚簇索引 109
4.3.1 堆表 110
4.3.2 与
非
聚簇索引的关系 110
4.3.3 聚簇索引建议 112
4.4
非
聚簇索引 117
4.4.1
非
聚簇索引维护 117
4.4.2 定义书签查找 117
4.4.3
非
聚簇索引建议 118
4.5 聚簇索引vs.
非
聚簇索引 118
4.5.1 聚簇索引相对于
非
聚簇索引的好处 119
4.5.2
非
聚簇索引相对于聚簇索引的好处 120
4.6 高级索引技术 121
4.6.1 覆盖索引 122
4.6.2 索引交叉 124
4.6.3 索引连接 125
4.6.4 过滤索引 126
4.6.5 索引视图 128
4.6.6 索引压缩 132
4.7 特殊索引类型 134
4.7.1 全文索引 134
4.7.2 空间索引 135
4.7.3 XML 135
4.8 索引的附加特性 135
4.8.1 不同的
列
排序顺序 135
4.8.2 在计算
列
上的索引 136
4.8.3 BIT数据类型
列
上的索引 136
4.8.4 作为一个查询处理的CREATE INDEX语句 136
4.8.5 并行索引创建 136
4.8.6 在线索引创建 137
4.8.7 考虑数据库引擎调整顾问 137
4.9 小结 137
第5章 数据库引擎调整顾问 139
5.1 数据库引擎调整顾问机制 139
5.2 数据库引擎调整顾问实例 143
5.2.1 调整一个查询 143
5.2.2 调整一个跟踪工作负载 146
5.3 数据库引擎调整顾问的局限性 148
5.4 小结 149
第6章 书签查找分析 150
6.1 书签查找的目的 150
6.2 书签查找的缺点 152
6.3 分析书签查找的起因 153
6.4 解决书签查找 155
6.4.1 使用一个聚簇索引 155
6.4.2 使用一个覆盖索引 155
6.4.3 使用索引连接 158
6.5 小结 160
第7章 统计分析 161
7.1 统计在查询优化中的角色 161
7.2 索引
列
上的统计 162
7.2.1 更新统计的好处 162
7.2.2 过时统计的缺点 164
7.3 在
非
索引
列
上的统计 165
7.3.1 在
非
索引
列
上统计的好处 166
7.3.2 丢失
非
索引
列
上的统计的缺点 169
7.4 分析统计 172
7.4.1 密度 174
7.4.2 多
列
索引上的统计 174
7.4.3 过滤索引上的统计 175
7.5 统计维护 176
7.5.1 自动维护 177
7.5.2 人工维护 179
7.5.3 统计维护状态 181
7.6 为查询分析统计的有效性 182
7.6.1 解决丢失统计问题 182
7.6.2 解决过时统计问题 184
7.7 建议 186
7.7.1 统计的向后兼容性 186
7.7.2 自动创建统计 186
7.7.3 自动更新统计 187
7.7.4 自动异步更新统计 189
7.7.5 收集统计的采样数量 189
7.8 小结 190
第8章 碎片分析 191
8.1 碎片的成因 191
8.1.1 UPDATE语句引起的页面分割 193
8.1.2 INSERT语句引起的页面分割 196
8.2 碎片开销 197
8.3 分析碎片数量 200
8.4 碎片解决方案 204
8.4.1 卸载并重建索引 204
8.4.2 使用DROP_EXISTING子句重建索引 205
8.4.3 执行ALTER INDEX REBUILD语句 205
8.4.4 执行ALTER INDEX REORGANIZE语句 207
8.5 填充因子的重要性 209
8.6 自动维护 212
8.7 小结 217
第9章 执行计划缓冲分析 218
9.1 执行计划生成 218
9.1.1 解析器 219
9.1.2 代数化器 220
9.1.3 优化 221
9.2 执行计划缓冲 227
9.3 执行计划组件 227
9.3.1 查询计划 227
9.3.2 执行上下文 227
9.4 执行计划的老化 228
9.5 分析执行计划缓冲 228
9.6 执行计划重用 229
9.6.1 即席工作负载 230
9.6.2 预定义工作负载 231
9.6.3 即席工作负载的计划可重用性 231
9.6.4 预定义工作负载的计划可重用性 239
9.7 查询计划Hash和查询Hash 248
9.8 执行计划缓冲建议 251
9.8.1 明确地参数化查询的可变部分 252
9.8.2 使用存储过程实现业务功能 252
9.8.3 使用sp_executesql编程以避免存储过程维护 252
9.8.4 实现准备/执行模式以避免重传查询字符串 253
9.8.5 避免即席查询 253
9.8.6 对于动态查询sp_executesql优于EXECUTE 253
9.8.7 小心地参数化查询的可变部分 254
9.8.8 不要允许查询中对象的隐含解析 254
9.9 小结 254
第10章 存储过程重编译 256
10.1 重编译的好处和缺点 256
10.2 确认导致重编译的语句 258
10.3 分析重编译起因 260
10.3.1 架构或绑定变化 261
10.3.2 统计变化 261
10.3.3 延迟对象解析 264
10.3.4 SET选项变化 266
10.3.5 执行计划老化 266
10.3.6 显式调用sp_recompile 267
10.3.7 显式使用RECOMPILE子句 268
10.4 避免重编译 269
10.4.1 不要交替使用DDL和DML语句 270
10.4.2 避免统计变化引起的重编译 271
10.4.3 使用表变量 273
10.4.4 避免在存储过程中修改SET选项 275
10.4.5 使用OPTIMIZE FOR查询提示 276
10.4.6 使用计划指南 277
10.5 小结 281
第11章 查询设计分析 282
11.1 查询设计建议 282
11.2 在小结果集上操作 283
11.2.1 限制选择
列
表中的
列
数 283
11.2.2 使用高选择性的WHERE子句 284
11.3 有效地使用索引 284
11.3.1 避免不可参数化的搜索条件 285
11.3.2 避免WHERE子句
列
上的算术运算符 289
11.3.3 避免WHERE子句
列
上的函数 290
11.4 避免优化器提示 292
11.4.1 连接提示 293
11.4.2 索引提示 295
11.5 使用域和参照完整性 296
11.5.1
非空
约束 297
11.5.2 声明参照完整性 299
11.6 避免资源密集型查询 301
11.6.1 避免数据类型转换 301
11.6.2 使用EXISTS代替COUNT(*)验证数据存在 303
11.6.3 使用UNION ALL代替UNION 304
11.6.4 为聚合和排序操作使用索引 305
11.6.5 避免在批查询中的局部变量 306
11.6.6 小心地命名存储过程 309
11.7 减少网络传输数量 311
11.7.1 同时执行多个查询 311
11.7.2 使用SET NOCOUNT 311
11.8 降低事务开销 312
11.8.1 减少日志开销 312
11.8.2 减少锁开销 314
11.9 小结 315
第12章 阻塞分析 316
12.1 阻塞基础知识 316
12.2 理解阻塞 317
12.2.1
原
子性 317
12.2.2 一致性 320
12.2.3 隔离性 320
12.2.4 持久性 321
12.3 数据库锁 321
12.3.1 锁粒度 322
12.3.2 锁升级 325
12.3.3 锁模式 326
12.3.4 锁兼容性 332
12.4 隔离级别 332
12.4.1 未提交读 333
12.4.2 已提交读 333
12.4.3 可重复读 335
12.4.4 可序
列
化(Serializable) 338
12.4.5 快照(Snapshot) 343
12.5 索引对锁的作用 343
12.5.1
非
聚簇索引的作用 344
12.5.2 聚簇索引的作用 346
12.5.3 索引在可序
列
化隔离级别上的作用 346
12.6 捕捉阻塞信息 347
12.6.1 使用SQL捕捉阻塞信息 347
12.6.2 Profiler跟踪和被阻塞进程报告事件 349
12.7 阻塞解决方案 351
12.7.1 优化查询 352
12.7.2 降低隔离级别 352
12.7.3 分区争用的数据 353
12.7.4 争用数据上的覆盖索引 354
12.8 减少阻塞的建议 354
12.9 自动化侦测和收集阻塞信息 355
12.10 小结 359
第13章 死锁分析 360
13.1 死锁基础知识 360
13.2 使用错误处理来捕捉死锁 361
13.3 死锁分析 362
13.3.1 收集死锁信息 362
13.3.2 分析死锁 364
13.4 避免死锁 368
13.4.1 按照相同的时间顺序访问资源 368
13.4.2 减少被访问资源的数量 369
13.4.3 最小化锁的争用 369
13.5 小结 370
第14章 游标开销分析 372
14.1 游标基础知识 372
14.1.1 游标位置 373
14.1.2 游标并发性 374
14.1.3 游标类型 376
14.2 游标开销比较 378
14.2.1 游标位置的开销比较 378
14.2.2 游标并发性上的开销比较 380
14.2.3 在游标类型上的开销比较 381
14.3 默认结果集 383
14.3.1 好处 384
14.3.2 缺点 384
14.4 分析SQL Server游标开销 386
14.5 游标建议 390
14.6 小结 392
第15章 数据库工作负载优化 393
15.1 工作负载优化基础知识 393
15.2 工作负载优化步骤 394
15.3 捕捉工作负载 397
15.4 分析工作负载 399
15.5 识别开销最大的查询 400
15.6 确定开销最大的查询的基线资源使用 402
15.6.1 总体资源使用 402
15.6.2 详细资源使用 402
15.7 分析和优化外部因素 405
15.7.1 分析应用程序使用的批级别选项 405
15.7.2 分析统计有效性 406
15.7.3 分析碎片整理需求 406
15.8 分析开销最大的查询的内部行为 410
15.8.1 分析查询执行计划 410
15.8.2 识别执行计划中开销较大的步骤 412
15.8.3 分析处理策略的效率 412
15.9 优化代价最大的查询 412
15.9.1 修改现有索引 413
15.9.2 分析连接提示的应用 415
15.9.3 避免聚簇索引扫描操作 417
15.9.4 修改过程 418
15.10 分析对数据库工作负载的影响 420
15.11 迭代各个优化阶段 421
15.12 小结 424
第16章 SQL Server优化检查
列
表 425
16.1 数据库设计 425
16.1.1 平衡不足和过多的规范化 426
16.1.2 从实体完整性约束中得利 427
16.1.3 从域和参照完整性约束中得利 428
16.1.4 采用索引设计最佳实践 430
16.1.5 避免在存储过程名称中使用sp_前缀 431
16.1.6 最小化触发器的使用 431
16.2 查询设计 432
16.2.1 使用SET NOCOUNT ON命令 432
16.2.2 显式定义对象所有者 432
16.2.3 避免不可参数化的搜索条件 432
16.2.4 避免WHERE子句
列
上的算术运算符 433
16.2.5 避免优化器提示 434
16.2.6 远离嵌套视图 434
16.2.7 确保没有隐含的数据类型转换 435
16.2.8 最小化日志开销 435
16.2.9 采用重用执行计划的最佳实践 435
16.2.10 采用数据库事务最佳实践 436
16.2.11 消除或减少数据库游标开销 437
16.3 配置设置 437
16.3.1 Affinity Mask 437
16.3.2 内存配置选项 437
16.3.3 并行性开销阈值 438
16.3.4 最大并行度 438
16.3.5 优化即席工作负载 438
16.3.6 查询调控器开销限制 439
16.3.7 填充因子(%) 439
16.3.8 被阻塞过程阈值 439
16.3.9 数据库文件布局 439
16.3.10 数据库压缩 440
16.4 数据库管理 440
16.4.1 保持统计最新 440
16.4.2 保持最小数量的索引碎片数量 441
16.4.3 循环使用SQL错误日志文件 441
16.4.4 避免像AUTO_CLOSE或AUTO_SHRINK这样的自动化数据库功能 441
16.4.5 最小化SQL跟踪开销 442
16.5 数据库备份 442
16.5.1 增量和事务日志备份频率 442
16.5.2 备份分布 443
16.5.3 备份压缩 444
16.6 小结 444
作者:(美国)弗里奇(Grant Fritchey) (美国)达姆(Sajal Dam) 译者:姚军
弗里奇(Grant Fritchey),为FM Global(一家行业领先的工程和保险公司)工作,担任首席DBA。他使用各种语言(如VB、C#和Java等)开发了许多大规模的应用程序,从版本6.0开始使用SQL Server。他曾经为3家失败的.com公司担任财务和咨询工作,还是Dissecting SQL Server Execution Plans一书的作者。
达姆(Sajal Dam),拥有位于印度班加罗尔的印度理工学院的计算机科学技术硕士学位,并且使用微软技术超过16年。他已经在设计数据库应用和管理软件开发方面拥有了很广泛的背景。Saial还在从前端网页到后端数据库的基于微软技术的应用程序上,具备了故障定位和性能优化的大量经验。他有许多为《财富》500强公司设计可伸缩的数据库解决方案和最大化数据库环境性能的经验。
ALTER TABLE 只允许添加可包含空值或指定了 DEFAULT 定义的
列
。
IF EXISTS(SELECT 1 FROM SYSOBJECTS WHERE NAME = N'tab_test') AND NOT
EXISTS(SELECT 1 FROM SYSOBJECTS A, SYSCOLUMNS B WHERE B.ID = A.ID AND
B.NAME =...
默认值default约束:Alter table 表名 add constraint 自定义约束名称 default('默认值') for 添加约束的
列
名。当添加多个主码时:
列
1 char(4),
列
2 char(4),primary key(
列
1,
列
2)默认值约束:create table 表名(
列
1 nchar(1) default '默认值')check约束:create table 表名(
列
1 char(4) check(约束条件))(2)已经创建表之后添加约束。
《精通SQ:结构化查询语言详解》全面讲解SQL语言,提供317个典型应用,读者可以随查随用,针对SQL Server和Oracle进行讲解,很有代表性。
全书共包括大小实例317个,突出了速学速查的特色。《精通SQ:结构化查询语言详解》内容丰富,讲解通俗易懂,具有很强的实用性和可操作性。
第1章 数据库与SQL基础
1.1 数据库的基本概念
1.1.1 数据库的由来
1.1.2 数据库系统的概念
1.2 数据库系统的结构、组成及工作流程
1.2.1 数据库的体系结构
1.2.2 数据库系统的组成
1.2.3 数据库的工作流程
1.3 数据库的发展
1.3.1 第一代数据库
1.3.2 第二代数据库
1.3.3 新一代数据库技术的研究和发展
1.4 关系数据库
1.4.1 关系模型
1.4.2 Codd十二法则
1.4.3 范式
1.5 SQL语言基础
1.5.1 SQL的历史
1.5.2 SQL语言的组成
1.5.3 SQL语句的结构
1.5.4 SQL的优点
1.5.5 SQL的执行
1.6 SQL环境
1.6.1 环境
1.6.2 SQL的层次结构
1.6.3 客户程序和服务程序系统
1.6.4 SQL环境中对象的命名规则
第2章 主要的关系数据库与SQL
2.1 SQL Server
2.1.1 SQL Server的结构
2.1.2 数据库访问标准化接口-ODBC
2.1.3 使用查询分析器执行SQL语句
2.2 Transact-SQL
2.2.1 Transact-SQL 概述
2.2.2 Transact-SQL的主要组成
2.2.3 Transact-SQL的一些重要命令
2.3 Oracle数据库
2.3.1 Oracle数据库软件组成
2.3.2 Oracle数据库体系结构
2.3.3 Oracle数据库系统结构
2.3.4 使用SQL*Plus执行SQL语句
2.4 PL/SQL简介
2.4.1 PL/SQL的特点
2.4.2 PL/SQL程序结构
第3章 创建、修改和删除表
3.1 表的基础知识
3.1.1 表的基本结构
3.1.2 表的种类
3.2 SQL数据类型
3.2.1 字符型数据
3.2.2 数字型数据
3.2.3 日期数据类型
3.2.4 二进制数据类型
3.2.5 文本和图形数据类型
3.2.6 自定义数据类型
3.3 表的创建(CREATE)
3.3.1 创建基本表
3.3.2
非空
约束
3.3.3 DEFAULT指定缺省值
3.4 表的修改
3.4.1
增加
新列
3.4.2 删除
列
3.4.3 修改
列
3.5 表的删除与重命名
3.5.1 重命名表
3.5.2 删除表
3.6 创建、删除数据库
3.6.1 数据库的创建
3.6.2 SQL Server中数据库的创建
3.6.3 删除数据库
第4章 索引与视图的创建
4.1 索引的基础知识
4.1.1 索引的概念
4.1.2 索引的结构
4.2 索引的创建与销毁
4.2.1 基本创建语法
4.2.2 本章实例用到的实例表
4.2.3 创建简单的
非
簇索引
4.2.4 多字段
非
簇索引的创建
4.2.5 使用UNIQUE关键字创建惟一索引
4.2.6 使用CLUSTERDE关键字创建簇索引
4.2.7 索引的销毁
4.2.8 使用索引的几点
原
则
4.3 视图的基础知识
4.3.1 视图简介
4.3.2 视图的优缺点
4.4 视图的创建与销毁
4.4.1 基本创建语法
4.4.2 创建简单的视图
4.4.3 利用视图简化表的复杂连接
4.4.4 利用视图简化复杂查询
4.4.5 视图的销毁
4.4.6 使用视图的几点
原
则
第5章 简单的查询
5.1 查询的基本结构
5.1.1 SELECT语句的结构
5.1.2 SELECT语句的执行步骤
5.2
列
的查询
5.2.1 本章用到的实例表
5.2.2 单
列
查询
5.2.3 使用DISTINCT去除重复信息
5.2.4 多
列
查询
5.2.5 查询所有的
列
5.3 排序查询结果
5.3.1 单
列
排序
5.3.2 多
列
排序
5.3.3 采用序号进行多
列
排序
5.3.4 反向排序
5.4 使用WHERE子句定义搜索条件查询
5.4.1 WHERE子句单条件查询
5.4.2 单值比较运算符
5.4.3 BETWEEN运算符范围筛选
5.4.4 NULL值的判断
第6章 复杂搜索条件查询
6.1 本章用到的实例表
6.2 组合查询条件
6.2.1 AND运算符
6.2.2 OR运算符
6.2.3 AND、OR运算符的组合使用
6.3 IN运算符
6.3.1 IN运算符的使用
6.3.2 IN运算符与OR运算符
6.4 NOT运算符
6.4.1 使用NOT运算符
6.4.2 NOT运算符与运算符
6.5 使用LIKE进行模糊查询
6.5.1 LIKE运算符
6.5.2 “%”通配符
6.5.3 “_”通配符
6.5.4 “[]”通配符
6.5.5 使用ESCAPE定义转义符
第7章 连接符、数值运算与函数
7.1 本章实例用到的表
7.2 连接符
7.2.1 连接符的应用
7.2.2 使用别名
7.3 数值运算
7.3.1 数学运算符的种类
7.3.2 数学运算符的运用
7.3.3 使用CAST表达式转换数据类型
7.3.4 使用CASE表达式
7.4 函数
7.4.1 有关函数的说明
7.4.2 字符处理函数
7.4.3 算术运算函数
7.4.4 日期时间函数
7.4.5 CONVERT()函数转换日期、时间
第8章 聚合分析与分组
8.1 聚合分析的基本概念
8.1.1 聚合分析
8.1.2 聚合函数
8.2 聚合函数的应用
8.2.1 求和函数-SUM()
8.2.2 计数函数-COUNT()
8.2.3 最大/最小值函数-MAX()/MIN()
8.2.4 均值函数-AVG()
8.2.5 聚合分析的重值处理
8.2.6 聚合函数的组合使用
8.3 组合查询
8.3.1 GROUP BY子句创建分组
8.3.2 GROUP BY子句根据多
列
组合行
8.3.3 ROLLUP运算符和CUBE运算符
8.3.4 GROUP BY子句中的NULL值处理
8.3.5 HAVING子句
8.3.6 HAVING子句与WHERE子句
8.3.7 SELECT语句各查询子句总结
第9章 多表查询
9.1 本章用到的实例表
9.2 表的基本连接
9.2.1 连接表的目的
9.2.2 简单的二表连接
9.2.3 多表连接
9.2.4 使用表别名
9.2.5 采用JOIN关键字建立连接
9.3 表的连接类型
9.3.1 自连接
9.3.2 自然连接(NATURAL JOIN)
9.3.3 内连接(INNER JOIN)
9.3.4 外连接(OUTER JOIN)
9.3.5 交叉连接(CROSS JOIN)
9.4 UNION与UNION JOIN
9.4.1 关系的集合运算
9.4.2 UNION运算符
9.4.3 ORDER BY子句排序UNION运算结果
9.4.4 对多表进行UNION运算
9.4.5 UNION JOIN 连接表
9.5 表连接的其他应用及注意问题
9.5.1 连接表进行聚合运算
9.5.2 多表连接的综合运用
9.5.3 多表连接注意事项
第10章 子查询
10.1 创建和使用返回单值的子查询
10.1.1 在多表查询中使用子查询
10.1.2 在子查询中使用聚合函数
10.2 创建和使用返回多行的子查询
10.2.1 IN子查询
10.2.2 IN子查询实现集合交和集合差运算
10.2.3 EXISTS子查询
10.2.4 EXISTS子查询实现两表交集
10.2.5 SOME/ALL子查询
10.2.6 UNIQUE子查询
10.3 相关子查询
10.3.1 使用IN引入相关子查询
10.3.2 比较运算符引入相关子查询
10.3.3 在HAVING子句中使用相关子查询
10.4 嵌套子查询
10.5 使用子查询创建视图
10.6 树查询
第11章 数据插入操作
11.1 插入单行记录
11.1.1 基本语法
11.1.2 整行插入
11.1.3 NULL值的插入
11.1.4 惟一值的插入
11.1.5 特定字段数据插入
11.1.6 通过视图插入行
11.2 插入多行记录
11.2.1 由VALUES关键字引入多行数据插入
11.2.2 使用SELECT语句插入值
11.3 表中数据的复制
11.3.1 基本语法
11.3.2 应用实例
11.4 从外部数据源导入、导出数据
11.4.1 Access数据库数据的导出
11.4.2 Access数据库数据的导入
11.4.3 SQL Server数据库数据导出
11.4.4 SQL Server数据库数据导入
第12章 数据的更新和删除
12.1 更新表中的数据
12.1.1 UPDATE语句的基本语法
12.1.2 UPDATE语句更
新列
值
12.1.3 利用子查询更新多行的值
12.1.4 依据外表值更新数据
12.1.5 分步更新表
12.2 删除表中的数据
12.2.1 DELETE语句基本语法
12.2.2 DELETE语句删除单行数据
12.2.3 DELETE语句删除多行数据
12.2.4 DELETE语句删除所有行
12.2.5 TRUNCATE TABLE语句
12.3 通过视图更新表
12.3.1 可更新视图的约束
12.3.2 通过视图更新表数据
12.3.3 通过视图删除表数据
第13章 安全性控制
13.1 SQL安全模式
13.1.1 授权ID
13.1.2 SQL的安全对象和权限
13.1.3 授权图
13.2 角色管理
13.2.1 CREATE语句创建角色
13.2.2 DROP语句删除角色
13.2.3 GRANT语句授予角色
13.2.4 REVOKE语句取消角色
13.3 权限管理
13.3.1 GRANT语句授予权限
13.3.2 REVOKE语句取消权限
13.3.3 SELECT权限控制
13.3.4 INSERT权限控制
13.3.5 UPDATE权限控制
13.3.6 DELETE权限控制
13.4 SQL Server安全管理
13.4.1 SQL Server登录认证
13.4.2 SQL Server用户ID的管理
13.4.3 SQL Server权限管理
13.4.4 SQL Server角色管理
13.5 Oracle安全管理
13.5.1 Oracle中用户、资源、概要文件、模式的概念
13.5.2 Oracle中的用户管理
13.5.3 Oracle中的资源管理
13.5.4 Oracle中的权限管理
13.5.5 Oracle中的角色管理
第14章 完整性控制
14.1 完整性约束简介
14.1.1 数据的完整性
14.1.2 完整性约束的类型
14.2 与表有关的约束
14.2.1
列
约束与表约束的创建
14.2.2 NOT NULL(
非空
)约束
14.2.3 UNIQUE(惟一)约束
14.2.4 PRIMARY KEY(主键)约束
14.2.5 FOREIGN KEY(外键)约束
14.2.6 CHECK(校验)约束
14.3 深入探讨外键与完整性检查
14.3.1 引用完整性检查
14.3.2 MATCH子句
14.3.3 更新、删除操作规则
14.4 域约束与断言
14.4.1 域与域约束
14.4.2 利用断言创建多表约束
14.5 SQL Server中的完整性控制
14.5.1 创建规则(Rule)
14.5.2 规则的绑定与松绑
14.5.3 创建缺省值(Default)
14.5.4 缺省值的绑定与松绑
第15章 存储过程与函数
15.1 SQL中的存储过程与函数
15.2 SQL Server 中的流控制语句
15.2.1 BEGIN...END语句
15.2.2 IF...ELSE语句
15.2.3 WHILE、BREAK和CONTINUE语句
15.2.4 DECLARE语句
15.2.5 GOTO label语句
15.2.6 RETURN语句
15.2.7 WAITFOR语句
15.2.8 PRINT语句
15.2.9 注释
15.3 SQL Server中的存储过程和函数
15.3.1 系统存储过程
15.3.2 使用CREATE PROCEDURE创建存储过程
15.3.3 使用EXECUTE语句调用存储过程
15.3.4 使用CREATE FUNCTION创建函数
15.3.5 使用Enterprise Manager创建存储过程和函数
15.3.6 修改和删除存储过程和函数
15.4 Oracle中的流控制语句
15.4.1 条件语句
15.4.2 循环语句
15.4.3 标号和GOTO
15.5 Oracle数据库中的存储过程
15.5.1 存储过程的创建与调用
15.5.2 Oracle中存储过程和函数的管理
第16章 SQL触发器
16.1 触发器的基本概念
16.1.1 触发器简介
16.1.2 触发器执行环境
16.2 SQL Server中的触发器
16.2.1 SQL Server触发器的种类
16.2.2 使用CREATE TRIGGER命令创建触发器
16.2.3 INSERT触发器
16.2.4 DELETE触发器
16.2.5 UPDATE触发器
16.2.6 INSTEAD OF触发器
16.2.7 嵌套触发器
16.2.8 递归触发器
16.2.9 SQL Server中触发器的管理
16.3 Oracle数据库中触发器的操作
16.3.1 Oracle触发器类型
16.3.2 触发器的创建
16.3.3 创建系统触发器
16.3.4 触发器的触发次序和触发谓词的使用
16.3.5 Oracle触发器的管理
第17章 SQL中游标的使用
17.1 SQL游标的基本概念
17.1.1 游标的概念
17.1.2 游标的作用及其应用
17.2 SQL游标的使用
17.2.1 使用DECLARE CURSOR语句创建游标
17.2.2 使用OPEN/CLOSE语句打开/关闭游标
17.2.3 使用FETCH语句检索数据
17.2.4 基于游标的定位DELETE语句
17.2.5 基于游标的定位UPDATE语句
17.3 SQL Server中游标的扩展
17.3.1 Transact_SQL扩展DECLARE CURSOR语法
17.3.2 @@CURSOR_ROWS全局变量确定游标的行数
17.3.3 @@FETCH_STATUS全局变量检测FETCH操作的状态
17.3.4 游标的关闭与释放
17.3.5 游标变量
17.3.6 使用系统过程管理游标
17.4 Oracle中游标的使用
17.4.1 显式游标与隐式游标
17.4.2 游标的
属性
17.4.3 %TYPE、%ROWTYPE定义记录变量
17.4.4 参数化游标
17.4.5 游标中的循环
17.4.6 游标变量
17.5 小结
第18章 事务控制与并发处理
18.1 SQL事务控制
18.1.1 事务控制的引入
18.1.2 事务的特性
18.1.3 SQL中与事务有关的语句
18.2 事务控制的具体实现
18.2.1 开始事务
18.2.2 SET CONSTRAINTS语句设置约束的延期执行
18.2.3 终止事务
18.3 并发控制
18.3.1 并发操作的问题
18.3.2 事务隔离级别
18.3.3 SET TRANSACTION设置事务
属性
18.4 SQL Server中的并发事务控制
18.4.1 锁的分类
18.4.2 SQL Server中表级锁的使用
18.4.3 设置隔离级别实现并发控制
18.4.4 死锁及其预防
18.5 Oracle中的并发事务控制
18.5.1 通过加锁避免写数据丢失
18.5.2 设置只读事务(READ ONLY)
18.5.3 Oracle中的隔离级别
第19章 嵌入式SQL
19.1 SQL的调用
19.1.1 直接调用SQL
19.1.2 嵌入式SQL
19.1.3 SQL调用层接口(CLI)
19.2 嵌入式SQL的使用
19.2.1 创建嵌入式SQL语句
19.2.2 SQL通信区
19.2.3 主变量
19.2.4 嵌入式SQL中使用游标
19.3 检索、操作SQL数据
19.3.1 不需要游标的SQL DML操作
19.3.2 使用游标的SQL DML操作
19.3.3 动态SQL技术
19.4 SQL Server中嵌入式SQL的编译运行
19.4.1 嵌入式SQL代码
19.4.2 预编译文件
19.4.3 设置Visual C++ 6.0连接
19.4.4 编译运行程序
19.5 Oracle中嵌入式SQL的编译运行
19.5.1 嵌入式SQL代码
19.5.2 预编译文件
19.5.3 设置Visual C++ 6.0编译环境
19.5.4 编译运行程序
附录A SQL保留字
附录B 常用的SQL命令
附录C 关于运行环境的说明
C.1 SQL Server 2000
C.1.1 直接访问
C.1.2 从企业管理器访问
C.2 Oracle系统
3.1.3 DropDownList和ListBox控件应用
3.1.4 CheckBOX和CheckBoxList控件应用
3.1.5 RadioButton和RadioButtonList控件应用
3.2 ASP.NET 2.0新增控件
3.2.1 BulletedList控件的应用
3.2.2 Substitution控件的应用
3.2.3 Wizard控件的应用
3.2.4 MultiView和View控件的应用
3.2.5 FileUpload控件的应用
3.3 其他常用控件
3.3.1 Calendar控件的应用
3.3.2 AdRotator控件的应用
3.3.3 Xml控件的应用
3.4 本章小结
第4章 验证控件
4.1
非空
验证
4.2 范围验证
4.3 比较验证
4.4 使用正则表达式验证
4.5 自定义验证
4.6 本章小结
第5章 ASP.NET 2.0对象、状态和配置
5.1 Response对象和Request对象
5.1.1 Response对象
5.1.2 Request对象
5.2 HTTP请求上下文
5.2.1 应用程序状态
5.2.2 Server对象
5.2.3 使用Server对象中Execute()和Transfer()
方法
重定向页面
5.2.4 Global.asax文件
5.3 状态管理
5.3.1 Application对象
5.3.2 Session对象
5.3.3 Cookie对象
5.3.4 ViewState对象
5.4 配置ASP.NET应用程序
5.4.1 Web.config文件概述
5.4.2 配置数据库链接字符串
5.4.3 添加自定义Web.Config文件配置节
5.4.4 对Web.Config文件进行读写操作
5.4.5 加密和解密Web.Config文件的配置节
5.4.6 ASP.NET网站管理工具
5.4.7 ASP.NET MMC管理单元
5.5 本章小结
第6章 数据源控件
6.1 SqlDataSource数据源控件
6.2 AccessDataSource数据源控件
6.3 XmlDataSource数据源控件
6.4 SiteMapDataSource数据源控件
6.5 0bjectDataSource数据源控件
6.6 本章小结
第7章 SQL Server 2005常用操作
7.1 SQL Server 2005
7.1.1 SQL Server 2005概述
7.1.2 安装SQL Server 2005数据库
7.1.3 连接数据库服务器
7.1.4 修改登录方式
7.2 管理数据库的基本对象
7.2.1 创建数据库
7.2.2 备份数据库
7.2.3 还
原
数据库
7.2.4 附加数据库
7.2.5 删除数据库
7.2.6 创建和修改袁
7.2.7 删除袁
7.3 SQL常用语句
7.3.1 获取指定条件的记录
7.3.2 获取指定数量的记录
7.3.3 对记录进行排序
7.3.4 模糊查询
7.3.5 对数据进行分组统计
7.3.6 嵌套查询
7.3.7 插入记录并返回ID
7.3.8 同时更新多条记录
7.3.9 根据条件删除记录
7.4 存储过程
7.4.1 使用存储过程添加数据
7.4.2 使用存储过程查询数据
7.4.3 使用存储过程更新数据
7.4.4 使用存储过程删除数据
7.4.5 存储过程与输出参数
7.5 本章小结
第8章 ADO.NET编程基础
8.1 AD0.NET的基本对象及其操作
8.1.1 Connection对象(连接数据库)
8.1.2 Command对象
8.1.3 DataReader对象
8.1.4 DataAdapter和DataSet对象
8.1.5 使用DataView过滤数据
8.1.6 动态创建DataTable对象
8.2 数据绑定
8.2.1 简单数据绑定
8.2.2 复杂数据绑定
8.2.3 Eval0
方法
和Bind()
方法
绑定数据
8.3 本章小结
第9章 GridView及其他数据控件的应用
9.1 GridView控件的应用
9.1.1 GridView控件的概述
9.1.2 使用GridView控件的绑定
列
绑定数据
9.1.3 使用GridView控件的模板
列
绑定数据
9.1.4 使用GridView控件编辑并删除数据
9.1.5 使用GridView控件分页显示数据
9.1.6 对GridView控件中的数据进行排序
9.2 其他数据控件的应用
9.2.1 使用Repeater控件显示数据
9.2.2 在Repeater控件中分页显示数据
9.2.3 使用DetailsView控件操作一条记录
9.2.4 使用FormView控件更新和插入数据
9.3 本章小结
第10章 导航与登录
10.1 站点导航
10.1.1 Menu控件
10.I.2 SiteMapPath控件
10.1.3 TreeView控件
10.2 站点登录
10.2.1 创建新用户
10.2.2 用户登录
10.3 本章小结
第11章 母版页
11.1 母版页概述
11.1.1 母版页的基础知识
11.1.2 母版页运行机制
11.2 创建母版页
11.3 创建内容页
11.4 本章小结
第12章 WebPart部件
12.1 WebPart基础知识
12.1.1 WebPart部件概述
12.1.2 W曲部件具体应用
12.1.3 Web部件基本控件
12.2 创建WebPart控件
12.2.1 WebPartManager控件
12.2.2 WebPart和WebPartZone控件简介
12.3 编辑WebPart控件
12.3.1 EditorZone控件简介
12.3.2 AppearanceEditorPart控件简介
12.3.3 BehaviorEditorPart控件简介
12.3.4 LayoutEditorPart控件简介
12.3.5 PropertyGridEditorPart控件简介
12.3.6 实现编辑WebPart控件
12.4 管理WebPart控件
12.4.1 CatalogZone控件简介
12.4.2 DeclarativeCatalogPart控件简介
12.4.3 PageCatalogPart控件简介
12.4.4 ImportCatalogPart控件简介
12.5 W曲部件个性化设置概述
12.5.1 个性化设置的工作方式
12.5.2 个性化设置和其他ASENET功能
12.6 本章小结
第13章 高级数据处理
13.1 文件处理
13.1.1 访问目录和文件
13.1.2 写入数据
13.1.3 上传文件
13.1.4 下载文件
13.2 XML操作
13.2.1 创建XML文件
13.2.2 写入XML文件
13.2.3 读取XML文件
13.3 其他数据处理
13.3.1 读取注册表信息
13.3.2 获取文件信息
13.4 本章小结
第14章 ASP.NET AJAX相关技术简介
14.1 Ajax概述
14.1.1 什么是Ajax
14.1.2 Ajax的工作
原
理
14.1.3 Ajax的优势与不足
14.2 ASP.NET AJAX
14.2.1 ASENET AJAX的特性
14.2.2 ASENET AJAX的安装
14.3 ASENET AJAX控件
14.3.1 ScriptManager控件
14.3.2 ScriptManagerProxy控件
14.3.3 UpdatePanel控件
14.3.4 UpdateProgress控件
14.3.5 Timer控件
14.4 本章小结
第15章 个人网站初学者工具包
15.1 个人网站初学者工具包概述及创建
15.2 系统通用类及配置文件
15.2.1 配置文件(Web.Config)
15.2.2 存储过程设计
15.2.3 系统通用类设计
15.3 母版页设计
15.4 系统实现
15.4.1 系统主页
15.4.2 用户注册
15.4.3 用户登录
15.4.4 浏览相册
15.4.5 下载照片
15.5 后台管理
15.5.1 创建相册
15.5.2 编辑和删除相册
15.5.3 添加照片
15.5.4 编辑和删除照片
15.6 本章小结
第16章 办公自动化系统
16.1 系统总体设计
16.1.1 系统功能描述
16.1.2 系统架构设计
16.2 系统模块设计
16.2.1 系统功能模块划分
16.2.2 功能模块设计
16.3 数据库设计
16.3.1 数据库表之间的关系
16.3.2 数据库表结构的详细设计
16.4 数据库操作类的设计
16.5 用户登录和注册
16.5.1 用户登录
16.5.2 用户注册
16.6 用户管理及角色管理
16.6.1 用户管理
16.6.2 角色管理
16.7 用户考勤及设置
16.7.1 用户考勤
16.7.2 考勤设置
16.8 站内短信
16.8.1 发送站内短信
16.8.2 收件箱
16.8.3 发件箱
16.9 请假信息管理
16.9.1 填写请假表单
16.9.2 查看审批进度
16.9.3 审批请假信息
16.10 我的通讯录
16.10.1 添加通信记录
16.10.2 查看和编辑通讯录
16.10.3 编辑和删除通讯录分类信息
16.11 部门及职位管理
16.11.1 添加部门
16.11.2 部门管理
16.11.3 添加职位
16.11.4 职位管理
16.12 我的文档管理
16.12.1 上传文档
16.12.2 文档下载
16.12.3 文档管理
16.13 公文流转
16.13.1 新建公文流转
16.13.2 查收公文文件
16.14 本章小结
15.3.2 使用create procedure创建存储过程 309
15.3.3 使用execute语句调用存储过程 310
15.3.4 使用create function创建函数 312
15.3.5 使用enterprise manager创建存储过程和函数 315
15.3.6 修改和删除存储过程和函数 317
15.4 oracle中的流控制语句 319
15.4.1 条件语句 319
15.4.2 循环语句 320
15.4.3 标号和goto 322
15.5 oracle数据库中的存储过程 322
15.5.1 存储过程的创建与调用 322
15.5.2 oracle中存储过程和函数的管理 324
第16章 sql触发器 325
16.1 触发器的基本概念 325
16.1.1 触发器简介 325
16.1.2 触发器执行环境 325
16.2 sql server中的触发器 326
16.2.1 sql server触发器的种类 326
16.2.2 使用create trigger命令创建触发器 326
16.2.3 insert触发器 328
16.2.4 delete触发器 329
16.2.5 update触发器 330
16.2.6 instead of触发器 332
16.2.7 嵌套触发器 334
16.2.8 递归触发器 336
16.2.9 sql server中触发器的管理 338
16.3 oracle数据库中触发器的操作 340
16.3.1 oracle触发器类型 340
16.3.2 触发器的创建 341
16.3.3 创建系统触发器 342
16.3.4 触发器的触发次序和触发谓词的使用 343
16.3.5 oracle触发器的管理 346
第17章 sql中游标的使用 349
17.1 sql游标的基本概念 349
17.1.1 游标的概念 349
17.1.2 游标的作用及其应用 350
17.2 sql游标的使用 351
17.2.1 使用declare cursor语句创建游标 351
17.2.2 使用open/close语句打开/关闭游标 352
17.2.3 使用fetch语句检索数据 352
17.2.4 基于游标的定位delete语句 354
17.2.5 基于游标的定位update语句 356
17.3 sql server中游标的扩展 357
17.3.1 transact_sql扩展declare cursor语法 357
17.3.2 @@cursor_rows全局变量确定游标的行数 359
17.3.3 @@fetch_status全局变量检测fetch操作的状态 360
17.3.4 游标的关闭与释放 361
17.3.5 游标变量 362
17.3.6 使用系统过程管理游标 363
17.4 oracle中游标的使用 365
17.4.1 显式游标与隐式游标 365
17.4.2 游标的
属性
366
17.4.3 %type、%rowtype定义记录变量 367
17.4.4 参数化游标 368
17.4.5 游标中的循环 369
17.4.6 游标变量 371
17.5 小结 372
第18章 事务控制与并发处理 373
18.1 sql事务控制 373
18.1.1 事务控制的引入 373
18.1.2 事务的特性 373
18.1.3 sql中与事务有关的语句 374
18.2 事务控制的具体实现 376
18.2.1 开始事务 376
18.2.2 set constraints语句设置约束的延期执行 377
18.2.3 终止事务 378
18.3 并发控制 380
18.3.1 并发操作的问题 381
18.3.2 事务隔离级别 382
18.3.3 set transaction设置事务
属性
383
18.4 sql server中的并发事务控制 384
18.4.1 锁的分类 384
18.4.2 sql server中表级锁的使用 385
18.4.3 设置隔离级别实现并发控制 387
18.4.4 死锁及其预防 391
18.5 oracle中的并发事务控制 393
18.5.1 通过加锁避免写数据丢失 393
18.5.2 设置只读事务(read only) 394
18.5.3 oracle中的隔离级别 395
第19章 嵌入式sql 397
19.1 sql的调用 397
19.1.1 直接调用sql 397
19.1.2 嵌入式sql 398
19.1.3 sql调用层接口(cli) 399
19.2 嵌入式sql的使用 401
19.2.1 创建嵌入式sql语句 401
19.2.2 sql通信区 402
19.2.3 主变量 404
19.2.4 嵌入式sql中使用游标 406
19.3 检索、操作sql数据 407
19.3.1 不需要游标的sql dml操作 407
19.3.2 使用游标的sql dml操作 410
19.3.3 动态sql技术 412
19.4 sql server中嵌入式sql的编译运行 413
19.4.1 嵌入式sql代码 413
19.4.2 预编译文件 415
19.4.3 设置visual c++ 6.0连接 417
19.4.4 编译运行程序 419
19.5 oracle中嵌入式sql的编译运行 420
19.5.1 嵌入式sql代码 420
19.5.2 预编译文件 421
19.5.3 设置visual c++ 6.0编译环境 423
19.5.4 编译运行程序 424
附录a sql保留字 427
附录b 常用的sql命令 431
附录c 关于运行环境的说明 435
c.1 sql server 2000 435
c.1.1 直接访问 435
c.1.2 从企业管理器访问 436
c.2 oracle系统 436
历史遗留问题,某些字段中有默认值,但允许为空,且记录中有为空的数据。
直接
更改
为
非空
的话会报错,解决办法:
1.alter table test1 with nocheck add constraint ck_n3 check (n3 is not null)
增加
一个
非空
的约束但加上with nocheck
2.批量
更改
为空的记录为默认值
转载于:https://www.cn...
非空
约束(NOT NULL)| 唯一约束(UNIQUE)
空字符串 ’ ’ 和 空值 NULL 有区别
向数据表中已存在
列
添加
非空
约束 则该
列
所有值中不能为空值,必须在插入值后才能 添加
非空
约束,如果想保留空值,可以用将空值NULL 修改为空字符串 ’ '后添加
非空
约束。
1.使用sql语句创建Test表 Testid 为主键自增 Test1 只添加了唯一约束
2.向表中添加数据
ERROR org.hibernate.util.JDBCExceptionReporter - 违反
列
[SEQUENCE_NUM]
非空
约束
报错
原
因是我们在 postgres 中为数据库的表字段设置为 "sequence_num" serial8
在 DMDB 中这个字段对应的是 "SEQUENCE_NUM" BIGINT NOT NULL
这种设置方式在 postgre...
设置表字段的
非空
约束(NOT NULL,NK)
当数据库表中的某个字段上的内容不希望设置为NULL时,可以使用NK约束进行设置。NK约束在创建数据库表时某些字段上加上“NOT NULL”约束条件,保证所有记录中的该字段都有值。如果在用户插入的记录中该字段为空值,那么数据库就会报错。
设置表中某字段的NK约束
非
常简单,查看帮助文档可以发现,在MySQL语句NOT NULL来实现,其语法如下:
CREATE TABLE tablename(
propName propType NOT NULL,...)