MySQL 基础SQL语句

Linux系统环境

[root@mysql ~]# cat /etc/redhat-release                     #==》系统版本
CentOS release 6.7 (Final)
[root@mysql ~]# uname –r                                    #==》内核版本
2.6.32-573.el6.x86_64
[root@mysql ~]# uname -m                                    #==》系统架构
x86_64
[root@mysql ~]# echo $LANG                                  #==》系统字符集
en_US.UTF-8
[root@mysql ~]# mysql –V                                    #==》MySQL版本
mysql  Ver 14.14 Distrib 5.5.32, for Linux (x86_64) using readline 5.1

MySQL配置文件
提示:/application/mysql是MySQL程序目录

#==》MySQL启动脚本,一般复制到/etc/init.d/mysqld
/application/mysql/support-files/mysql.server   

#==》MySQL主配置文件,一 般复制到/etc/my.cnf
/application/mysql/support-files/my-small.cnf /etc/my.cnf   

#==》MySQL所有二进制命令存放目录,可复制到/usr/local/sbin目录下或者添加环境变量
/application/mysql/bin/

#==》MySQL错误日志
/application/mysql/data/ MySQL01.err

#==》MySQL默认端口 3306
[root@mysql ~]# netstat -tlunp | grep 3306
tcp 0      0 0.0.0.0:3306        0.0.0.0:*        LISTEN      4780/mysqld

#==》MySQL套接字文件sock
/application/mysql-5.5.32/tmp/mysql.sock

什么是SQL

SQL英文全称Structured Query Language,中文意思是结构化查询语言,它是一种数据查询和程序设计语言,对关系数据库中的数据进行定义和操作的语言方法,是大多数关系数据库管理系统所支持。

SQL结构化查询语言分类
1、数据查询语言(DQL)

DQL全称Data Query Language,其语句,也称为“数据检索语句”,用以从表中获得数据,确定数据怎样在应用程序给出。保留字SELECT是DQL(也是所有SQL)用得最多的动词,其他DQL常用的保留字有WHERE,ORDER BY,GROUP BY和HAVING.这些DQL保留字常与其他类型的SQL语句一起使用。具体语句例如:
mysql> select user,host,password from mysql.user;

2、数据操作语言(DML)

DML全称Data Manipulation Language,其语句包括动词INSERT,UPDATE和DELETE.它们分别用于添加,修改和删除表中的行(数据)。也称为动作查询语言。具体语句例如:
mysql> delete from mysql.user where user='oldboy' and host='localhost';

3、事务处理语言(TPL)

它的语句能确保被DML语句影响的表的所有行及时得以更新。TPL语句包括BEGIN TRANSACTION,COMMIT和ROLLBACK.

4、数据控制语言(DCL)

DCL全称(Data Control Language),它的语句通过GRANT或REVOKE获得许可,确定单个用户和用户组对数据库对象的访问。某些RDBMS可用GRANT或REVOKE控制对表单个列的访问。
mysql> grant all privileges on test.* to 'xiaoming'@'localhost' identified by '123456';

5、数据定义语言(DDL)

DDL全称(Data Definition Language),其语句包括动词CREATE和DROP。在数据库中创建新表或删除表(CREAT TABLE或DROP TABLE);为表加入索引等。DDL包括许多与人数据库目录中获得数据有关的保留字,它也是动作查询的一部分。

6、指针控制语言(CCL)

CCL全称(CURSOR Control Language),它的语句,像DECLARE CURSOR,FETCH INTO和UPDATE WHERE CURRENT用于对一个或多个表单独行的操作。

7、SQL语句最常见的分类一般就是3类:

    #==》运维常用
(1)、DDL一数据定义语言(CREATE,ALTER,DROP)
    #==》开发常用
(2)、DML一数据操作语言(SELECT,INSERT,DELETE,UPDATE)
    #==》运维常用
(3)、DCL一数据控制语言(GRANT,REVOKE,COMMIT,ROLLBACK)

一、MySQL创建数据库

命令语法 : create database 数据库名称          #==》数据库名不能数字开头

mysql> create database db01;
Query OK, 1 row affected (0.00 sec)

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| db01               |
| mysql              |
| performance_schema |
+--------------------+
4 rows in set (0.00 sec)
mysql> help create                        #==》查看create命令帮助,非常有用

二、MySQL创建数据库并指定字符集
标注:MySQL支持多种字符集, 在编译安装MySQL可以指定所支持字符集,同时可以设置MySQL默认字符集,如果没有指定默认字符集,MySQL默认字符集是lating1拉丁字符

1、查看库对应的字符集
mysql> show create database db01\G
*************************** 1. row ***************************
       Database: db01
Create Database: CREATE DATABASE `db01` /*!40100 DEFAULT CHARACTER SET latin1 */
1 row in set (0.00 sec)

2、创建db02数据库并指定gbk字符集
mysql> create database db02 DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci;
Query OK, 1 row affected (0.00 sec)

mysql> show create database db02\G
*************************** 1. row ***************************
       Database: db02
Create Database: CREATE DATABASE `db02` /*!40100 DEFAULT CHARACTER SET gbk */
1 row in set (0.00 sec)

