Mysql

事务

事务是必须满足4个条件(ACID):原子性(Atomicity,或称不可分割性)、一致性(Consistency)、隔离性(Isolation,又称独立性)、持久性(Durability)。

原子性:一个事务(transaction)中的所有操作,要么全部完成,要么全部不完成,不会结束在中间某个环节。事务在执行过程中发生错误,会被回滚(Rollback)到事务开始前的状态,就像这个事务从来没有执行过一样。
一致性:在事务开始之前和事务结束以后,数据库的完整性没有被破坏。这表示写入的资料必须完全符合所有的预设规则,这包含资料的精确度、串联性以及后续数据库可以自发性地完成预定的工作。
隔离性:数据库允许多个并发事务同时对其数据进行读写和修改的能力,隔离性可以防止多个事务并发执行时由于交叉执行而导致数据的不一致。事务隔离分为不同级别,包括读未提交(Read uncommitted)、读提交(read committed)、可重复读(repeatable read)和串行化(Serializable)。
持久性:事务处理结束后,对数据的修改就是永久的,即便系统故障也不会丢失。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
用 BEGIN, ROLLBACK, COMMIT来实现

begin; # 开始事务
Query OK, 0 rows affected (0.00 sec)

insert into runoob_transaction_test values(7);
Query OK, 1 rows affected (0.00 sec)

rollback; # 回滚
Query OK, 0 rows affected (0.00 sec)

commit; # 提交事务

BEGIN 开始一个事务
ROLLBACK 事务回滚
COMMIT 事务确认

ALTER命令

  • 删除,添加或修改表字段
1
2
3
4
5
6
7
ALTER TABLE 表名  DROP column 列名;

ALTER TABLE 表名 ADD 列名 数据类型;

ALTER TABLE 表名 RENAME column 旧列名 to 新列名;

ALTER TABLE 表名 MODIFY 列名 数据类型;
  • 修改表名
1
ALTER TABLE 旧表名 RENAME TO 新表名;

索引

  • 创建
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
CREATE INDEX 索引名称 ON 表名(列名(length));
如果是CHAR,VARCHAR类型,length可以小于字段实际长度;如果是BLOB和TEXT类型,必须指定length。

修改表结构(添加索引)
ALTER table 表名 ADD INDEX i索引名称(列名)

创建表的时候直接指定
CREATE TABLE mytable(
ID INT NOT NULL,
username VARCHAR(16) NOT NULL,
INDEX [索引名] (列名(length))
);

删除索引的语法
DROP INDEX [索引名] ON 表名;

临时表

MySQL临时表在我们需要保存一些临时数据时是非常有用的。临时表只在当前连接可见,当关闭连接时,Mysql会自动删除表并释放所有空间。

1
2
3
4
5
6
CREATE TEMPORARY TABLE SalesSummary (
product_name VARCHAR(50) NOT NULL,
total_sales DECIMAL(12,2) NOT NULL DEFAULT 0.00,
avg_unit_price DECIMAL(7,2) NOT NULL DEFAULT 0.00,
total_units_sold INT UNSIGNED NOT NULL DEFAULT 0
);

序列

1
2
3
4
5
6
7
8
9
10
CREATE TABLE insect(
id INT UNSIGNED NOT NULL AUTO_INCREMENT,
PRIMARY KEY (id),
name VARCHAR(30) NOT NULL, # type of insect
date DATE NOT NULL, # date collected
origin VARCHAR(30) NOT NULL # where collected
);

一般情况下序列的开始值为1,但如果你需要指定一个开始值100,我们可以在建表时在)外增加
auto_increment=100
  • 读取不重复的数据
1
SELECT DISTINCT last_name, first_name FROM person_tbl;