MYSQL 5.5从零开始学PDF电子书下载
- 电子书积分:14 积分如何计算积分?
- 作 者:刘增杰,张少军编著
- 出 版 社:北京:清华大学出版社
- 出版年份:2012
- ISBN:9787302274360
- 页数:444 页
第1章 初识MySQL 1
1.1数据库基础 1
1.1.1什么是数据库 1
1.1.2表 2
1.1.3数据类型 2
1.1.4主键 2
1.2数据库技术构成 2
1.2.1数据库系统 3
1.2.2 SQL语言 3
1.2.3数据库访问技术 4
1.3什么是MySQL 5
1.3.1客户机-服务器软件 5
1.3.2 MySQL版本 6
1.3.3 MySQL的优势 7
1.4 MySQL工具 7
1.4.1 mysql命令行实用程序 7
1.4.2 MySQL Workbench 8
1.5如何学习MySQL 8
第2章MySQL的安装与配置 10
2.1 Windows平台下安装与配置MySQL 5.5 10
2.1.1安装MySQL 5.5 10
2.1.2配置MySQL 5.5 16
2.2启动服务并登录MySQL数据库 23
2.2.1启动MySQL服务 23
2.2.2登录MySQL数据库 24
2.2.3配置Path变量 26
2.3更改MySQL的配置 28
2.3.1通过配置向导来更改配置 28
2.3.2手工更改配置 30
2.4 MySQL常用图形管理工具 32
2.5 Linux平台下安装与配置MySQL 5.5 33
2.5.1 Linux操作系统下的MySQL版本介绍 33
2.5.2安装和配置MySQL的RPM包 35
2.5.3安装和配置MySQL的源码包 38
2.6专家点拨 39
点拨1: MySQL必须注册为系统服务吗? 39
点拨2: MySQL安装失败? 40
2.7经典习题 40
第3章 数据库的基本操作 41
3.1创建数据库 41
3.2删除数据库 42
3.3数据库存储引擎 43
3.3.1 MySQL存储引擎简介 43
3.3.2 InnoDB存储引擎 44
3.3.3 MyISAM存储引擎 45
3.3.4 MEMORY存储引擎 45
3.3.5存储引擎的选择 46
3.4综合案例——数据库的创建和删除 47
3.5专家点拨 49
点拨:如何查看默认存储引擎? 49
3.6经典习题 49
第4章 数据表的基本操作 50
4.1.创建数据表 50
4.1.1创建表的语法形式 50
4.1.2使用主键约束 52
4.1.3使用外键约束 53
4.1.4使用非空约束 54
4.1.5使用唯一性约束 55
4.1.6使用默认约束 56
4.1.7设置表的属性值自动增加 56
4.2查看数据表结构 57
4.2.1查看表基本结构语句DESCRIBE 57
4.2.2查看表详细结构语句SHOW CREATE TABLE 58
4.3修改数据表 60
4.3.1修改表名 60
4.3.2修改字段的数据类型 61
4.3.3修改字段名 62
4.3.4添加字段 63
4.3.5删除字段 65
4.3.6修改字段的排列位置 66
4.3.7更改表的存储引擎 68
4.3.8删除表的外键约束 69
4.4删除数据表 70
4.4.1删除没有被关联的表 71
4.4.2删除被其他表关联的主表 71
4.5综合案例——数据表的基本操作 73
4.6专家点拨 82
点拨1:表删除操作须谨慎。 82
点拨2:每一个表中都要有一个主键吗? 82
点拨3:并不是每个表都可以任意选择存储引擎。 83
点拨4:带AUTO_ INCREMENT约束的字段值 是从1开始的吗? 83
4.7经典习题 83
第5章 数据类型和运算符 85
5.1 MySQL数据类型介绍 85
5.1.1整数类型 85
5.1.2浮点数类型和定点数类型 87
5.1.3日期与时间类型 89
5.1.4字符串类型 102
5.1.5二进制类型 107
5.2如何选择数据类型 110
5.3常见运算符介绍 112
5.3.1运算符概述 112
5.3.2算术运算符 112
5.3.3比较运算符 114
5.3.4逻辑运算符 122
5.3.5位运算符 125
5.3.6运算符的优先级 128
5.4综合案例——运算符的使用 129
5.5专家点拨 131
点拨1: MySQL中如何使用特殊字符? 131
点拨2: MySQL中可以存储文件吗? 131
点拨3: MySQL中如何执行区分大小写的字符串比较? 131
5.6经典习题 132
第6章MySQL函数 133
6.1 MySQL函数简介 133
6.2数学函数 133
6.2.1绝对值函数ABS(x)和返回圆周率的函数PI() 134
6.2.2平方根函数SQRT(x)和求余函数MOD(x,y) 134
6.2.3获取整数的函数CEIL(x)、 CEILING(x)和FLOOR(x) 135
6.2.4获取随机数的函数RAND()和RAND(x) 135
6.2.5四舍五入函数ROUND(x)、 ROUND(x,y)和TRUNCATE(x,y) 136
6.2.6符号函数SIGN(x) 137
6.2.7幂运算函数POW(x,y)、 POWER(x,y)和EXP(x) 138
6.2.8对数运算函数LOG(x)和LOG10(x) 138
6.2.9角度与弧度相互转换的函数RADIANS(x)和DEGREES(x) 139
6.2.10正弦函数SIN(x)和反正弦函数ASIN(x) 139
6.2.11余弦函数COS(x)和反余弦函数ACOS(x) 140
6.2.12正切函数、反正切函数和余切函数 140
6.3字符串函数 141
6.3.1计算字符串字符数的函数和字符串长度的函数 141
6.3.2合并字符串函数CONCAT(s1,s2,…)、CONCAT WS(x,s1,s2,…) 142
6.3.3替换字符串的函数INSERT(s1,x,len,s2) 143
6.3.4字母大小写转换函数 143
6.3.5获取指定长度的字符串的函数LEFT(s,n)和RIGHT(s,n) 144
6.3.6填充字符串的函数LPAD(s1,len,s2)和RPAD(s1,len,s2) 145
6.3.7删除空格的函数LTRIM(s)、RTRIM(s)和TRIM(s) 145
6.3.8 删除指定字符串的函数TRIM(s1 FROM s) 146
6.3.9重复生成字符串的函数REPEAT(s,n) 147
6.3.10空格函数SPACE(n)和替换函数REPLACE(s,s1,s2) 147
6.3.11比较字符串大小的函数STRCMP(s1,s2) 148
6.3.12获取子串的函数SUBSTRING(s,n,len)和MID(s,n,len) 148
6.3.13匹配子串开始位置的函数 149
6.3.14字符串逆序的函数REVERSE(s) 149
6.3.15返回指定位置的字符串的函数 150
6.3.16返回指定字符串位置的函数FIELD(s,s1,s2,…) 150
6.3.17返回子串位置的函数FINDSET(s1,s2) 151
6.3.18选取字符串的函数MAKINDSET(x,s1,s2,…) 151
6.4日期和时间函数 152
6.4.1获取当前日期的函数和获取当前时间的函数 152
6.4.2获取当前日期和时间的函数 152
6.4.3 UNIX时间戳函数 153
6.4.4返回UTC日期的函数和返回UTC时间的函数 154
6.4.5获取月份的函数MONTH(date)和MONTHNAME(date) 154
6.4.6获取星期的函数DAYNAME(d)、DAYOFWEEK(d)和WEEKDAY(d) 155
6.4.7 获取星期数的函数WEEK(d)和WEEKOFYEAR(d) 156
6.4.8获取天数的函数DAYOFYEAR(d)和DAYOFMONTH(d) 157
6.4.9获取年份、季度、小时、分钟和秒钟的函数 157
6.4.10获取日期的指定值的函数EXTRACT(type FROM date) 158
6.4.11时间和秒钟转换的函数 159
6.4.12计算日期和时间的函数 159
6.4.13将日期和时间格式化的函数 162
6.5条件判断函数 165
6.5.1 IF(expr,v1,v2)函数 165
6.5.2 IFNULL(v1,v2)函数 166
6.5.3 CASE函数 166
6.6系统信息函数 167
6.6.1获取MySQL版本号、连接数和数据库名的函数 167
6.6.2获取用户名的函数 169
6.6.3获取字符串的字符集和排序方式的函数 170
6.6.4获取最后一个自动生成的ID值的函数 170
6.7加密函数 172
6.7.1加密函数PASSWORD(str) 172
6.7.2加密函数MD5(str) 173
6.7.3加密函数ENCODE(str,pswd_ str) 173
6.7.4解密函数DECODE(crypt str,pswd_ str) 174
6.8其他函数 174
6.8.1格式化函数FORMAT(x,n) 174
6.8.2不同进制的数字进行转换的函数 174
6.8.3 IP地址与数字相互转换的函数 175
6.8.4加锁函数和解锁函数 176
6.8.5重复执行指定操作的函数 177
6.8.6改变字符集的函数 177
6.8.7改变数据类型的函数 178
6.9综合案例——MySQL函数的使用 178
6.10专家点拨 182
点拨1:如何从日期时间值中获取年、月、日等部分日期或时间值? 182
点拨2:如何改变默认的字符集? 182
6.11经典习题 183
第7章 查询数据 184
7.1基本查询语句 184
7.2单表查询 186
7.2.1查询所有字段 186
7.2.2查询指定字段 187
7.2.3查询指定记录 189
7.2.4带IN关键字的查询 190
7.2.5带BETWEEN AND的范围查询 191
7.2.6带LIKE的字符匹配查询 192
7.2.7查询空值 194
7.2.8带AND的多条件查询 195
7.2.9带OR的多条件查询 196
7.2.10查询结果不重复 197
7.2.11对查询结果排序 198
7.2.12分组查询 201
7.2.13使用LIMIT限制查询结果的数量 205
7.3使用集合函数查询 206
7.3.1 COUNT()函数 206
7.3.2 SUM()函数 208
7.3.3 AVG()函数 208
7.3.4 MAX()函数 209
7.3.5 MIN()函数 210
7.4连接查询 211
7.4.1内连接查询 211
7.4.2外连接查询 213
7.4.3复合条件连接查询 215
7.5子查询 216
7.5.1带ANY、SOME关键字的子查询 216
7.5.2带ALL关键字的子查询 216
7.5.3带EXISTS关键字的子查询 217
7.5.4带IN关键字的子查询 218
7.5.5带比较运算符的子查询 220
7.6合并查询结果 221
7.7为表和字段取别名 223
7.7.1为表取别名 223
7.7.2为字段取别名 225
7.8使用正则表达式查询 226
7.8.1查询以特定字符或字符串开头的记录 227
7.8.2查询以特定字符或字符串结尾的记录 227
7.8.3用符号“.”来替代字符串中的任意一个字符 228
7.8.4使用“*”和“+”来匹配多个字符 228
7.8.5匹配指定字符串 229
7.8.6匹配指定字符中的任意一个 230
7.8.7匹配指定字符以外的字符 231
7.8.8使用﹛n,﹜或者﹛n,m﹜来指定字符串连续出现的次数 231
7.9综合案例——数据表查询操作 232
7.10专家点拨 239
点拨1: DISTINCT可以应用于所有的列吗? 239
点拨2: ORDER BY可以和LIMIT混合使用吗? 239
点拨3:什么时候使用引号? 239
点拨4:在WHERE子句中必须使用圆括号吗? 239
点拨5:为什么使用通配符格式正确,却没有查找出符合条件的记录? 239
7.11经典习题 239
第8章 插入、更新与删除数据 241
8.1插入数据 241
8.1.1为表的所有字段插入数据 241
8.1.2为表的指定字段插入数据 243
8.1.3同时插入多条记录 244
8.1.4将查询结果插入到表中 246
8.2更新数据 247
8.3删除数据 249
8.4综合案例——记录的插入、更新和删除 251
8.5专家点拨 255
点拨1:插入记录时可以不指定字段名称吗? 255
点拨2:更新或者删除表时必须指定WHERE子句吗? 255
8.6经典习题 255
第9章 索引 257
9.1索引简介 257
9.1.1索引的含义和特点 257
9.1.2索引的分类 258
9.1.3索引的设计原则 258
9.2创建索引 259
9.2.1创建表的时候创建索引 259
9.2.2在已经存在的表上创建索引 264
9.3删除索引 270
9.4综合案例——创建索引 271
9.5专家点拨 274
使用它? 274
点拨2:尽量使用短索引。 275
9.6经典习题 275
第10章存储过程和函数 276
10.1创建存储过程和函数 276
10.1.1创建存储过程 276
10.1.2创建存储函数 279
10.1.3变量的使用 280
10.1.4定义条件和处理程序 281
10.1.5光标的使用 284
10.1.6流程控制的使用 285
10.2调用存储过程和函数 290
10.2.1调用存储过程 290
10.2.2调用存储函数 291
10.3查看存储过程和函数 292
10.3.1 SHOW STATUS语句查看存储过程和函数的状态 292
10.3.2 SHOW CREATE语句查看存储过程和函数的定义 293
10.3.3从information_ schema.Routines表中查看存储过程和函数的信息 293
10.4修改存储过程和函数 295
10.5删除存储过程和函数 297
10.6综合案例——创建存储过程和函数 297
10.7专家点拨 301
点拨1: MySQL存储过程和函数有什么区别? 301
点拨2:存储过程中的代码可以改变吗? 301
点拨3:存储过程中可以调用其他存储过程吗? 301
点拨4:存储过程的参数不要与数据表中的字段名相同。 301
点拨5:存储过程的参数可以使用中文吗? 301
10.8经典习题 302
第11章 视图 303
11.1视图概述 303
11.1.1视图的含义 303
11.1.2视图的作用 304
11.2创建视图 305
11.2.1创建视图的语法形式 305
11.2.2在单表上创建视图 305
11.2.3在多表上创建视图 307
11.3查看视图 308
11.3.1 DESCRIBE语句查看视图基本信息 308
11.3.2 SHOW TABLE STATUS语句查看视图基本信息 308
11.3.3 SHOW CREATE VIEW语句查看视图详细信息 310
11.3.4在views表中查看视图详细信息 310
11.4修改视图 312
11.4.1 CREATE OR REPLACE VIEW语句修改视图 312
11.4.2 ALTER语句修改视图 313
11.5更新视图 314
11.6删除视图 317
11.7综合案例——视图应用 318
11.8专家点拨 327
点拨1: MySQL中视图和表的区别以及联系是什么? 327
11.9经典习题 327
第12章MySQL函数 328
12.1创建触发器 328
12.1.1创建只有一个执行语句的触发器 328
12.1.2创建有多个执行语句的触发器 329
12.2查看触发器 332
12.2.1 SHOW TRIGGERS语句查看触发器信息 332
12.2.2在triggers表中查看触发器信息 334
12.3触发器的使用 335
12.4删除触发器 336
12.5综合案例——触发器使用 336
12.6专家点拨 339
点拨1:使用触发器时须特别注意。 339
点拨2:及时删除不再需要的触发器。 339
12.7经典习题 339
第13章MySQL用户管理 340
13.1权限表 340
13.1.1 user表 340
13.1.2 db表和host表 343
13.1.3 tables_priv表和columns_priv表 345
13.1.4 procs_priv表 346
13.2账户管理 346
13.2.1登录和退出MySQL服务器 346
13.2.2新建普通用户 348
13.2.3删除普通用户 352
13.2.4 root用户修改自己的密码 354
13.2.5 root用户修改普通用户密码 355
13.2.6普通用户修改密码 357
13.2.7 root用户密码丢失的解决办法 357
13.3权限管理 359
13.3.1 MySQL的各种权限 359
13.3.2授权 361
13.3.3收回权限 363
13.3.4查看权限 364
13.4访问控制 365
13.4.1连接核实阶段 365
13.4.2请求核实阶段 365
13.5综合案例——综合管理用户权限 366
13.6专家点拨 370
点拨1:已经将一个账户的信息从数库中完全删除,为什么该用户还能登录数据库? 370
点拨2:应该使用哪种方法创建用户? 370
13.7经典习题 371
第14章 数据备份与还原 372
14.1数据备份 372
14.1.1使用mysqldump命令备份 372
14.1.2直接复制整个数据库目录 379
14.1.3使用mysqlbotcopy工具快速备份 380
14.2数据还原 380
14.2.1使用mysql命令还原 380
14.2.2直接复制到数据库目录 381
14.2.3 mysqlhotcopy快速恢复 381
14.3数据库迁移 382
14.3.1相同版本的MySQL数据库之间的迁移 382
14.3.2不同版本的MySQL数据库之间的迁移 382
14.3.3不同数据库之间的迁移 383
14.4表的导出和导入 383
14.4.1用SELECT…INTO OUTFILE导出文本文件 383
14.4.2用mysqldump命令导出文本文件 387
14.4.3用mysql命令导出文本文件 389
14.4.4使用LOAD DATA INFILE方式导入文本文件 393
14.4.5使用mysqlimport命令导入文本文件 395
14.5综合案例——数据的备份与恢复 397
14.6专家点拨 402
点拨1: mysqldump备份的文件只能在MySQL中使用吗? 402
点拨2:如何选择备份工具? 402
点拨3:使用mysqldump备份整个数据库成功,把表和数据库都删除了,但使用备份文件却不能恢复数据库? 402
14.7经典习题 403
第15章MySQL日志 404
15.1日志简介 404
15.2二进制日志 405
15.2.1启动和设置二进制日志 405
15.2.2查看二进制日志 406
15.2.3删除二进制日志 408
15.2.4使用二进制日志还原数据库 410
15.2.5暂时停止二进制日志功能 411
15.3错误日志 411
15.3.1启动和设置错误日志 411
15.3.2查看错误日志 412
15.3.3删除错误日志 413
15.4通用查询日志 413
15.4.1启动和设置通用查询日志 413
15.4.2查看通用查询日志 413
15.4.3删除通用查询日志 414
15.5慢查询日志 415
15.5.1启动和设置慢查询日志 415
15.5.2查看慢查询日志 415
15.5.3删除慢查询日志 416
15.6综合案例——MySQL日志的综合管理 416
15.7专家点拨 422
点拨1:平时应该打开哪些日志? 422
点拨2:如何使用二进制日志? 422
点拨3:如何使用慢查询日志? 423
15.8经典习题 423
第16章 性能优化 424
16.1优化简介 424
16.2优化查询 425
16.2.1分析查询语句 425
16.2.2索引对查询速度的影响 428
16.2.3使用索引查询 429
16.2.4优化子查询 432
16.3优化数据库结构 432
16.3.1将字段很多的表分解成多个表 432
16.3.2增加中间表 433
16.3.3增加冗余字段 435
16.3.4优化插入记录的速度 435
16.3.5分析表、检查表和优化表 437
16.4优化MySQL服务器 439
16.4.1优化服务器硬件 439
16.4.2优化MySQL的参数 439
16.5综合案例——全面优化MySQL服务器 441
16.6专家点拨 443
点拨1:是不是索引建立得越多越好? 443
点拨2:为什么查询语句中的索引没有起作用? 443
点拨3:如何使用查询缓冲区? 443
16.7经典习题 443
- 《罗京 现在开始播音》刘卓著 2019
- 《我的第一套编程启蒙绘本 看事件 开始了》编程猫教研团队编绘 2019
- 《从零开始学温敷》蔡仁妤,艾利著 2019
- 《从零开始学水墨画 水墨画家的调墨、运笔秘诀》殷雨涵译;(日)日本株式会社日贸出版社 2018
- 《三十岁 一切刚刚开始》李尚龙著 2020
- 《Re:从零开始的异世界生活》陈诗泳,欧阳佳子责编;温玥译者;(日)大塚真一郎绘画;(日)长月达平 2020
- 《美好,从美开始》辰薇著 2019
- 《从0到亿 创业从失败开始》(中国)高佳奇,薛丰 2019
- 《结尾与开始》范小青 2020
- 《从零开始成人钢琴教程》灌木文化编著 2019
- 《市政工程基础》杨岚编著 2009
- 《家畜百宝 猪、牛、羊、鸡的综合利用》山西省商业厅组织技术处编著 1959
- 《《道德经》200句》崇贤书院编著 2018
- 《高级英语阅读与听说教程》刘秀梅编著 2019
- 《计算机网络与通信基础》谢雨飞,田启川编著 2019
- 《看图自学吉他弹唱教程》陈飞编著 2019
- 《法语词汇认知联想记忆法》刘莲编著 2020
- 《培智学校义务教育实验教科书教师教学用书 生活适应 二年级 上》人民教育出版社,课程教材研究所,特殊教育课程教材研究中心编著 2019
- 《国家社科基金项目申报规范 技巧与案例 第3版 2020》文传浩,夏宇编著 2019
- 《流体力学》张扬军,彭杰,诸葛伟林编著 2019
- 《大学计算机实验指导及习题解答》曹成志,宋长龙 2019
- 《指向核心素养 北京十一学校名师教学设计 英语 七年级 上 配人教版》周志英总主编 2019
- 《大学生心理健康与人生发展》王琳责任编辑;(中国)肖宇 2019
- 《大学英语四级考试全真试题 标准模拟 四级》汪开虎主编 2012
- 《大学英语教学的跨文化交际视角研究与创新发展》许丽云,刘枫,尚利明著 2020
- 《北京生态环境保护》《北京环境保护丛书》编委会编著 2018
- 《复旦大学新闻学院教授学术丛书 新闻实务随想录》刘海贵 2019
- 《大学英语综合教程 1》王佃春,骆敏主编 2015
- 《大学物理简明教程 下 第2版》施卫主编 2020
- 《指向核心素养 北京十一学校名师教学设计 英语 九年级 上 配人教版》周志英总主编 2019