3、创建db03数据库并指定utf8字符集
mysql> create database db03 DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
Query OK, 1 row affected (0.01 sec)

mysql> show create database db03\G
*************************** 1. row ***************************
       Database: db03
Create Database: CREATE DATABASE `db03` /*!40100 DEFAULT CHARACTER SET utf8 */
1 row in set (0.00 sec)

4、MySQL编译安装支持字符集类型并指定默认utf8字符集
-DDEFAULT_CHARSET=utf8 \                    #==》指定默认utf8字符集
-DDEFAULT_COLLATION=utf8_general_ci \       #==》指定默认utf8字符集
-DEXTRA_CHARSETS=gbk,gb2312,utf8,ascii \        #==》安装支持的字符集

三、MySQL显示数据库

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| db01               |
| db02               |
| db03               |
| mysql              |
| performance_schema |
+--------------------+
6 rows in set (0.00 sec)

mysql> help show                            #==》查看show命令帮助,非常有用
mysql> show databases like '%db%';          #==》%为通配符,匹配所有内容
+-----------------+
| Database (%db%) |
+-----------------+
| db01            |
| db02            |
| db03            |
+-----------------+
3 rows in set (0.00 sec)
mysql> use db01;                            #==》进入db01数据库
Database changed
mysql> select database();
+------------+
| database() |
+------------+
| db01       |
+------------+
1 row in set (0.00 sec)

四、MySQL删除数据库

mysql> show databases like 'db%';
+----------------+
| Database (db%) |
+----------------+
| db01           |
| db02           |
| db03           |
+----------------+
3 rows in set (0.00 sec)
mysql> drop database db03;
Query OK, 0 rows affected (0.00 sec)

mysql> show databases like 'db%';
+----------------+
| Database (db%) |
+----------------+
| db01           |
| db02           |
+----------------+
2 rows in set (0.01 sec)
mysql> help drop database                   #==》学习潜意识就要查看帮助

五、MySQL连接数据库

语法格式:use 数据库名

mysql> use db01                             #==》进入db01数据库
Database changed
mysql> select database();
+------------+
| database() |
+------------+
| db01       |
+------------+
1 row in set (0.00 sec)

mysql> select version();
+-----------+
| version() |
+-----------+
| 5.5.32    |
+-----------+
1 row in set (0.00 sec)

mysql> select user();
+----------------+
| user()         |
+----------------+
| root@localhost |
+----------------+
1 row in set (0.00 sec)

mysql> select now();
+---------------------+
| now()               |
+---------------------+
| 2019-07-26 14:31:44 |
+---------------------+
1 row in set (0.00 sec)
mysql> show tables;
Empty set (0.00 sec)

mysql> show tables like 'user';                 #==》连接到mysql数据库查询指定表
+------------------------+
| Tables_in_mysql (user) |
+------------------------+
| user                   |
+------------------------+
1 row in set (0.00 sec)

mysql> show tables from mysql like 'user';      #==》没有连接到mysql数据库查询指定表
+------------------------+
| Tables_in_mysql (user) |
+------------------------+
| user                   |
+------------------------+
1 row in set (0.00 sec)

六、删除MySQL数据库多余账号
标注:如果drop删除不了(一般是特殊字符或大写),可以使用delete from语句进行删除

mysql> create user 'test01'@'localhost' identified by '123456';     #==》创建测试用户
Query OK, 0 rows affected (0.00 sec)

mysql> create user 'test02'@'localhost' identified by '123456';     #==》创建测试用户
Query OK, 0 rows affected (0.00 sec)

mysql> select user,host,password from mysql.user;
+--------+-----------+-------------------------------------------+
| user   | host      | password                                  |
+--------+-----------+-------------------------------------------+
| root   | localhost | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
| root   | 127.0.0.1 |                                           |
| test02 | localhost | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
| test01 | localhost | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
+--------+-----------+-------------------------------------------+
4 rows in set (0.00 sec)
mysql> drop user 'test01'@'localhost';
Query OK, 0 rows affected (0.00 sec)
mysql> delete from mysql.user where user='test02' and host='localhost';
Query OK, 1 row affected (0.00 sec)
mysql> select user,host,password from mysql.user;
+------+-----------+-------------------------------------------+
| user | host      | password                                  |
+------+-----------+-------------------------------------------+
| root | localhost | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
| root | 127.0.0.1 |                                           |
+------+-----------+-------------------------------------------+
2 rows in set (0.00 sec)
mysql> flush privileges;                    #==》一定要刷新,否则不生效
Query OK, 0 rows affected (0.00 sec)
mysql> help drop                            #==》多查帮助,养成习惯

七、创建MySQL用户并赋予用户权限

语法格式:
授权命令    对应权限           目录:库和表      用户名和客户端主机        用户密码
grant      all privileges     on db01.*     to username@localhost   identified by ‘password’

1、一条命令创建用户并授权权限

mysql> select user,host,password from mysql.user;
+------+-----------+-------------------------------------------+
| user | host      | password                                  |
+------+-----------+-------------------------------------------+
| root | localhost | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
| root | 127.0.0.1 |                                           |
+------+-----------+-------------------------------------------+
2 rows in set (0.00 sec)

