编辑推荐
从根本上改变数据库学习方法,趣味、互动起来……
《大话数据库》不是一《大话数据库》,而是一套通过研习数据库体系教会你快乐学习的方法
程序猿,给哥乐一个
§笑着掌握数据库,躺床上也能看
§传统书本和课堂学习方法的彻底颠覆
§嬉笑怒骂中为你立体呈现一套全新的学习和思考方法
§每一个知识点的讲解均通过提出问题再解答问题,再引发问题再解答,环环相扣
§《大话数据库》中有“错”,《大话数据库》故意在核心知识的讲解过程中设置陷阱,让你记忆深刻
§按天给出学习计划,让学习不再没有秩序,没有管理
§《大话数据库》所涉及的专业术语按照初学者的理解能力设置,从口水趋于专业
《大话数据库》相关代码请访问作者微博进行下载。
内容简介
《大话数据库》是一本独特的数据库入门书,以有效的教学思路讲解数据库的每一个知识点,完全以初学者的思维方式提出疑问再深入答疑。这也许不是一本传统的教科书,但绝对是自学数据库的优选书籍。《大话数据库》采用【老田、小天】二人对话的形式讲解,其中不乏诙谐幽默的问题和解答,避免对知识点生搬硬套。
通过学习《大话数据库》,你能够在嬉笑怒骂的环境中轻松掌握数据存储原理、数据库设计技巧以及大量数据库编程的实战经验,更重要的是能够掌握一种优秀的学习方法、解决问题的思路和思考的方式。这些经验和技巧得益于我和邹老师两人加起来近25年的项目开发和教育培训经历。
《大话数据库》第1部分对于数据库的创建、备份、配置、安全等做详细介绍,通过这部分学习,可以掌握关系数据库的基础,以及对数据库的日常维护操作;《大话数据库》第二部分对于分析项目需求,创建表,然后使用T-SQL语句和存储过程对表中数据做各种操作等做详细讲解,通过这一部分的学习,可以掌握对数据库的基本应用,熟练使用T-SQL语言建库、建表、T-SQL查询、高级检索、存储过程、性能优化技巧等;
读者对象:希望靠一《大话数据库》从头到尾自学的零基础学员;培训讲师的备课资料,因为这《大话数据库》总结了我们培训过程所遇到的问题和学生会问的问题、有疑虑的地方;自觉性不高的学员。
作者简介
田洪川,2010年获得中电科三十集团下属国信安投资,创办学云网
2007年进入成都国信安,完成本科授课、社招培训班授课、企业培训授课、实训授课千余次
2002年进入绵阳新潮集团,从程序员一直干到技术总监(期间换过公司)
1999年开始守网吧,自学编程
1996年初中毕业:卖馒头、端盘子洗碗、小混混、搞传销。
邹茂杨,从业13年,一直从事数据库开发与教学研究。任职于成都信息工程学院之前,曾经在成都微软技术中心等多家公司工作。主持或参与过国家科研项目2项,省级科研项目1项,市区级科研项目3项,校级科研项目1项,参与商业项目和产品的研发推广数十项。研究教学规律、负责教改工作2项。2011年作为访问学者在美国TROY大学访问半年。
精彩书评
如何令学习者事半功倍地学习数据库?如何在学习过程中能得到实际工程经验?作者得益于多年领导软件团队和教学的经验,针对以上问题,轻松帮你完成数据库的修炼,希望读者通过努力,能轻松运用SQLServer,并融会贯通地掌握其他数据库软件。
——成都信息工程学院计算机学院院长何嘉
目录
第一部分关系型数据库基础
第1章概述
1.1什么是数据库
1.2为什么要使用数据库
1.3数据库的基本概念
1.4数据库的历史
1.5关系数据库
1.6为什么选择SQLServer
1.7SQL语言
1.8SQL标准
1.910分钟探索IDE
1.9.1启动和登录SQLServerManagementStudio
1.9.2修改登录验证模式
1.9.3注册数据库服务器
1.9.4修改数据库服务器属性
1.9.5启动和停止服务器
1.9.6创建查询
1.9.7使用指定数据库
本章小结
问题
第2章创建和维护数据库
2.1系统数据库
2.1.1修改系统数据
2.1.2查看系统数据
2.2创建数据库
2.2.1使用Transact-SQL语句创建数据库
2.2.2查看数据库文件属性
2.3数据库文件和文件组
2.3.1数据库文件的类型
2.3.2文件组
2.3.3删除数据库文件
2.3.4管理文件组
2.3.5文件组的填充策略
2.3.6优化数据库的策略
2.3.7文件状态
2.4数据库状态和选项
2.5查看数据库
2.6删除数据库
2.7修改数据库
2.7.1修改数据库名称
2.7.2扩展数据库
2.7.3收缩数据库
2.8数据库快照
2.8.1数据库快照的应用
2.8.2数据库快照的原理
2.8.3管理数据库快照
2.9分离和附加数据库
2.9.1分离数据库
2.9.2附加数据库
2.10移动数据库文件
2.11移动和复制数据库
2.12备份和还原数据库
2.12.1备份数据库
2.12.2还原数据库
本章小结
问题
第二部分设计、实现和使用数据库
第3章Transact-SQL语言
3.1SQL与Transact-SQL语言概述方式
3.2Transact-SQL语言的执行方式与调试
3.2.1调试代码
3.2.2调试Transact-SQL代码
3.3数据定义语言(DDL)
3.4数据操纵语言(DML)
3.5数据库控制语言(DCL)
3.6附加的语言元素
3.6.1标识符和命名规范
3.6.2局部变量
3.6.3全局变量
3.6.4运算符
3.6.5表达式
3.6.6注释
3.7数据类型
3.7.1字符数据类型
3.7.2数字数据类型
3.7.3日期和时间数据类型
3.7.4二进制数据类型
3.7.5其他数据类型
3.7.6用户自定义数据类型
3.8内置函数
3.8.1概述
3.8.2如何查看SQLServer帮助中的语法
3.8.3如何使用函数
3.8.4函数类型
本章小结
问题
第4章创建与维护表
4.1概述
4.2设计表时应该考虑的因素
4.3E-R模型
4.3.1概述
4.3.2属性和主键
4.3.3外键
4.3.4联系
4.3.5关系规范化
4.4利用PowerDesigner设计数据库
4.4.1PowerDesigner说明和模型设置
4.4.2创建概念数据模型实体
4.4.3创建概念数据模型关系
4.4.4从概念数据模型到生成物理数据模型
4.4.5创建物理数据模型
4.4.6更新已有的物理数据模型
4.4.7生成数据库脚本
4.5表的基本特点和类型
4.5.1表的特点
4.5.2表的类型
4.6创建和修改表
4.6.1创建普通表
4.6.2创建临时表
4.6.3创建分区表
4.6.4增加和删除列
4.6.5修改列
4.6.6创建和修改列标识符
4.6.7查看表信息
4.6.8删除表
4.7约束
4.7.1主键约束
4.7.2外键约束
4.7.3NOTNULL约束
4.7.4DEFAULT约束
4.7.5CHECK约束
4.7.6UNIQUE约束
4.7.7禁止与删除约束
本章小结
问题
第5章操作表中的数据
5.1准备工作
5.2插入语句
5.2.1简单的插入语句
5.2.2批量插入语句
5.3检索数据
5.3.1选择数据列
5.3.2使用文字串
5.3.3改变列标题
5.3.4数据运算
5.3.5使用ALL与DISTINCT关键字
5.3.6使用TOP关键字
5.3.7排序
5.4WHERE子句
5.4.1简单条件查询
5.4.2模糊查询
5.4.3复合条件查询
5.4.4使用IN子句
5.4.5使用BETWEEN子句
5.4.6空值与非空值
5.5修改语句
5.6删除语句
本章小结
问题
第6章高级检索技术
6.1聚合技术
6.1.1SELECT子句中的聚合
6.1.2COMPUTE子句中的聚合
6.2分组数据
6.2.1普通分组
6.2.2使用HAVING子句
6.2.3使用ROLLUP和CUBE
6.3联合查询
6.4连接查询
6.4.1内连接
6.4.2外连接
6.4.3交叉连接
6.4.4自连接
6.5子查询技术
6.5.1使用IN和NOTIN的子查询
6.5.2ANY、ALL等比较运算符的使用
6.5.3使用EXISTS关键字
6.5.4子查询的规则
本章小结
问题
阶段作业
第7章索引
7.1概述
7.1.1表组织
7.1.2堆
7.1.3B树
7.2索引的优缺点
7.3索引的类型
7.3.1聚集索引
7.3.2非聚集索引
7.4索引的属性
7.4.1唯一性索引
7.4.2复合索引
7.5创建索引
7.5.1使用向导创建索引
7.5.2使用CREATEINDEX语句创建索引
7.5.3索引的选项
7.6维护索引
7.6.1查看索引碎片
7.6.2重建索引
7.6.3统计信息
7.6.4查看索引
7.6.5修改索引
7.6.6删除索引
本章小结
问题
第8章视图
8.1概述
8.1.1为什么需要视图
8.1.2什么是视图
8.2视图的优缺点
8.3创建视图
8.3.1创建视图的基本原则
8.3.2使用SQLServerManagementStudio创建视图
8.3.3使用Transact-SQL命令创建视图
8.4使用视图
8.5查看视图
8.6加密视图
8.7修改视图
8.8删除视图
8.9重命名视图
8.10通过视图更新数据
8.10.1通过视图插入数据
8.10.2使用UPDATE修改
数据
本章小结
问题
第9章SQL编程及高级应用
9.1概述
9.2流程控制语句
9.2.1IF…ELSE…语句
9.2.2BEGIN…END语句
9.2.3GOTO语句
9.2.4WHILEBREAK和
CONTINUE语句
9.2.5CASE语句
9.2.6WAITFOR语句
9.3游标
9.3.1游标的类型
9.3.2选择游标类型的原则
9.3.3游标的生命周期
9.3.4实现Transact-SQL游标
9.4用户自定义函数
9.4.1创建用户自定义函数的思考
9.4.2用户自定义函数的分类
9.4.3创建及使用用户自定义函数
9.4.4维护用户自定义函数
本章小结
问题
第10章存储过程
10.1概述
10.2存储过程的优点
10.3存储过程的分类
10.3.1系统存储过程
10.3.2API存储过程
10.3.3用户自定义存储过程
10.4创建存储过程
10.4.1创建存储过程应考虑的因素
10.4.2创建存储过程的语法
10.4.3创建不带参数的存储过程
10.4.4创建带参数的存储过程
10.4.5创建返回值的存储过程
10.4.6创建带有OUTPUT参数的存储过程
10.4.7使用SQLServerManagementStudio创建存储过程
10.5维护存储过程
10.5.1查看存储过程信息
10.5.2加密存储过程
10.5.3修改、删除存储过程
10.6存储过程进阶知识
10.6.1存储过程的执行过程
10.6.2存储过程命名
本章小结
问题
第11章触发器
11.1概述
11.1.1触发器与约束规则
11.1.2触发器的优缺点
11.2触发器的分类
11.2.1DDL触发器
11.2.2登录触发器
11.2.3DML触发器
11.3创建触发器
11.3.1创建DDL触发器
11.3.2可触发DDL触发器的事件
11.3.3维护触发器
11.4创建DML触发器
11.4.1创建DML触发器的语法
11.4.2创建DML触发器需要考虑的因素
11.4.3创建DML触发器
11.5DML触发器嵌套
本章小结
问题
第12章事务和锁
12.1事务概述
12.1.1概念
12.1.2属性
12.2创建事务
12.2.1使用事务考虑的因素
12.2.2事务的声明和提交
12.2.3事务的回滚
12.2.4查看当前执行中的事务
12.2.5事务的嵌套
12.3事务的工作原理
12.4锁定和行版本控制
12.5锁定的分类
12.6锁的自动优化
12.6.1升级阈值
12.7死锁
12.7.1死锁的概念
12.7.2产生死锁的主要原因和必要条件
12.7.3减少和预防死锁
12.7.4检测死锁
12.7.5设置锁的优先级
本章小结
问题
第13章全文索引
13.1概述
13.2全文索引概念
13.2.1全文索引与查询
13.2.2全文索引引擎
13.3全文目录
13.3.1创建全文目录
13.3.2修改全文目录
13.3.3查看全文目录
13.4管理全文索引
13.4.1创建全文索引需要考虑的因素
13.4.2创建全文索引
13.4.3查看全文索引
13.4.4修改和删除全文索引
13.4.5填充全文索引
13.5使用全文索引
13.5.1使用全文谓词CONTAINS和FREETEXT查询概述
13.5.2使用CONTAINS谓词的简单搜索
13.5.3使用CONTAINS谓词的派生词搜索
13.5.4使用CONTAINS谓词的前缀词搜索
13.5.5使用CONTAINS谓词的邻近词搜索
13.5.6使用CONTAINS谓词的加权词搜索
13.5.7使用FREETEXT查询
13.5.8使用CONTAINSTABLE函数搜索
13.5.9使用FREETEXTTABLE函数搜索
13.6检索二进制列
本章小结
问题
结束语
精彩书摘
只有枯燥的教材,没有枯燥的编程
——天轰穿
“编程很枯燥!”是这句话是我要写一套编程类入门书籍的主要诱因。
而数据库则是作为进入编程世界的一个重要“关卡”,为什么这么说,首先,因为所有编程语言到了实际应用阶段都无法避免地与数据库打交道;其次,数据库是体现编程艺术的一个重要平台;另外,学好数据库,会使你以后学习其他语言的时候事半功倍。
而能否让你学得轻松、学得扎实就成为了一个至关重要的条件,这也是《大话数据库》的宗旨。
通过学习《大话数据库》,你能够在嬉笑怒骂的环境中轻松掌握数据存储原理、数据库设计技巧以及大量数据库编程的实战经验,更重要的是能够掌握一种优秀的学习方法、解决问题的思路和思考的方式。这些经验和技巧得益于我和邹老师两人加起来近25年的项目开发和教育培训经历。
《大话数据库》特色
这不是一本以传统顺序堆砌而成的书
1.《大话数据库》以最有效的教学思路讲解数据库的每一个知识点,完全以初学者的思维方式提出疑问再深入答疑。这也许不是一本传统的教科书,但绝对是自学数据库的首选书籍。
2.《大话数据库》并非严格将数据库知识分类整理讲解,而是按照初学者的思维习惯,将每一个知识点放在最恰当的位置,所以单看目录,会感觉知识的排列不像同类书那样“井井有条”。
3.《大话数据库》采用【老田、小天】二人对话的形式讲解,其中不乏诙谐幽默的问题和解答,避免对知识点生搬硬套。
4.《大话数据库》总是提出问题再来解释,通过解释的过程来讲解新的知识。这样极大地避免了知识点的生硬出现,转而将学习的过程变成了解决问题的过程,同时也复习的相关其他知识点。
5.《大话数据库》中出现的专业术语随着知识的深入而出现,故尽量从头开始阅读。
6.每章最后的“每日一练”中提出的问题常常有错误的问法夹杂其中,在这种题下面会紧跟着一道题,要求你将前一个题修改正确,极大避免了填鸭式教学,让你想不思考都不行。
7.《大话数据库》配备对应的视频教程,去百度谷歌“天轰穿趣味编程”就可以找到,或者去学云网搜“天轰穿”。
这是一本教会你学习方法的书
·学习方式是按照初学者的理解方式,看实例→提出问题→解答问题;
·通过对小天提出问题的解答来引导学员的思考和学习;
·学习时间按“天”计算;
·每章均有本章学习线路提示。
读者定位
·希望靠一《大话数据库》从头到尾自学的零基础学员;
·培训讲师的备课资料,因为这《大话数据库》总结了我们培训过程所遇到的问题和学生会问的问题、有疑虑的地方;
·自觉性不高的学员。
关于《大话数据库》的创作起点与过程
我在2006年制作了《天轰穿VS2005入门.Net2.0系列视频教程》,其“非主流”的讲授风格受到大部分兄弟姐妹的肯定。截至目前,该视频在6年时间,已知的浏览量超过1000万次。
从2007年开始做培训,直到现在,我带过完全零基础的社招培训班、去高校上过专业课、去企业做过专题培训,也做了大量的以“天轰穿”命名的视频教程。在积累了大量实体培训和与网络学员交互培训的经验后,我再次萌生了要写一套专门给自学的兄弟姐妹的教材,于是和成都信息工程学院邹茂杨老师联合编写了这《大话数据库》。
我不想太多去谈这《大话数据库》怎么样,但当你翻开《大话数据库》,那些无伤大雅的小幽默和深入浅出的实例引导会让您觉得选择这本“由初中生+高校教授的诡异组合”撰写的教材来学习数据库是对的。因为《大话数据库》不仅是我个人自学技巧和教学经验的深度体现,还是邹茂杨老师十余年教学经验的总结和汇聚。
近几年,常常有去一些企业和高校做讲座的机会,总有学员问:“川哥,我英语不好,能学好编程吗?我数学不好,能学好编程吗”。我的回答永远都是:“只要你努力,只要你坚持,就肯定能学好编程”。
·因为你底子再差,不会比我这个初中生更差;
·因为你英语再差,不会比我这个初中英语最高成绩就没不及格过的家伙差;
·因为你数学再差,不会比我这个因为不会计算圆柱体面积而被老师骂的刺头更差。
我从1999年第一次接触计算机,从连鼠标都不会玩的土包子到做出自己的网站用了不到一年(一个纯静态页面组成的图片网站),再从只会做HTML页面到做出第一个ASP的留言本用了一年,之后多次闭关学习新技术(最狠的一次为了管住自己的双脚,把眉毛剃掉)。
回想写这《大话数据库》的过程,眼眶湿了。虽然今天已经是学云网CEO,但作为一个1996年初中毕业就混社会的农村小伙子而言,这一路走来,有欢笑也有泪水,但更多是汗水。由此得出一个结论,要学好编程,不在于你智商多高,而取决于你能否坚持,取决于你是否勤奋。编程不是看书、看视频就能学会了,而是靠大量的练习——不断举一反三的练习。
出社会后这十几年,我养成了一个习惯,无论做什么事都会全力以赴(如果做不到,就人为斩断自己的一切退路),写《大话数据库》的时候也一样,我辞去公司的讲师工作、推掉所有找上门的外包项目和一些高校的课程安排,期间仅靠老婆的工资和我去企业做培训的收入来糊口,过程中也有两周写不完一章的情况,由于想不出更好的办法来将深奥的知识讲得足够有趣,很多时候觉得自己很笨、很失败,很想放弃。但在老婆和朋友们的鼓励下,我坚持了下来。在此,感谢我亲爱的老婆,感谢这一路走来所有支持我、理解我、鼓励我的兄弟姐妹们!谢谢你们!!!
……
前言/序言
前言
只有枯燥的教材,没有枯燥的编程
——天轰穿
“编程很枯燥!”是这句话是我要写一套编程类入门书籍的主要诱因。
而数据库则是作为进入编程世界的一个重要“关卡”,为什么这么说,首先,因为所有编程语言到了实际应用阶段都无法避免地与数据库打交道;其次,数据库是体现编程艺术的一个重要平台;另外,学好数据库,会使你以后学习其他语言的时候事半功倍。
而能否让你学得轻松、学得扎实就成为了一个至关重要的条件,这也是《大话数据库》的宗旨。
通过学习《大话数据库》,你能够在嬉笑怒骂的环境中轻松掌握数据存储原理、数据库设计技巧以及大量数据库编程的实战经验,更重要的是能够掌握一种优秀的学习方法、解决问题的思路和思考的方式。这些经验和技巧得益于我和邹老师两人加起来近25年的项目开发和教育培训经历。
《大话数据库》特色
这不是一本以传统顺序堆砌而成的书
1.《大话数据库》以最有效的教学思路讲解数据库的每一个知识点,完全以初学者的思维方式提出疑问再深入答疑。这也许不是一本传统的教科书,但绝对是自学数据库的首选书籍。
2.《大话数据库》并非严格将数据库知识分类整理讲解,而是按照初学者的思维习惯,将每一个知识点放在最恰当的位置,所以单看目录,会感觉知识的排列不像同类书那样“井井有条”。
3.《大话数据库》采用【老田、小天】二人对话的形式讲解,其中不乏诙谐幽默的问题和解答,避免对知识点生搬硬套。
4.《大话数据库》总是提出问题再来解释,通过解释的过程来讲解新的知识。这样极大地避免了知识点的生硬出现,转而将学习的过程变成了解决问题的过程,同时也复习的相关其他知识点。
5.《大话数据库》中出现的专业术语随着知识的深入而出现,故尽量从头开始阅读。
6.每章最后的“每日一练”中提出的问题常常有错误的问法夹杂其中,在这种题下面会紧跟着一道题,要求你将前一个题修改正确,极大避免了填鸭式教学,让你想不思考都不行。
7.《大话数据库》配备对应的视频教程,去百度谷歌“天轰穿趣味编程”就可以找到,或者去学云网搜“天轰穿”。
这是一本教会你学习方法的书
·学习方式是按照初学者的理解方式,看实例→提出问题→解答问题;
·通过对小天提出问题的解答来引导学员的思考和学习;
·学习时间按“天”计算;
·每章均有本章学习线路提示。
读者定位
·希望靠一《大话数据库》从头到尾自学的零基础学员;
·培训讲师的备课资料,因为这《大话数据库》总结了我们培训过程所遇到的问题和学生会问的问题、有疑虑的地方;
·自觉性不高的学员。
关于《大话数据库》的创作起点与过程
我在2006年制作了《天轰穿VS2005入门.Net2.0系列视频教程》,其“非主流”的讲授风格受到大部分兄弟姐妹的肯定。截至目前,该视频在6年时间,已知的浏览量超过1000万次。
从2007年开始做培训,直到现在,我带过完全零基础的社招培训班、去高校上过专业课、去企业做过专题培训,也做了大量的以“天轰穿”命名的视频教程。在积累了大量实体培训和与网络学员交互培训的经验后,我再次萌生了要写一套专门给自学的兄弟姐妹的教材,于是和成都信息工程学院邹茂杨老师联合编写了这《大话数据库》。
我不想太多去谈这《大话数据库》怎么样,但当你翻开《大话数据库》,那些无伤大雅的小幽默和深入浅出的实例引导会让您觉得选择这本“由初中生+高校教授的诡异组合”撰写的教材来学习数据库是对的。因为《大话数据库》不仅是我个人自学技巧和教学经验的深度体现,还是邹茂杨老师十余年教学经验的总结和汇聚。
近几年,常常有去一些企业和高校做讲座的机会,总有学员问:“川哥,我英语不好,能学好编程吗?我数学不好,能学好编程吗”。我的回答永远都是:“只要你努力,只要你坚持,就肯定能学好编程”。
·因为你底子再差,不会比我这个初中生更差;
·因为你英语再差,不会比我这个初中英语最高成绩就没不及格过的家伙差;
·因为你数学再差,不会比我这个因为不会计算圆柱体面积而被老师骂的刺头更差。
我从1999年第一次接触计算机,从连鼠标都不会玩的土包子到做出自己的网站用了不到一年(一个纯静态页面组成的图片网站),再从只会做HTML页面到做出第一个ASP的留言本用了一年,之后多次闭关学习新技术(最狠的一次为了管住自己的双脚,把眉毛剃掉)。
回想写这《大话数据库》的过程,眼眶湿了。虽然今天已经是学云网CEO,但作为一个1996年初中毕业就混社会的农村小伙子而言,这一路走来,有欢笑也有泪水,但更多是汗水。由此得出一个结论,要学好编程,不在于你智商多高,而取决于你能否坚持,取决于你是否勤奋。编程不是看书、看视频就能学会了,而是靠大量的练习——不断举一反三的练习。
出社会后这十几年,我养成了一个习惯,无论做什么事都会全力以赴(如果做不到,就人为斩断自己的一切退路),写《大话数据库》的时候也一样,我辞去公司的讲师工作、推掉所有找上门的外包项目和一些高校的课程安排,期间仅靠老婆的工资和我去企业做培训的收入来糊口,过程中也有两周写不完一章的情况,由于想不出更好的办法来将深奥的知识讲得足够有趣,很多时候觉得自己很笨、很失败,很想放弃。但在老婆和朋友们的鼓励下,我坚持了下来。在此,感谢我亲爱的老婆,感谢这一路走来所有支持我、理解我、鼓励我的兄弟姐妹们!谢谢你们!!!