MariaDB笔记¶
默认设定¶
默认系统数据库和用户数据库
- information_schema
- performance_schema
- mysql
- test..
默认字符集
- 字符集latin1(西欧语言)
- 比较是latin1_swedish_ci;可更改为utf8, utf8_general_ci。
数据类型和运算符¶
运算符¶
=
关系比较相等<>
,!=
不等于
注意关系比较相等是一个=
。
数据类型¶
数值类型数据¶
[TINY | SMALL | MEDIUM]INT[(M)]
分别占用1、2、3和4字节储存,其中M表示显示宽度,与实际占用的空间大小无关。- INT [SIGNED | UNSIGNED | ZEROFILL] 默认为有符号,如果是
ZEROFILL
,等价于UNSIGNED ZEROFILL
。 -
ZEROFILL
使得数值在显示时未达到M
的指定位数会在前部填充零;当超过指定的显示宽度时,会按照原样输出(即不会截断)。 -
DECIMAL(M, D)
定点数,M为总位数,D为小数位数。 FLOAT[(M, D)]
,DOUBLE[(M, D)]
单精度浮点数和双精度浮点数。
非数值类型数据¶
CHAR(M)
,VARCHAR(M)
,TINYTEXT
,TEXT
DATE
,DATETIME
,TIME
,TIMESTAMP
,YEAR
如果不指定CHAR的宽度,默认值是灾难性的1。
常用函数的类型¶
NOW()
,DATETIME
CURRENT_TIMESTAMP
,TIMESTAMP
用户管理¶
- 创建用户
CREATE USER 'user' IDENTIFIED BY 'password';
- 赋予权限
GRANT ALL PRIVILEGES ON dbname.* TO uesr;
,GRANT SELCET, INSERT, UPDATE, DELETE, GRANT OPTION on dbname TO user;
GRANT OPTION
使得获取的权限可以传递。
DDL¶
- 单行注释
//
- 多行注释
/* ... */
操作数据库¶
SHOW DATABASES;
USE 数据库名;
CREATE DATABASE 数据库名;
DROP DATABASE 数据库名;
操作数据表¶
创建表¶
CREATE TABLE [IF NOT EXISTS] 'tbname' (
'colName' INT(4) PRIMARY KEY COMMENT '这里前面没有等号',
字段名 数据类型 [字段属性 | 约束] [索引] [注释],
...,
) [COMMENT='这里前面有等号'] [CHARSET=...];
注意CREATE TABLE命令的最后一个参数(即最后一行)不要附加逗号。
SHOW CREATE TABLE 表名[\G]
查看创建表的语句
对于多字段主键,可以先定义完字段,再定义主键PRIMARY KEY(id, name)
定义外键 FOREIGN KEY(col1, col2) REFERENCES 主表名 (col1, col2)
ALTER TABLE DROP FOREIGN KEY 外键约束名称
维护表¶
SHOW TABLES
DESCRIBE 表名
DESC 表名
查看表的定义(表中定义的字段),不能查看数据库的“定义”DROPE TABLE [IF EXISTS] 表名
表的重命名和字段的修改
ALTER TABLE 旧表名 RENAME [TO] 新表名;
[TO]可省略无影响ALTER TABLE 表名 ADD 字段名 数据类型 [属性]
ALTER TABLE 表名 MODIFY 字段名 数据类型
改变字段数据类型ALTER TABLE 表名 MODIFY 字段名 数据类型 FIRST | AFTER 字段名
改变字段的排列顺序ALTER TABLE 表名 CHANGE 原字段名 新字段名 数据类型(不能为空) [属性]
改变字段名或字段数据类型ALTER TABLE 表名 DROP 字段名
添加主键约束 ALTER TABLE 表名 ADD CONSTRAINT 字段名(形如,pk_表名) PRIMARY KEY 表名(字段名)
添加字段约束 ALTER TABLE 表名 ADD CONSTRAINT 字段名(形容,fk_从表名_主表名) FOREIGN KEY(外键字段) REFERENCES 主标名(主表字段)
字段约束¶
- 非空约束 NOT NULL
- 默认约束 DEFAULT 如:DEFAULT '男'
- 唯一约束 UNIQUE KEY
- 主键约束 PRIMARY KEY
- 外键约束 FOREIGN KEY 从表某数据项在主表中必须存在
- 自动增长 AUTO_INCREMENT
InnoDB支持外键,MyISAM不支持外键;外键关联的表要求都是InnoDB。
UNSIGNED也是一种约束
DML¶
表的储存引擎¶
InnoDB, MyISAM, Memory, Archive
CREATE TABLE tbname (
# 省略代码
) ENGINE=InnoDB;
ALTER TABLE 表名 ENGINE=<引擎名>
INSERT¶
INSERT INTO 表名 [字段名列表] VALUES (值列表);
INSERT INTO 表名 [字段名列表] VALUES (值列表1), (值列表2), ...;
将查询结果插入到新表
CREATE TABLE 新表 (
SELECT 字段1, 字段2, ... FROM 原表
);
UPDATE¶
UPDATE 表名 SET 字段名 = 更新值
DELETE¶
DELETE FROM 表名 [WHRER ... ]
TRUNCATE TABLE 表名
标志列会重新开始编号
Chapter 6 DQL¶
SELECT <字段名 | 表达式 | 函数 | 常量>
FROM 表名
[WHERE <查询条件>]
[ORDER BY <排序的列名> [ASC(默认) | DESC]]
SELECT¶
SELECT 字段名 AS 别名
SELECT 字段1+字段2 AS 别名
WHERE 字段名 IS NULL
查询空值SELECT 常量 AS 字段名
ORDER BY¶
ORDER BY 字段1 [排序], 字段2[排序]
LIMIT¶
LIMIT [[位置偏移量offset], 行数row_count]
第1条记录的位置偏移量是0。
子查询¶
使用等号的子查询作为WHERE语句的一部分,需要保证子查询返回的值为空或者只有一个
SELECT 'studentName' FROM 'student' WHERE 'studentNo' = (
SELECT 'studentNo' FROM 'result'
INNER JOIN 'subjcet' ON result.subjectNO = subject.subjectNo
WHERE 'studentResult'=60 AND 'subjectName'='LogicJava'
);
IN¶
如果子查询返回的值多于一个,可以使用IN
SELECT 'studentName' FROM 'student' WHERE 'studentNo' IN (
SELECT 'studentNo' FROM 'result'
INNER JOIN 'subjcet' ON result.subjectNO = subject.subjectNo
WHERE 'studentResult'=60 AND 'subjectName'='LogicJava'
);
还有NOT IN
。
BETWEEN AND¶
SELECT name FROM student WHERE id BETWEEN 1706300001 AND 1806300001
还有NOT BETWEEN AND
LIKE¶
匹配查询,%
任意多个字符(包括0个),_
任意一个字符
SELECT * FROM books WHRER name LIKE '%大全'
DISTINCT¶
DISTINCT
必须放在查询语句的开头,可以与COUNT()
结合使用,返回不重复的字段;反义词是ALL
SELECT DISTINCT author FROM books WHRER name LIKE '%大全'
SOME¶
SOME
亦作ANY
,表示为满足任意一个条件
SELECT * FROM books WHRER price > SOME(5, 15, 20)
表示查询价格大于5的数据
EXISTS¶
SELECT FROM 表名 WHRER EXISTS(子查询)
如果子查询的结果具有返回行,则执行父查询
常见错误¶
嵌套在FROM子句中的SELECT语句需要为derived table指定别名 (子查询) AS 别名
- 错误:
SELCET * FROM (SELECT * FORM 表名)
- 正确:
SELCET * FROM (SELECT * FORM 表名) AS 别名
GROUP BY¶
分组查询:根据字段分组查询后合并结果
SELECT subjectNo, AVG(studentResult) from result group by subjectNo
SELECT COUNT(*), gradeId FROM student GROUP BY gradeId;
使用HAVING
对分组后的数据进行筛选,无法使用WHERE
对分组后的数据进行筛选
SELECT COUNT(*) '人数', gradeId '年级', sex '性别'
FROM student
GROUP BY gradeId
HAVING COUNT(*) > 2;
执行顺序:WHERE
-> GROUP BY
-> 聚合函数 -> HAVING
UNION¶
UNION
合并多个查询的结果并去除重复项目,合并时表对应的字段和数据类型必须相同
UNION ALL
不去除重复
连接查询¶
- 内连接 根据表中共同的列来进行匹配
- 外连接 至少返回一个表中的所有记录,根据匹配条件有选择地从另一个表中返回记录
内连接¶
使用WHERE
的内连接
SELECT student.studentName, result.subjectNo, result.studentResult
FROM student, result
WHERE student.studentNo = result.studentNo;
使用[INNER] JOIN ... ON ..
的内连接
SELECT studentName, subjectNo, studentResult
FROM student
INNER JOIN result ON student.studentNo = result.studentNo;
或使用别名,其中若连接中的两个表或多个表中查询的字段不重复则不需要对这一列不需要指定别名。
SELECT S.studentName, R.subjectNo, R.studentResult
FROM student as S
INNER JOIN result as R ON S.studentNo = R.studentNo;
可以对多个表使用内连接
SELECT S.studentName, SU.subjectName, R.studentResult
FROM student AS S
INNER JOIN result AS R ON S.studentNo = R.studentNo
INNER JOIN subject AS SU ON SU.subjectNo = R.subjectNo;
外连接¶
<LEFT | RIGHT> OUTER JOIN ... ON
SELECT S.studentName, R.studentResult
FROM student AS S
LEFT OUTER
JOIN result AS R ON S.studentNo = R.studentNo;
LEFT OUTTER JOIN返回结果包含左表的所有行
函数¶
聚合函数
AVG()
COUNT()
MAX()
,MIN()
SUM()
字符串函数,注意下标从1开始
CONCAT(str1, str2, ...)
INSERT(str, pos, len, newstr)
LOWER(str)
,UPPER(str)
SUBSTRING(str, pos, len)
时间日期函数
CURDATE()
当前日期CURTIME()
当前时间NOW()
当前日期和时间WEEK(date)
,YEAR(date)
,HOUR(date)
,MINUTE(date)
DATEDIFF(date1, date2)
返回日期相隔的天数ADDDATE(date, n)
返回date
数学函数
CEIL(x)
,FLOOR(x)
RAND()
Chapter 8 事务 Transaction¶
将一系列数据操作左为整体处理,如果某一事务提交成功则该事务的所有数据更改均会提交,成为数据库中的永久组成部分;如果事务执行时遇到错误且必须去取消或回滚,则数据将全部恢复到操作前的状态,所有数据的更改均被清除。
- 原子性 事务的各个元素是不可分割的
- 一致性 事务完成时数据处于一致状态,事务不能使数据储存处于不稳定的状态
- 隔离性 所有并发事务彼此隔离;事务不应该以任何方式依赖或影响其他事务
- 持久性 一旦事务提交,对数据库的影响是永久的
InnoDB对事物的支持:REDO日志、UNDO日志
BEGIN; // 或 START TRANSACTION;
COMMIT;
ROLLBACK;
未显式开启事务时,每条SQL语句都作为单独的事务执行完毕自动提交。
MySQL设置自动提交 SET autocommit = 0 | 1;
视图¶
- 创建视图
CREATE VIEW 视图名(形如view_xxx或v_xxx)AS <SELECT 语句>
- 删除视图
DROP VIEW [IF EXISTS] 视图名
- 查看视图
SELECT * FROM 视图名
视图可以嵌套另一个视图,对视图数据的添加修改和查询直接影响表中的数据。
索引¶
- 普通索引 允许重复和空值
- 唯一索引 不允许重复,允许空值
- 主键索引 单一主键时自动创建主键索引,主键索引非空不重复
- 复合索引 将多个列组合作为索引;在查询中只有使用了组合索引中最左边的字段时,索引才会被使用
- 全文索引 主要用于在CAHR, TEXT等数据中全文检索数据
- 空间索引 MyISAM only,对空间数据类型建立的索引
创建和使用索引
- 创建索引
CREATE [UNQIUE | FULLTEXT | SPATIAL |] INDEX 索引名 ON 表名(字段名[字符串类型可以指定索引长度])
- 删除索引
DROP INDEX 表名.索引名
- 查看索引
SHOW INDEX FROM 表名
数据备份¶
备份
mysqldump -u usrname -h host -p dbname[tbname1, ...] > filename.sql
或保存到外部文件
SELECT * FROM ...
INTO OUTFILE 'filename' [OPTIONS]
恢复
mysql -u -p [dbname] < filename.sql
- 登陆MySQL后,
source filename
安装¶
在Linux发行版上可以使用配置工具。
在CentOS7上安装¶
yum install mariadb-server
sudo systemctl start mariadb
sudo systemctl status mariadb
sudo systemctl enable mariadb
sudo mysql_secure_installation
mysqladmin -u root -p version
管理¶
配置文件¶
/etc/my.cnf
此文件中可以修改默认编码。
命令行工具¶
mysql -u root -p
- 显示帮助目录
HELP contents
- 查看版本和登陆用户名
SELECT VERSION(), USER()
-
编码问题临时解决
SET NAMES gbk; # 相当于下面三条语句 SET character_set_client=gbk; SET character_set_results=gbk; SET character_set_connection=gbk;
-
查看支持的引擎
SHOW ENGINES
,SHOW VARIABLES LIKE 'storage_engine'