mysql> grant all privileges on db01.* to 'xiaoming'@'localhost' identified by '123456';
Query OK, 0 rows affected (0.00 sec)

mysql> select user,host,password from mysql.user;
+----------+-----------+-------------------------------------------+
| user     | host      | password                                  |
+----------+-----------+-------------------------------------------+
| root     | localhost | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
| root     | 127.0.0.1 |                                           |
| xiaoming | localhost | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
+----------+-----------+-------------------------------------------+
3 rows in set (0.00 sec)

mysql> show grants for 'xiaoming'@'localhost';
+-----------------------------------------------------------------------------------------------------------------+
| Grants for xiaoming@localhost                                                                                   |
+-----------------------------------------------------------------------------------------------------------------+
| GRANT USAGE ON *.* TO 'xiaoming'@'localhost' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9' |
| GRANT ALL PRIVILEGES ON `db01`.* TO 'xiaoming'@'localhost'                                                      |
+-----------------------------------------------------------------------------------------------------------------+
2 rows in set (0.00 sec)    

mysql> flush privileges;                    #==》一定要刷新,否则不生效
Query OK, 0 rows affected (0.00 sec)

2、先创建用户在授权权限

mysql> select user,host,password from mysql.user;
+------+-----------+-------------------------------------------+
| user | host      | password                                  |
+------+-----------+-------------------------------------------+
| root | localhost | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
| root | 127.0.0.1 |                                           |
+------+-----------+-------------------------------------------+
2 rows in set (0.00 sec)

mysql> create user 'zhangshang'@'localhost' identified by '123456';
Query OK, 0 rows affected (0.00 sec)

mysql> grant all privileges on db01.* to 'zhangshang'@'localhost';
Query OK, 0 rows affected (0.00 sec)

mysql> select user,host,password from mysql.user;
+------------+-----------+-------------------------------------------+
| user       | host      | password                                  |
+------------+-----------+-------------------------------------------+
| root       | localhost | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
| root       | 127.0.0.1 |                                           |
| zhangshang | localhost | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
+------------+-----------+-------------------------------------------+
3 rows in set (0.00 sec)

mysql> show grants for 'zhangshang'@'localhost';
+-------------------------------------------------------------------------------------------------------------------+
| Grants for zhangshang@localhost                                                                                   |
+-------------------------------------------------------------------------------------------------------------------+
| GRANT USAGE ON *.* TO 'zhangshang'@'localhost' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9' |
| GRANT ALL PRIVILEGES ON `db01`.* TO 'zhangshang'@'localhost'                                                      |
+-------------------------------------------------------------------------------------------------------------------+
2 rows in set (0.00 sec)

mysql> flush privileges;                #==》刷新权限
Query OK, 0 rows affected (0.00 sec)

mysql> help grant all                   #==》多查看帮忙,养成习惯

3、授权指定IP远程连接数据库

(1)、单独IP匹配
mysql> select user,host from mysql.user;
+------+-----------+
| user | host      |
+------+-----------+
| root | 127.0.0.1 |
| root | localhost |
+------+-----------+
2 rows in set (0.00 sec)

mysql> grant all privileges on db3.* to 'xiaozhang'@'10.0.0.200' identified by '123456';
Query OK, 0 rows affected (0.00 sec)

mysql> select user,host from mysql.user;
+-----------+------------+
| user      | host       |
+-----------+------------+
| xiaozhang | 10.0.0.200 |
| root      | 127.0.0.1  |
| root      | localhost  |
+-----------+------------+
3 rows in set (0.00 sec)

(2)、百分号匹配
mysql> select user,host from mysql.user;
+------+-----------+
| user | host      |
+------+-----------+
| root | 127.0.0.1 |
| root | localhost |
+------+-----------+
2 rows in set (0.00 sec)

mysql> grant all on db01.* to 'xiaoming'@'10.0.0.%' identified by '123456';
Query OK, 0 rows affected (0.01 sec)

mysql> select user,host from mysql.user;
+----------+-----------+
| user     | host      |
+----------+-----------+
| xiaoming | 10.0.0.%  |
| root     | 127.0.0.1 |
| root     | localhost |
+----------+-----------+
3 rows in set (0.00 sec)

(3)、网段匹配
mysql> select user,host from mysql.user;
+------+-----------+
| user | host      |
+------+-----------+
| root | 127.0.0.1 |
| root | localhost |
+------+-----------+
2 rows in set (0.00 sec)

mysql> grant all on db02.* to 'xiaohong'@'10.0.0.0/255.255.255.0' identified by '123456';
Query OK, 0 rows affected (0.00 sec)

mysql> select user,host from mysql.user;
+----------+------------------------+
| user     | host                   |
+----------+------------------------+
| xiaohong | 10.0.0.0/255.255.255.0 |
| root     | 127.0.0.1              |
| root     | localhost              |
+----------+------------------------+
3 rows in set (0.00 sec)

4、查看用户可以授权类别

