常见命令
连接本地数据库与远程数据库(10.4.xx.xx:3306)
1
2
3
| mysql -h localhost -u root -p123
mysql -h 10.4.xx.xx -P 3306 -u root -p
|
显示数据库列表
显示库中的数据表
显示数据表的结构
默认表结构类型为MYISAM,并在/var/lib/mysql/abc 目录下建立student.frm(表定义文件),student.MDY(数据文件),student.MYI(索引文件)。
建库
建表
1
| create table 表名 (字段设定列表);
|
例如:
1
| mysql> create table test (id int(20));
|
删库和删表
1
2
| drop database 库名;
drop table 表名;
|
将表中记录清空
1
2
3
4
5
| delete from 表名;
# 内容清空,自增id不会被清掉,自增id会保留
mysql> truncate table users;
# 数据库返回:“Query OK, 0 rows affected (0.04 sec)”
#(成功返回0)(自增id也一同会被清掉)
|
显示表中的记录
库的基本操作
创建数据库
1
| mysql> create database ceshi;
|
连接数据库
查看当前使用的数据库
1
| mysql> select database();
|
当前数据库包含的表信息
删除数据库
1
| mysql> drop database ceshi;
|
表的基本操作
命令
1
| create table <表名> (<字段名 1> <类型 1> [,..<字段名 n> <类型 n>]);
|
例如
1
2
3
4
5
| mysql> create table Class(
id int(4) not null primary key auto_increment,
name varchar(25) not null,
age int (4) not null default'0');
# default'0' 设置默认值为0 ,not null(不能为空) ,primary key(主键),auto_increment(自增长)
|
获取表结构
命令
1
| desc 表名,或者show columns from 表名
|
例如
1
2
3
| mysql> desc Class;
mysql> describe Class;
mysql> show columns from Class;
|
插入数据
命令
1
| insert into <表名> [( <字段名 1>[,..<字段名 n > ])] values ( 值 1 )[, ( 值 n )]
|
例如
1
| mysql> insert into Class values(1,'Wrry',26),(2,'ZJW',28);
|
查询表中的数据
查询所有行
1
| mysql> select * from Class;
|
查询前几行数据
例如:查看表 Class 中前 3 行数据
1
| mysql> select * from Class limit 0,3;
|
或者
1
| mysql> select * from Class order by id limit 0,3; # order by id:以id排序
|
删除表中数据
命令
1
| delete from 表名 where 表达式;
|
例如:删除表 Class 中编号为 6 的记录
1
| mysql> delete from MyClass where id=6;
|
修改表中数据
命令
1
| update 表名 set 字段=新值,... where 条件;
|
例如
1
| mysql> update Class set name='AI' where id=1;
|
在表中增加字段
命令
1
| alter table 表名 add 字段 类型 其他;
|
例如:在表 Class 中添加了一个字段 sex,类型为 varchar(25),默认值为 0
1
| mysql> alter table Class add sex varchar(25) default '0';
|
更改表名
命令
1
| rename table 原表名 to 新表名;
|
例如:在表 Class 名字更改为 MClass
1
| mysql> rename table Class to MClass;
|
复制表
1
| create table 新表名 like 原表名称;
|
例如
1
| mysql> create table Test like test;
|
删除表
例如:删除表名为 MClass 的表
1
| mysql> drop table MClass;
|
更多操作参考
Mysql查看触发器
连接数据库并进入库
查看当前库中所有表的触发器
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
| mysql> show triggers \G;
*************************** 1. row ***************************
Trigger: trigupdate
Event: UPDATE
Table: account
Statement: INSERT INTO myevent VALUES(1,'after update')
Timing: AFTER
Created: NULL
sql_mode:
Definer: root@localhost
character_set_client: utf8
collation_connection: utf8_general_ci
Database Collation: utf8_general_ci
1 row in set (0.00 sec)
ERROR:
No query specified
|
触发器的创建
新建表account,表中有两个字段,分别是 INT 类型的 accnum 和 DECIMAL 类型的 amount。SQL 语句和运行结果如下:
1
2
3
4
| mysql> CREATE TABLE account(
accnum INT(4),
amount DECIMAL(10,2));
Query OK, 0 rows affected (0.49 sec)
|
创建一个名为 trigupdate 的触发器,每次 account 表更新数据之后都向 myevent 数据表中插入一条数据。创建数据表 myevent 的 SQL 语句和运行结果如下:
1
2
3
4
| mysql> CREATE TABLE myevent(
id INT(11) DEFAULT NULL,
evtname CHAR(20) DEFAULT NULL);
Query OK, 0 rows affected (0.26 sec)
|
创建 trigupdate 触发器的 SQL 代码如下:
1
2
3
| mysql> CREATE TRIGGER trigupdate AFTER UPDATE ON account
FOR EACH ROW INSERT INTO myevent VALUES(1,'after update');
Query OK, 0 rows affected (0.15 sec)
|
使用 SHOW TRIGGERS 语句查看触发器(在 SHOW TRIGGERS 命令后添加\G
,这样显示信息会比较有条理),SQL 语句和运行结果如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
| mysql> show triggers\G;
*************************** 1. row ***************************
Trigger: trigupdate
Event: INSERT
Table: account
Statement: INSERT INTO myevent VALUES(1,'after insert')
Timing: AFTER
Created: NULL
sql_mode:
Definer: root@localhost
character_set_client: utf8
collation_connection: utf8_general_ci
Database Collation: utf8_general_ci
1 row in set (0.00 sec)
ERROR:
No query specified
|
由运行结果可以看到触发器的基本信息。对以上显示信息的说明如下:
- Trigger 表示触发器的名称,在这里触发器的名称为 trigupdate;
- Event 表示激活触发器的事件,这里的触发事件为更新操作 UPDATE;
- Table 表示激活触发器的操作对象表,这里为 account 表;
- Statement 表示触发器执行的操作,这里是向 myevent 数据表中插入一条数据;
- Timing 表示触发器触发的时间,这里为更新操作之后(AFTER);
- 还有一些其他信息,比如触发器的创建时间、SQL 的模式、触发器的定义账户和字符集等,这里不再一一介绍。
SHOW TRIGGERS 语句用来查看当前创建的所有触发器的信息。因为该语句无法查询指定的触发器,所以在触发器较少的情况下,使用该语句会很方便。如果要查看特定触发器的信息或者数据库中触发器较多时,可以直接从 information_schema 数据库中的 triggers 数据表中查找。
在triggers表中查看触发器信息
在 MySQL 中,所有触发器的信息都存在 information_schema 数据库的 triggers 表中,可以通过查询命令 SELECT 来查看,具体的语法如下:
1
| SELECT * FROM information_schema.triggers WHERE trigger_name= '触发器名';
|
其中,'触发器名'
用来指定要查看的触发器的名称,需要用单引号引起来。这种方式可以查询指定的触发器,使用起来更加方便、灵活。
下面使用 SELECT 命令查看 trigupdate 触发器,SQL 语句如下:
1
| SELECT * FROM information_schema.triggers WHERE TRIGGER_NAME= 'trigupdate'\G;
|
上述命令通过 WHERE 来指定需要查看的触发器的名称,运行结果如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
| mysql> SELECT * FROM information_schema.triggers WHERE TRIGGER_NAME= 'trigupdate'\G;
*************************** 1. row ***************************
TRIGGER_CATALOG: def
TRIGGER_SCHEMA: test
TRIGGER_NAME: trigupdate
EVENT_MANIPULATION: INSERT
EVENT_OBJECT_CATALOG: def
EVENT_OBJECT_SCHEMA: test
EVENT_OBJECT_TABLE: account
ACTION_ORDER: 0
ACTION_CONDITION: NULL
ACTION_STATEMENT: INSERT INTO myevent VALUES(1,'after insert')
ACTION_ORIENTATION: ROW
ACTION_TIMING: AFTER
ACTION_REFERENCE_OLD_TABLE: NULL
ACTION_REFERENCE_NEW_TABLE: NULL
ACTION_REFERENCE_OLD_ROW: OLD
ACTION_REFERENCE_NEW_ROW: NEW
CREATED: NULL
SQL_MODE:
DEFINER: root@localhost
CHARACTER_SET_CLIENT: utf8
COLLATION_CONNECTION: utf8_general_ci
DATABASE_COLLATION: utf8_general_ci
1 row in set (0.01 sec)
|
由运行结果可以看到触发器的详细信息。对以上显示信息的说明如下:
- TRIGGER_SCHEMA 表示触发器所在的数据库;
- TRIGGER_NAME 表示触发器的名称;
- EVENT_OBJECT_TABLE 表示在哪个数据表上触发;
- ACTION_STATEMENT 表示触发器触发的时候执行的具体操作;
- ACTION_ORIENTATION 的值为 ROW,表示在每条记录上都触发;
- ACTION_TIMING 表示触发的时刻是 AFTER;
- 还有一些其他信息,比如触发器的创建时间、SQL 的模式、触发器的定义账户和字符集等,这里不再一一介绍。
上述 SQL 语句也可以不指定触发器名称,这样将查看所有的触发器,SQL 语句如下:
1
| SELECT * FROM information_schema.triggers \G;
|
这个语句会显示 triggers 数据表中所有的触发器信息。
警告
本文最后更新于 January 3, 2022,文中内容可能已过时,请谨慎使用。