第1篇 MariaDB数据库基础 2
第1章 数据库概述 2
1.1 MariaDBs基础 2
1.1.1 常见的数据库系统 2
1.1.2 为什么要使用MariaDB 3
1.1.3 MariaDB版本和获取 4
1.2 如何学习数据库 5
1.2.1 多上机实践 5
1.2.2 多编写SQL语句 7
1.2.3 讨论和交流 7
1.3 常见问题及解答 8
1.4 小结 8
1.5 本章习题 8
第2章 在Windows平台下安装与配置MariaDB 9
2.1 安装与配置MariaDB 9
2.1.1 安装MariaDB 9
2.1.2 启动MariaDB服务 12
2.1.3 登录MariaDB数据库 13
2.1.4 配置Path变量 16
2.2 更改MariaDB的配置 17
2.3 MariaDB常用图形管理工具 18
2.4 使用免安装的MariaDB 19
2.5 上机实践 21
2.6 常见问题及解答 22
2.7 小结 22
2.8 本章习题 22
第3章 在Linux平台下安装与配置MariaDB 23
3.1 Linux操作系统下的MariaDB版本介绍 23
3.2 安装和配置MariaDB的RPM包 24
3.3 安装和配置MariaDB的DEB包 29
3.4 安装和配置MariaDB的二进制包 32
3.5 安装和配置MariaDB的源码包 36
3.6 上机实践 41
3.7 常见问题及解答 42
3.8 小结 42
3.9 本章习题 42
第2篇 MariaDB数据库基础维护 44
第4章 MariaDB数据类型 44
4.1 MariaDB数据类型介绍 44
4.1.1 整数类型 44
4.1.2 浮点数类型和定点数类型 46
4.1.3 日期与时间类型 47
4.1.4 字符串类型 55
4.1.5 二进制类型 57
4.2 如何选择数据类型 59
4.3 常见问题及解答 61
4.4 小结 61
4.5 本章习题 61
第5章 操作数据库 62
5.1 创建数据库 62
5.2 删除数据库 63
5.3 数据库存储引擎 64
5.3.1 MariaDB存储引擎简介 65
5.3.2 IunoDB存储引擎 67
5.3.3 MyISAM存储引擎 67
5.3.4 MEMORY存储引擎 68
5.3.5 存储引擎的选择 68
5.4 本章实例 69
5.5 上机实践 71
5.6 常见问题及解答 72
5.7 小结 72
5.8 本章习题 73
第6章 创建、修改和删除表 74
6.1 创建表 74
6.1.1 创建表的语法形式 74
6.1.2 设置表的主键 75
6.1.3 设置表的外键 76
6.1.4 设置表的非空约束 77
6.1.5 设置表的唯一性约束 77
6.1.6 设置表的属性值自动增加 78
6.1.7 设置表的属性的默认值 78
6.2 查看表结构 79
6.2.1 查看表基本结构语句DESCRIBE 79
6.2.2 查看表详细结构语句SHOW CREATE TABLE 80
6.3 修改表 80
6.3.1 修改表名 81
6.3.2 修改字段的数据类型 81
6.3.3 修改字段名 82
6.3.4 增加字段 84
6.3.5 删除字段 88
6.3.6 修改字段的排列位置 89
6.3.7 更改表的存储引擎 91
6.3.8 删除表的外键约束 92
6.4 删除表 94
6.4.1 删除没有被关联的普通表 94
6.4.2 删除被其他表关联的父表 95
6.5 本章实例 96
6.6 上机实践 102
6.7 常见问题及解答 105
6.8 小结 106
6.9 本章习题 106
第7章 索引 108
7.1 索引简介 108
7.1.1 索引的含义和特点 108
7.1.2 索引的分类 109
7.1.3 索引的设计原则 110
7.2 创建索引 111
7.2.1 创建表的时候创建索引 111
7.2.2 在已经存在的表上创建索引 116
7.2.3 用ALTER TABLE语句来创建索引 118
7.3 删除索引 119
7.4 本章实例 120
7.5 上机实践 125
7.6 常见问题及解答 127
7.7 小结 127
7.8 本章习题 127
第8章 视图 128
8.1 视图简介 128
8.1.1 视图的含义 128
8.1.2 视图的作用 129
8.2 创建视图 130
8.2.1 创建视图的语法形式 130
8.2.2 在单表上创建视图 131
8.2.3 在多表上创建视图 132
8.3 查看视图 133
8.3.1 DESCRIBE语句查看视图基本信息 134
8.3.2 SHOW TABLE STATUS语句查看视图基本信息 134
8.3.3 SHOW CREATE VIEW语句查看视图详细信息 136
8.3.4 在views表中查看视图详细信息 136
8.4 修改视图 137
8.4.1 CREATE OR REPLACE VIEW语句修改视图 138
8.4.2 ALTER语句修改视图 139
8.5 更新视图 140
8.6 删除视图 143
8.7 本章实例 144
8.8 上机实践 149
8.9 常见问题及解答 150
8.10 小结 151
8.11 本章习题 151
第9章 触发器 152
9.1 创建触发器 152
9.1.1 创建只有一个执行语句的触发器 152
9.1.2 创建有多个执行语句的触发器 153
9.2 查看触发器 154
9.2.1 SHOW TRIGGERS语句查看触发器信息 154
9.2.2 在triggers表中查看触发器信息 155
9.3 触发器的使用 157
9.4 删除触发器 158
9.5 本章实例 159
9.6 上机实践 162
9.7 常见问题及解答 163
9.8 小结 163
9.9 本章习题 163
第3篇 SQL查询语句 166
第10章 查询数据 166
10.1 基本查询语句 166
10.2 单表查询 168
10.2.1 查询所有字段 168
10.2.2 查询指定字段 169
10.2.3 查询指定记录 170
10.2.4 带IN关键字的查询 171
10.2.5 带BETWEEN AND的范围查询 172
10.2.6 带LIKE的字符匹配查询 173
10.2.7 查询空值 175
10.2.8 带AND的多条件查询 176
10.2.9 带OR的多条件查询 177
10.2.10 查询结果不重复 179
10.2.11 对查询结果排序 180
10.2.12 分组查询 182
10.2.13 用LIMIT限制查询结果的数量 186
10.3 使用集合函数查询 188
10.3.1 COUNT()函数 188
10.3.2 SUM()函数 189
10.3.3 AVG()函数 190
10.3.4 MAX()函数 191
10.3.5 MIN()函数 192
10.4 连接查询 193
10.4.1 内连接查询 193
10.4.2 外连接查询 194
10.4.3 复合条件连接查询 196
10.5 子查询 197
10.5.1 带IN关键字的子查询 197
10.5.2 带比较运算符的子查询 198
10.5.3 带EXISTS关键字的子查询 201
10.5.4 带ANY关键字的子查询 203
10.5.5 带ALL关键字的子查询 204
10.6 合并查询结果 205
10.7 为表和字段取别名 206
10.7.1 为表取别名 206
10.7.2 为字段取别名 207
10.8 使用正则表达式查询 209
10.8.1 查询以特定字符或字符串开头的记录 209
10.8.2 查询以特定字符或字符串结尾的记录 210
10.8.3 用符号“.”来替代字符串中的任意一个字符 211
10.8.4 匹配指定字符中的任意一个 211
10.8.5 匹配指定字符以外的字符 212
10.8.6 匹配指定字符串 213
10.8.7 使用“*”和“+”来匹配多个字符 214
10.8.8 使用{M}或者{M,N}来指定字符串连续出现的次数 214
10.9 本章实例 215
10.10 上机实践 227
10.11 常见问题及解答 230
10.12 小结 231
10.13 本章习题 231
第11章 插入、更新与删除数据 233
11.1 插入数据 233
11.1.1 为表的所有字段插入数据 233
11.1.2 为表的指定字段插入数据 235
11.1.3 同时插入多条记录 237
11.1.4 将查询结果插入到表中 238
11.2 更新数据 240
11.3 删除数据 242
11.4 本章实例 244
11.5 上机实践 248
11.6 常见问题及解答 249
11.7 小结 250
11.8 本章习题 250
第12章 MariaDB运算符 251
12.1 运算符简介 251
12.2 算术运算符 252
12.3 比较运算符 253
12.4 逻辑运算符 259
12.5 位运算符 262
12.6 运算符的优先级 264
12.7 本章实例 265
12.8 上机实践 266
12.9 常见问题及解答 267
12.10 小结 267
12.11 本章习题 268
第13章 MariaDB函数 269
13.1 MariaDB函数简介 269
13.2 数学函数 270
13.2.1 绝对值函数ABS(x)和返回圆周率的函数PI() 271
13.2.2 平方根函数SQRT(x)和求余函数MOD(x,y) 271
13.2.3 获取整数的函数CEIL(x)、CEILING(x)和FLOOR(x) 271
13.2.4 获取随机数的函数RAND()和RAND(x) 272
13.2.5 四舍五入函数ROUND(x)、ROUND(x,y)和TRUNCATE(x,y) 272
13.2.6 符号函数SIGN(x) 273
13.2.7 幂运算函数POW(x,y)、POWER(x,y)和EXP(x) 273
13.2.8 对数运算函数LOG(x)和LOG10(x) 274
13.2.9 角度与弧度相互转换的函数RADIANS(x)和DEGREES(x) 274
13.2.10 正弦函数SIN(x)和反正弦函数ASIN(x) 274
13.2.11 余弦函数COS(x)和反余弦函数ACOS(x) 275
13.2.12 正切函数、反正切函数和余切函数 275
13.3 字符串函数 276
13.3.1 计算字符串字符数的函数和字符串长度的函数 277
13.3.2 合并字符串的函数CONCAT(s1,s2,...)和CONCAT_WS(x,s1,s2,...) 277
13.3.3 替换字符串的函数INSERT(s1,x,len,s2) 277
13.3.4 字母大小写转换函数 278
13.3.5 获取指定长度的字符串的函数LEFT(s,n)和RIGHT(s,n) 278
13.3.6 填充字符串的函数LPAD(s1,len,s2)和RPAD(s1,len,s2) 278
13.3.7 删除空格的函数LTRIM(s)、RTRIM(s)和TRIM(s) 279
13.3.8 删除指定字符串的函数TRIM(sl FROM s) 279
13.3.9 重复生成字符串的函数REPEAT(s,n) 280
13.3.10 空格函数SPACE(n)和替换函数REPLACE(s,s1,s2) 280
13.3.11 比较字符串大小的函数STRCMP(s1,s2) 280
13.3.12 获取子串的函数SUBSTRING(s,n,len)和 MID(s,n,len) 281
13.3.13 匹配子串开始位置的函数 281
13.3.14 字符串逆序的函数REVERSE(s) 281
13.3.15 返回指定位置的字符串的函数 281
13.3.16 返回指定字符串位置的函数FIELD(s,s1,s2,...) 282
13.3.17 返回子串位置的函数FIND IN SET(s1,s2) 282
13.3.18 选取字符串的函数MAKE SET(x,s1,s2...) 282
13.4 日期和时间函数 283
13.4.1 获取当前日期的函数和获取当前时间的函数 284
13.4.2 获取当前日期和时间的函数 284
13.4.3 UNIX时间戳函数 285
13.4.4 返回UTC日期的函数和返回UTC时间的函数 285
13.4.5 获取月份的函数MONTH(d)和MONTHNAME(d) 286
13.4.6 获取星期的函数DAYNAME(d)、DAYOFWEEK(d)和WEEKDAY(d) 286
13.4.7 获取星期数的函数WEEK(d)和WEEKOFYEAR(d) 287
13.4.8 获取天数的函数DAYOFYEAR(d)和DAYOFMONTH(d) 287
13.4.9 获取年份、季度、小时、分钟和秒钟的函数 288
13.4.10 获取日期的指定值的函数EXTRACT(type FROM d) 288
13.4.11 时间和秒钟转换的函数 289
13.4.12 计算日期和时间的函数 289
13.4.13 将日期和时间格式化的函数 291
13.5 条件判断函数 294
13.5.1 IF(expr,v1,v2)函数 294
13.5.2 IFNULL(v1,v2)函数 295
13.5.3 CASE函数 295
13.6 系统信息函数 296
13.6.1 获取MariaDB版本号、连接数和数据库名的函数 297
13.6.2 获取用户名的函数 297
13.6.3 获取字符串的字符集和排序方式的函数 298
13.6.4 获取最后一个自动生成的ID值的函数 298
13.7 加密函数 299
13.7.1 加密函数PASSWORD(str) 299
13.7.2 加密函数MD5(str) 299
13.7.3 加密函数ENCODE(str,pswd_str) 300
13.7.4 解密函数DECODE(crypt_str,pswd_str) 300
13.8 其他函数 300
13.8.1 格式化函数FORMAT(x,n) 301
13.8.2 不同进制的数字进行转换的函数 301
13.8.3 IP地址与数字相互转换的函数 302
13.8.4 加锁函数和解锁函数 302
13.8.5 重复执行指定操作的函数 303
13.8.6 改变字符集的函数 303
13.8.7 改变字段数据类型的函数 303
13.9 本章实例 304
13.10 上机实践 307
13.11 常见问题及解答 308
13.12 小结 309
13.13 本章习题 309
第14章 存储过程和函数 310
14.1 创建存储过程和函数 310
14.1.1 创建存储过程 310
14.1.2 创建存储函数 312
14.1.3 变量的使用 313
14.1.4 定义条件和处理程序 313
14.1.5 光标的使用 315
14.1.6 流程控制的使用 316
14.2 调用存储过程和函数 319
14.2.1 调用存储过程 319
14.2.2 调用存储函数 320
14.3 查看存储过程和函数 321
14.3.1 SHOW STATUS语句查看存储过程和函数的状态 321
14.3.2 SHOW CREATE语句查看存储过程和函数的定义 321
14.3.3 从information schema.Routines表中查看存储过程和函数的信息 322
14.4 修改存储过程和函数 323
14.5 删除存储过程和函数 325
14.6 本章实例 325
14.7 上机实践 327
14.8 常见问题及解答 329
14.9 小结 329
14.10 本章习题 329
第4篇 MariaDB数据库高级管理 332
第15章 MariaDB用户管理 332
15.1 权限表 332
15.1.1 user表 332
15.1.2 db表和host表 333
15.1.3 tables priv表和columns priv表 334
15.1.4 procs priv表 334
15.2 账户管理 335
15.2.1 新建普通用户 335
15.2.2 删除普通用户 337
15.2.3 root用户修改自己的密码 338
15.2.4 root用户修改普通用户密码 339
15.2.5 普通用户修改密码 340
15.3 权限管理 341
15.3.1 MariaDB的各种权限 341
15.3.2 授权 342
15.3.3 收回权限 344
15.3.4 查看权限 345
15.4 本章实例 346
15.5 上机实践 347
15.6 常见问题及解答 348
15.7 小结 349
15.8 本章习题 349
第16章 数据备份与还原 350
16.1 数据备份 350
16.1.1 使用mysqldump命令备份 350
16.1.2 直接复制整个数据库目录 353
16.1.3 使用mysqlhotcopy工具快速备份 353
16.2 数据还原 354
16.2.1 使用mysql命令还原 354
16.2.2 直接复制到数据库目录 354
16.3 数据库迁移 355
16.3.1 相同版本的MariaDB数据库之间的迁移 355
16.3.2 不同版本的MariaDB数据库之间的迁移 356
16.3.3 Windows操作系统下的MySQL向MariaDB的迁移 356
16.3.4 Linux操作系统下的MySQL向MariaDB的迁移 359
16.4 表的导出和导入 361
16.4.1 用SELECT...INTO OUTFILE导出文本文件 361
16.4.2 用mysqldump命令导出文本文件 362
16.4.3 用mysql命令导出文本文件 363
16.4.4 用LOAD DATA INFILE方式导入文本文件 364
16.4.5 用mysqlimport命令导入文本文件 366
16.5 本章实例 366
16.6 上机实践 369
16.7 常见问题及解答 370
16.8 小结 371
16.9 本章习题 371
第17章 MariaDB日志 372
17.1 日志简介 372
17.2 二进制日志 373
17.2.1 启动和设置二进制日志 373
17.2.2 查看二进制日志 374
17.2.3 删除二进制日志 375
17.2.4 使用二进制日志还原数据库 376
17.2.5 暂时停止二进制日志功能 376
17.3 错误日志 377
17.3.1 启动和设置错误日志 377
17.3.2 查看错误日志 377
17.3.3 删除错误日志 378
17.4 通用查询日志 379
17.4.1 启动和设置通用查询日志 379
17.4.2 查看通用查询日志 379
17.4.3 删除通用查询日志 380
17.5 慢查询日志 380
17.5.1 启动和设置慢查询日志 380
17.5.2 查看慢查询日志 380
17.5.3 删除慢查询日志 381
17.6 本章实例 381
17.7 上机实践 386
17.8 常见问题及解答 387
17.9 小结 388
17.10 本章习题 388
第18章 性能优化 389
18.1 优化简介 389
18.2 优化查询 390
18.2.1 分析查询语句 390
18.2.2 索引对查询速度的影响 391
18.2.3 使用索引查询 392
18.2.4 优化子查询 394
18.3 优化数据库结构 395
18.3.1 将字段很多的表分解成多个表 395
18.3.2 增加中间表 395
18.3.3 增加冗余字段 396
18.3.4 优化插入记录的速度 397
18.3.5 分析表、检查表和优化表 398
18.4 优化MariaDB服务器 399
18.4.1 优化服务器硬件 399
18.4.2 优化MariaDB的参数 400
18.5 本章实例 401
18.6 上机实践 402
18.7 常见问题及解答 403
18.8 小结 404
18.9 本章习题 404
第5篇 MariaDB应用与实战开发 406
第19章 Java访问MariaDB数据库 406
19.1 Java连接MariaDB数据库 406
19.1.1 下载JDBC驱动MariaDB Connector 406
19.1.2 安装MariaDB Connector驱动 406
19.1.3 连接MariaDB数据库 408
19.2 Java操作MariaDB数据库 409
19.2.1 创建Statement对象 409
19.2.2 使用SELECT语句查询数据 409
19.2.3 插入、更新或者删除数据 410
19.2.4 执行任意SQL语句 411
19.2.5 关闭创建的对象 412
19.3 Java备份与还原MariaDB数据库 412
19.3.1 Java备份MariaDB数据库 412
19.3.2 Java还原MariaDB数据库 413
19.4 本章实例 413
19.5 上机实践 416
19.6 常见问题及解答 419
19.7 小结 419
19.8 本章习题 420
第20章 PHP访问MariaDB数据库 421
20.1 PHP连接MariaDB数据库 421
20.1.1 Windows操作系统下配置PHP 421
20.1.2 Linux操作系统下配置PHP 423
20.1.3 连接MariaDB数据库 424
20.2 PH-P操作MariaDB数据库 425
20.2.1 执行SQL语句 425
20.2.2 处理查询结果 426
20.2.3 获取查询结果的字段名 427
20.2.4 一次执行多个SQL语句 427
20.2.5 处理带参数的SQL语句 428
20.2.6 关闭创建的对象 429
20.3 PHP备份与还原MariaDB数据库 429
20.3.1 PHP备份MariaDB数据库 429
20.3.2 PHP还原MariaDB数据库 430
20.4 本章实例 430
20.5 上机实践 431
20.6 常见问题及解答 432
20.7 小结 433
20.8 本章习题 433
第21章 C#访问MariaDB数据库 434
21.1 C#连接MariaDB数据库 434
21.1.1 下载Connector/Net驱动程序 434
21.1.2 安装Connector/Net驱动程序 434
21.1.3 使用Connector/Net驱动程序 437
21.1.4 连接MariaDB数据库 437
21.2 C#操作MariaDB数据库 438
21.2.1 创建MySqlCommand对象 438
21.2.2 插入、更新或者删除数据 439
21.2.3 使用SELECT语句查询数据 440
21.2.4 一次执行多个SELECT语句 440
21.2.5 处理SELECT语句只返回一个值的情况 441
21.2.6 处理带参数的SQL语句 442
21.2.7 使用DataSet对象和DataTable对象 443
21.2.8 关闭创建的对象 444
21.3 C#备份与还原MariaDB数据库 444
21.3.1 C#备份MariaDB数据库 444
21.3.2 C#还原MariaDB数据库 445
21.4 本章实例 446
21.5 上机实践 448
21.6 常见问题及解答 450
21.7 小结 450
21.8 本章习题 451
第22章 驾校学员管理系统 452
22.1 系统概述 452
22.2 系统功能 452
22.3 数据库设计 453
22.3.1 设计表 453
22.3.2 设计索引 458
22.3.3 设计视图 459
22.3.4 设计触发器 460
22.4 系统实现 461
22.4.1 构建工程 461
22.4.2 访问和操作MariaDB数据库的代码 461
22.5 用户管理模块 464
22.5.1 用户登录功能 464
22.5.2 修改密码 465
22.6 学籍管理模块 466
22.6.1 添加学员的学籍信息 466
22.6.2 查询学员的学籍信息 467
22.6.3 修改学员的学籍信息 468
22.6.4 删除学员的学籍信息 468
22.7 体检管理模块 468
22.8 成绩管理模块 470
22.9 证书管理模块 471
22.10 小结 472