mysql> show grants for 'xiaozhang'@'10.0.0.200';
+-------------------------------------------------------------------------------------------------------------------+
| Grants for [email protected]                                                                                   |
+-------------------------------------------------------------------------------------------------------------------+
| GRANT USAGE ON *.* TO 'xiaozhang'@'10.0.0.200' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9' |
| GRANT ALL PRIVILEGES ON `db3`.* TO 'xiaozhang'@'10.0.0.200'                                                       |
| GRANT ALL PRIVILEGES ON `db1`.* TO 'xiaozhang'@'10.0.0.200'                                                       |
+-------------------------------------------------------------------------------------------------------------------+
3 rows in set (0.00 sec)
mysql> revoke insert on db01.* from 'xiaozhang'@'10.0.0.200';        #==》指定撤回插入权限
Query OK, 0 rows affected (0.00 sec)

mysql> show grants for 'xiaozhang'@'10.0.0.200';
+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Grants for [email protected]                                                                                                                                                                                                   |
+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| GRANT USAGE ON *.* TO 'xiaozhang'@'10.0.0.200' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9'                                                                                                                 |
| GRANT ALL PRIVILEGES ON `db3`.* TO 'xiaozhang'@'10.0.0.200'                                                                                                                                                                       |
| GRANT SELECT, UPDATE, DELETE, CREATE, DROP, REFERENCES, INDEX, ALTER, CREATE TEMPORARY TABLES, LOCK TABLES, EXECUTE, CREATE VIEW, SHOW VIEW, CREATE ROUTINE, ALTER ROUTINE, EVENT, TRIGGER ON `db01`.* TO 'xiaozhang'@'10.0.0.200' |
+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
3 rows in set (0.00 sec)
#==》查看用户指定对应的表权限
mysql> select * from mysql.user where user='xiaozhang'\G    
mysql> help grant                                               #==》多查看帮忙,养成习惯

5、企业生产环境如何授权用户权限

常规情况下只授权  select/insert/update/delete  4个权限即可

八、MySQL回收指定权限或所有权限回收

mysql> show grants for 'xiaoming'@'localhost';
+-----------------------------------------------------------------------------------------------------------------+
| Grants for xiaoming@localhost                                                                                   |
+-----------------------------------------------------------------------------------------------------------------+
| GRANT USAGE ON *.* TO 'xiaoming'@'localhost' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9' |
| GRANT ALL PRIVILEGES ON `db01`.* TO 'xiaoming'@'localhost'                                                      |
+-----------------------------------------------------------------------------------------------------------------+
2 rows in set (0.00 sec)

mysql> revoke INSERT,SELECT,DELETE,UPDATE on db01.* from 'xiaoming'@'localhost';
Query OK, 0 rows affected (0.00 sec)

mysql> show grants for 'xiaoming'@'localhost';
+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Grants for xiaoming@localhost                                                                                                                                                                            |
+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| GRANT USAGE ON *.* TO 'xiaoming'@'localhost' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9'                                                                                          |
| GRANT CREATE, DROP, REFERENCES, INDEX, ALTER, CREATE TEMPORARY TABLES, LOCK TABLES, EXECUTE, CREATE VIEW, SHOW VIEW, CREATE ROUTINE, ALTER ROUTINE, EVENT, TRIGGER ON `db01`.* TO 'xiaoming'@'localhost' |
+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
2 rows in set (0.00 sec)
mysql> REVOKE ALL PRIVILEGES, GRANT OPTION FROM 'xiaoming'@'localhost';
Query OK, 0 rows affected (0.00 sec)

九、MySQL设置及修改用户密码
1、删除root管理用户,创建system管理员替换root管理用户(root与system等价)

mysql> select user,host from mysql.user;
+----------+-----------+
| user     | host      |
+----------+-----------+
| root     | 127.0.0.1 |
| root     | localhost |
| xiaoming | localhost |
+----------+-----------+
3 rows in set (0.00 sec)

mysql> drop user 'root'@'127.0.0.1';
Query OK, 0 rows affected (0.00 sec)

mysql> drop user 'root'@'localhost';
Query OK, 0 rows affected (0.02 sec)

mysql> drop user 'xiaoming'@'localhost';
Query OK, 0 rows affected (0.00 sec)

mysql> grant all privileges on *.* to 'system'@'localhost' identified by '123456' with grant option;
Query OK, 0 rows affected (0.00 sec)
mysql> grant all privileges on *.* to 'system'@'127.0.0.1' identified by '123456' with grant option;
Query OK, 0 rows affected (0.00 sec)
mysql> select user,host from mysql.user;
+--------+-----------+
| user   | host      |
+--------+-----------+
| system | 127.0.0.1 |
| system | localhost |
+--------+-----------+
2 rows in set (0.00 sec)
mysql> flush privileges;                #==》一定要刷新权限,否则不生效
Query OK, 0 rows affected (0.00 sec)
mysql> show grants for 'system'@'localhost';
+------------------------------------------------------------------------------------------------------------------------------------------+
| Grants for system@localhost                                                                                                              |
+------------------------------------------------------------------------------------------------------------------------------------------+
| GRANT ALL PRIVILEGES ON *.* TO 'system'@'localhost' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9' WITH GRANT OPTION |
+------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

2、MySQL修改密码三种方法

