侧边栏壁纸
博主头像
Blog博主等级

行动起来,活在当下

  • 累计撰写 211 篇文章
  • 累计创建 94 个标签
  • 累计收到 0 条评论

目 录CONTENT

文章目录

mysql常用命令总结

常见命令

连接本地数据库与远程数据库(10.4.xx.xx:3306)

mysql -h localhost -u root -p123
​
mysql -h 10.4.xx.xx -P 3306 -u root -p

显示数据库列表

show databases;

显示库中的数据表

show tables;

显示数据表的结构

describe 表名;

默认表结构类型为MYISAM,并在/var/lib/mysql/abc 目录下建立student.frm(表定义文件),student.MDY(数据文件),student.MYI(索引文件)。

建库

create database 库名;

建表

create table 表名 (字段设定列表);

例如:

mysql> create table test (id int(20));

删库和删表

drop database 库名;
drop table 表名;

将表中记录清空

delete from 表名;
# 内容清空,自增id不会被清掉,自增id会保留
mysql> truncate table users;
# 数据库返回:“Query OK, 0 rows affected (0.04 sec)”
#(成功返回0)(自增id也一同会被清掉)

显示表中的记录

select * from 表名;

库的基本操作

创建数据库

mysql> create database ceshi;

连接数据库

mysql> use ceshi;

查看当前使用的数据库

mysql> select database();

当前数据库包含的表信息

mysql> show tables; 

删除数据库

mysql> drop database ceshi;

表的基本操作

命令

create table <表名> (<字段名 1> <类型 1> [,..<字段名 n> <类型 n>]);

例如

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(自增长)

获取表结构

命令
desc 表名,或者show columns from 表名

例如

mysql> desc Class;
mysql> describe Class;
mysql> show columns from Class;

插入数据

命令
insert into <表名> [( <字段名 1>[,..<字段名 n > ])] values ( 值 1 )[, ( 值 n )]

例如

mysql> insert into Class values(1,'Wrry',26),(2,'ZJW',28);

查询表中的数据

查询所有行
mysql> select * from Class;
查询前几行数据

例如:查看表 Class 中前 3 行数据

mysql> select * from Class limit 0,3;

或者

mysql> select * from Class order by id limit 0,3;    # order by id:以id排序

删除表中数据

命令
delete from 表名 where 表达式;
例如:删除表 Class 中编号为 6 的记录
mysql> delete from MyClass where id=6;

修改表中数据

命令
update 表名 set 字段=新值,... where 条件;
例如
mysql> update Class set name='AI' where id=1;

在表中增加字段

命令
alter table 表名 add 字段 类型 其他;
例如:在表 Class 中添加了一个字段 sex,类型为 varchar(25),默认值为 0
mysql> alter table Class add sex varchar(25) default '0';

更改表名

命令
rename table 原表名 to 新表名;
例如:在表 Class 名字更改为 MClass
mysql> rename table Class to MClass;

复制表

create table 新表名 like 原表名称;

例如

mysql> create table Test like test;

删除表

命令:drop table <表名>
例如:删除表名为 MClass 的表
mysql> drop table MClass;

更多操作参考

Mysql查看触发器

连接数据库并进入库

use test;

查看当前库中所有表的触发器

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 语句和运行结果如下:

mysql> CREATE TABLE account(
       accnum INT(4),
       amount DECIMAL(10,2));
Query OK, 0 rows affected (0.49 sec)

创建一个名为 trigupdate 的触发器,每次 account 表更新数据之后都向 myevent 数据表中插入一条数据。创建数据表 myevent 的 SQL 语句和运行结果如下:

mysql> CREATE TABLE myevent(
       id INT(11) DEFAULT NULL,
       evtname CHAR(20) DEFAULT NULL);
Query OK, 0 rows affected (0.26 sec)

创建 trigupdate 触发器的 SQL 代码如下:

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 语句和运行结果如下:

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 来查看,具体的语法如下:

SELECT * FROM information_schema.triggers WHERE trigger_name= '触发器名';

其中,'触发器名'用来指定要查看的触发器的名称,需要用单引号引起来。这种方式可以查询指定的触发器,使用起来更加方便、灵活。

下面使用 SELECT 命令查看 trigupdate 触发器,SQL 语句如下:

SELECT * FROM information_schema.triggers WHERE TRIGGER_NAME= 'trigupdate'\G;

上述命令通过 WHERE 来指定需要查看的触发器的名称,运行结果如下:

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 语句如下:

SELECT * FROM information_schema.triggers \G;

这个语句会显示 triggers 数据表中所有的触发器信息。

0

评论区