(1)、方法一:命令行外修改方法
[root@mysql ~]# mysqladmin -u root -p'123456'  password 'ssti123'
[root@mysql ~]# mysqladmin -u root -p  password 'ssti123'

(2)、方法二:sql语句update命令修改
标注:使用update命令修改用户密码,必须遵守两点:
(2.1)、必须指定where条件
(2.2)、必须使用password()函数加密更改密码,否则修改的账号密码登录失败
mysql> update mysql.user set password=password("123456") where user="root" and host="localhost";
Query OK, 1 row affected (0.00 sec)
Rows matched: 1  Changed: 1  Warnings: 0

mysql> flush privileges;                    #==》一定要刷新权限,否则不生效
Query OK, 0 rows affected (0.00 sec)

(3)、方法三:
标注:此命令只能修改当前登录用户的密码
mysql> set password=password("123456");
Query OK, 0 rows affected (0.00 sec)

mysql> flush privileges;                    #==》一定要刷新权限,否则不生效
Query OK, 0 rows affected (0.00 sec)

十、MySQL 表操作

语法格式:
create table <表名> (
    <字段名1> <类型1>,
    <字段名2> <类型2>,
    <字段名3> <类型3>,
<字段名1> <类型1>);

1、创建表

mysql> create database testdb DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci;
Query OK, 1 row affected (0.00 sec)

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| testdb             |
+--------------------+
4 rows in set (0.00 sec)

mysql> use testdb
Database changed
mysql>

#==》第一种建表语句
create table student(
id int(4) not null,
name char(20) not null,
aga tinyint(2) NOT NULL default '0',
dept varchar(16) default NULL
);

#==》第二种建表语句
create table student02(
`id` int(4) not null,                         #==》学号,数字类型,长度为4,不为空值
`name` char(20) not null,                     #==》姓名,定长字符类型,长度为20,不为空值
`aga` tinyint(2) NOT NULL default '0',        #==》年龄,数字类型,长度为2,不为空,默认0值 
`dept` varchar(16) default NULL               #==》系,变长字符类型,长度为16,默认为空
)ENGINE=InnoDB DEFAULT CHARSET=gbk;           #==》引擎和字符集,默认引擎为InnoDB,字符集,继承库的gbk

2、查看表结构

mysql> use testdb
Database changed
mysql> show tables;
+------------------+
| Tables_in_testdb |
+------------------+
| student          |
+------------------+
1 row in set (0.00 sec)
mysql> show create table student\G                            #==》查已建表的语句(可看索引及创建表的信息)
*************************** 1. row ***************************
       Table: student
Create Table: CREATE TABLE `student` (
  `id` int(4) NOT NULL,
  `name` char(20) NOT NULL,
  `aga` tinyint(2) NOT NULL DEFAULT '0',
  `dept` varchar(16) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=gbk
1 row in set (0.00 sec)
mysql> desc student;                                           #==》查看表结构
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id    | int(4)      | NO   |     | NULL    |       |
| name  | char(20)    | NO   |     | NULL    |       |
| aga   | tinyint(2)  | NO   |     | 0       |       |
| dept  | varchar(16) | YES  |     | NULL    |       |
+-------+-------------+------+-----+---------+-------+
4 rows in set (0.00 sec)
mysql> show columns from student;
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id    | int(4)      | NO   |     | NULL    |       |
| name  | char(20)    | NO   |     | NULL    |       |
| aga   | tinyint(2)  | NO   |     | 0       |       |
| dept  | varchar(16) | YES  |     | NULL    |       |
+-------+-------------+------+-----+---------+-------+
4 rows in set (0.00 sec)

十一、表插入数据insert

命令格式: insert inot <表名>(字段1,字段2…….) values(值1,值2…….)
表插入优化之一:insert inot 插入数据尽量批量插入

mysql> 
create table student(
id int(4) not null AUTO_INCREMENT,
name char(20) not null,
primary key(`id`)
);
Query OK, 0 rows affected (0.03 sec)

mysql> show tables;
mysql> show create table student;
mysql> desc student;
+-------+----------+------+-----+---------+----------------+
| Field | Type     | Null | Key | Default | Extra          |
+-------+----------+------+-----+---------+----------------+
| id    | int(4)   | NO   | PRI | NULL    | auto_increment |
| name  | char(20) | NO   |     | NULL    |                |
+-------+----------+------+-----+---------+----------------+
2 rows in set (0.00 sec)
mysql> select * from student;
Empty set (0.00 sec)
mysql> insert into student(id,name) values(1,'xiaoming');
Query OK, 1 row affected (0.01 sec)

mysql> insert into student(id,name) values(2,'zhangshang'); #==》一条数据插入
Query OK, 1 row affected (0.00 sec)

mysql> insert into student(id,name) values(3,'lishi');
Query OK, 1 row affected (0.01 sec)

mysql> select * from student;
+----+------------+
| id | name       |
+----+------------+
|  1 | xiaoming   |
|  2 | zhangshang |
|  3 | lishi      |
+----+------------+
mysql> insert into student(id,name) values(4,'wangwu'),(5,'Tom');  #==》批量插入数据
Query OK, 2 rows affected (0.00 sec)
Records: 2  Duplicates: 0  Warnings: 0

mysql> select * from student;
+----+------------+
| id | name       |
+----+------------+
|  1 | xiaoming   |
|  2 | zhangshang |
|  3 | lishi      |
|  4 | wangwu     |
|  5 | Tom        |
+----+------------+
5 rows in set (0.00 sec)
3 rows in set (0 mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec).00 sec)
mysql> help insert

十二、表查询数据select

命令格式:select  <字段1>,<字段2>……  from  <表名>  where  <表达式>,其中,select/from/where不能随便改,支持大小写
表查询优化之一:select 查询尽量指定明确的字段,这样查询效率高

1、单表查询

mysql> use testdb
Database changed
mysql> select * from student;
+----+------------+
| id | name       |
+----+------------+
|  1 | xiaoming   |
|  2 | zhangshang |
|  3 | lishi      |
|  4 | wangwu     |
|  5 | Tom        |
+----+------------+
5 rows in set (0.00 sec)

mysql> select id,name from student;
+----+------------+
| id | name       |
+----+------------+
|  1 | xiaoming   |
|  2 | zhangshang |
|  3 | lishi      |
|  4 | wangwu     |
|  5 | Tom        |
+----+------------+
5 rows in set (0.00 sec)
mysql> select id,name from student limit 2;
+----+------------+
| id | name       |
+----+------------+
|  1 | xiaoming   |
|  2 | zhangshang |
+----+------------+
2 rows in set (0.00 sec)
mysql> select id,name from student where id=1;
+----+----------+
| id | name     |
+----+----------+
|  1 | xiaoming |
+----+----------+
1 row in set (0.00 sec)
mysql> select id,name from student where id > 1 and id < 3;
+----+------------+
| id | name       |
+----+------------+
|  2 | zhangshang |
+----+------------+
1 row in set (0.00 sec)
mysql> select id,name from student where name='xiaoming' or id=3;
+----+----------+
| id | name     |
+----+----------+
|  1 | xiaoming |
|  3 | lishi    |
+----+----------+
2 rows in set (0.00 sec)

2、多表查询

mysql> select * from student01;
+----+------------+-------+
| id | name       | class |
+----+------------+-------+
|  1 | xiaoming   | 1班   |
| 21 | xiaozhang  | 2班   |
| 33 | xiaohong   | 2班   |
|  2 | xiaocheng  | 2班   |
|  3 | zhangshang | 3班   |
|  4 | lishi      | 3班   |
+----+------------+-------+
6 rows in set (0.00 sec)

mysql> select * from grade;
+----+--------+---------+
| id | course | chengji |
+----+--------+---------+
|  1 | shuxue | 78      |
| 21 | shuxue | 88      |
|  2 | shuxue | 93      |
|  3 | shuxue | 45      |
+----+--------+---------+
4 rows in set (0.00 sec)

mysql>select student01.id,student01.name,grade.course,grade.chengji from student01,grade where student01.id=grade.id;
+----+------------+--------+---------+
| id | name       | course | chengji |
+----+------------+--------+---------+
|  1 | xiaoming   | shuxue | 78      |
| 21 | xiaozhang  | shuxue | 88      |
|  2 | xiaocheng  | shuxue | 93      |
|  3 | zhangshang | shuxue | 45      |
+----+------------+--------+---------+
4 rows in set (0.00 sec)

十三、使用explain查询select 查询语句执行计划,即可以判断是否引用索引情况

mysql> desc student;
+-------+----------+------+-----+---------+----------------+
| Field | Type     | Null | Key | Default | Extra          |
+-------+----------+------+-----+---------+----------------+
| id    | int(4)   | NO   | PRI | NULL    | auto_increment |
| name  | char(20) | NO   |     | NULL    |                |
+-------+----------+------+-----+---------+----------------+
2 rows in set (0.01 sec)

mysql> select * from student;
+----+------------+
| id | name       |
+----+------------+
|  1 | xiaoming   |
|  2 | zhangshang |
|  3 | lishi      |
|  4 | wangwu     |
|  5 | Tom        |
+----+------------+
5 rows in set (0.00 sec)

mysql> explain select id,name from student where name="wangwu"\G
*************************** 1. row ***************************
           id: 1
  select_type: SIMPLE
        table: student
         type: ALL
possible_keys: NULL
          key: NULL
      key_len: NULL
          ref: NULL
         rows: 5
        Extra: Using where
1 row in set (0.00 sec)

mysql> desc student;
+-------+----------+------+-----+---------+----------------+
| Field | Type     | Null | Key | Default | Extra          |
+-------+----------+------+-----+---------+----------------+
| id    | int(4)   | NO   | PRI | NULL    | auto_increment |
| name  | char(20) | NO   | MUL | NULL    |                |
+-------+----------+------+-----+---------+----------------+
2 rows in set (0.00 sec)

mysql> explain select id,name from student where name="wangwu"\G
*************************** 1. row ***************************
           id: 1
  select_type: SIMPLE
        table: student
         type: ref
possible_keys: index_name
          key: index_name
      key_len: 40
          ref: const
         rows: 1
        Extra: Using where; Using index
1 row in set (0.00 sec)

mysql> help explain                           #==》多查看帮助

十四、修改表中指定条件固定列数据update

命令格式:  update <表名>  set 字段=新值 where 条件(一定要添加条件并且注意条件)
注意:如果update后面没有添加where条件语句会把表中的数据都修改了,这是很严重的问题。

mysql> select * from student;
+----+------------+
| id | name       |
+----+------------+
|  3 | lishi      |
|  5 | Tom        |
|  4 | wangwu     |
|  1 | xiaoming   |
|  2 | zhangshang |
+----+------------+
5 rows in set (0.00 sec)
mysql> update student set name='oldboy' where name='Tom';
Query OK, 1 row affected (0.01 sec)
Rows matched: 1  Changed: 1  Warnings: 0

mysql> select * from student;
+----+------------+
| id | name       |
+----+------------+
|  3 | lishi      |
|  5 | oldboy     |
|  4 | wangwu     |
|  1 | xiaoming   |
|  2 | zhangshang |
+----+------------+
5 rows in set (0.00 sec)

update防止误更新(update)操作办法
[root@mysql ~]# echo " alias mysql='mysql -U'" >> /etc/profile
[root@mysql ~]# tail -1 /etc/profile
 alias mysql='mysql -U'
[root@mysql ~]# mysql -uroot -p123456
mysql> use testdb
Database changed
mysql> select * from student;
+----+------------+
| id | name       |
+----+------------+
|  3 | lishi      |
|  5 | oldboy     |
|  4 | wangwu     |
|  1 | xiaoming   |
|  2 | zhangshang |
+----+------------+
5 rows in set (0.00 sec)
mysql> update student set name="oldgirl";
#==》报错原因是没有添加where条件,防止update误操作更新
ERROR 1175 (HY000): You are using safe update mode and you tried to update a table without a WHERE that uses a KEY column

mysql> update student set name="oldgirl" where id=2;
Query OK, 1 row affected (0.00 sec)
Rows matched: 1  Changed: 1  Warnings: 0

mysql> select * from student;
+----+----------+
| id | name     |
+----+----------+
|  3 | lishi    |
|  5 | oldboy   |
|  2 | oldgirl  |
|  4 | wangwu   |
|  1 | xiaoming |
+----+----------+
5 rows in set (0.00 sec)

十五、删除表中数据delete

命令格式: delete from <表名> where 条件(delete一定要加条件,否则整个表都会删除,此命令操作需要谨慎)

1、delete 删除表中数据(逻辑一行一行删除)

mysql> use testdb
Database changed
mysql> select * from student;
+----+----------+
| id | name     |
+----+----------+
|  3 | lishi    |
|  5 | oldboy   |
|  2 | oldgirl  |
|  4 | wangwu   |
|  1 | xiaoming |
+----+----------+
5 rows in set (0.00 sec)

mysql> delete from student where id=4 and name='wangwu';
Query OK, 1 row affected (0.02 sec)

mysql> select * from student;
+----+----------+
| id | name     |
+----+----------+
|  3 | lishi    |
|  5 | oldboy   |
|  2 | oldgirl  |
|  1 | xiaoming |
+----+----------+
4 rows in set (0.00 sec)
mysql> delete from student where id>4;
Query OK, 1 row affected (0.01 sec)

mysql> select * from student;
+----+----------+
| id | name     |
+----+----------+
|  3 | lishi    |
|  2 | oldgirl  |
|  1 | xiaoming |
+----+----------+
3 rows in set (0.00 sec)

2、truncate 清空表中所有内容(物理清空,直接删除文件)

mysql> select * from student;
+----+----------+
| id | name     |
+----+----------+
|  3 | lishi    |
|  2 | oldgirl  |
|  1 | xiaoming |
+----+----------+
3 rows in set (0.00 sec)

mysql> truncate table student;                      #==》此命令操作需要谨慎
Query OK, 0 rows affected (0.01 sec)
mysql> select * from student;
Empty set (0.00 sec)

十六、增删改表中的字段 alter table

命令格式:alter table <表名> add 字段 类型  其它;
mysql> desc student;
+-------+----------+------+-----+---------+----------------+
| Field | Type     | Null | Key | Default | Extra          |
+-------+----------+------+-----+---------+----------------+
| id    | int(4)   | NO   | PRI | NULL    | auto_increment |
| name  | char(20) | NO   | MUL | NULL    |                |
+-------+----------+------+-----+---------+----------------+
2 rows in set (0.00 sec)

#==》默认age字段添加在表中最后一列
mysql> alter table student add age int(3);
Query OK, 4 rows affected (0.06 sec)
Records: 4  Duplicates: 0  Warnings: 0

mysql> desc student;
+-------+----------+------+-----+---------+----------------+
| Field | Type     | Null | Key | Default | Extra          |
+-------+----------+------+-----+---------+----------------+
| id    | int(4)   | NO   | PRI | NULL    | auto_increment |
| name  | char(20) | NO   | MUL | NULL    |                |
| age   | int(3)   | YES  |     | NULL    |                |
+-------+----------+------+-----+---------+----------------+
3 rows in set (0.00 sec)

#==》指定在name字段后面添加sex字段
mysql> alter table student add sex char(6) after name;      
Query OK, 4 rows affected (0.04 sec)
Records: 4  Duplicates: 0  Warnings: 0

mysql> desc student;
+-------+----------+------+-----+---------+----------------+
| Field | Type     | Null | Key | Default | Extra          |
+-------+----------+------+-----+---------+----------------+
| id    | int(4)   | NO   | PRI | NULL    | auto_increment |
| name  | char(20) | NO   | MUL | NULL    |                |
| sex   | char(6)  | YES  |     | NULL    |                |
| age   | int(3)   | YES  |     | NULL    |                |
+-------+----------+------+-----+---------+----------------+
4 rows in set (0.00 sec)
#==》指定xuehao字段s添加到表中第一列
mysql> alter table student add xuehao int(10) first;    
Query OK, 4 rows affected (0.15 sec)
Records: 4  Duplicates: 0  Warnings: 0

mysql> desc student;
+--------+----------+------+-----+---------+----------------+
| Field  | Type     | Null | Key | Default | Extra          |
+--------+----------+------+-----+---------+----------------+
| xuehao | int(10)  | YES  |     | NULL    |                |
| id     | int(4)   | NO   | PRI | NULL    | auto_increment |
| name   | char(20) | NO   | MUL | NULL    |                |
| sex    | char(6)  | YES  |     | NULL    |                |
| age    | int(3)   | YES  |     | NULL    |                |
+--------+----------+------+-----+---------+----------------+
5 rows in set (0.00 sec)

#==》删除指定xuehao字段
mysql> alter table student drop xuehao;
Query OK, 4 rows affected (0.04 sec)
Records: 4  Duplicates: 0  Warnings: 0

mysql> desc student;
+-------+----------+------+-----+---------+----------------+
| Field | Type     | Null | Key | Default | Extra          |
+-------+----------+------+-----+---------+----------------+
| id    | int(4)   | NO   | PRI | NULL    | auto_increment |
| name  | char(20) | NO   | MUL | NULL    |                |
| sex   | char(6)  | YES  |     | NULL    |                |
| age   | int(3)   | YES  |     | NULL    |                |
+-------+----------+------+-----+---------+----------------+
4 rows in set (0.00 sec)
#==》修改age字段类型int型修改为char型
mysql> alter table student modify age char(20);
Query OK, 4 rows affected (0.04 sec)
Records: 4  Duplicates: 0  Warnings: 0

mysql> desc student;
+-------+----------+------+-----+---------+----------------+
| Field | Type     | Null | Key | Default | Extra          |
+-------+----------+------+-----+---------+----------------+
| id    | int(4)   | NO   | PRI | NULL    | auto_increment |
| name  | char(20) | NO   | MUL | NULL    |                |
| sex   | char(6)  | YES  |     | NULL    |                |
| age   | char(20) | YES  |     | NULL    |                |
+-------+----------+------+-----+---------+----------------+
4 rows in set (0.00 sec) 

#==》修改age字段名称及类型
mysql> alter table student change age kecheng varchar(10);
Query OK, 4 rows affected (0.05 sec)
Records: 4  Duplicates: 0  Warnings: 0

mysql> desc student;
+---------+-------------+------+-----+---------+----------------+
| Field   | Type        | Null | Key | Default | Extra          |
+---------+-------------+------+-----+---------+----------------+
| id      | int(4)      | NO   | PRI | NULL    | auto_increment |
| name    | char(20)    | NO   | MUL | NULL    |                |
| sex     | char(6)     | YES  |     | NULL    |                |
| kecheng | varchar(10) | YES  |     | NULL    |                |
+---------+-------------+------+-----+---------+----------------+
4 rows in set (0.00 sec)

十七、修改表名rename

mysql> show tables;
+------------------+
| Tables_in_testdb |
+------------------+
| student          |
+------------------+
1 row in set (0.00 sec)

mysql> rename table student to xuesheng;
Query OK, 0 rows affected (0.00 sec)

mysql> show tables;
+------------------+
| Tables_in_testdb |
+------------------+
| xuesheng         |
+------------------+
1 row in set (0.00 sec)

mysql> alter table xuesheng rename to student;
Query OK, 0 rows affected (0.01 sec)

mysql> show tables;
+------------------+
| Tables_in_testdb |
+------------------+
| student          |
+------------------+
1 row in set (0.00 sec)

十八、删除表或库 drop

1、删除库

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| testdb             |
| wiki               |
+--------------------+
5 rows in set (0.00 sec)
mysql> drop database wiki;              #==》删除wiki库
Query OK, 0 rows affected (0.02 sec)
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| testdb             |
+--------------------+
4 rows in set (0.00 sec)

2、删除表

mysql> use testdb
Database changed
mysql> show tables;
+------------------+
| Tables_in_testdb |
+------------------+
| bk01             |
| student          |
+------------------+
2 rows in set (0.00 sec)

mysql> drop table bk01;
Query OK, 0 rows affected (0.00 sec)

mysql> show tables;
+------------------+
| Tables_in_testdb |
+------------------+
| student          |
+------------------+
1 row in set (0.00 sec)

你可能感兴趣的:(MySQL 基础SQL语句)