mysql最佳入门_MySQL入门教学(看完必懂,图文详解!)

SQL 基础使用

MySQL 是一种关系型数据库,说到关系,那么就离不开表与表之间的关系,而最能体现这种关系的其实就是我们接下来需要介绍的主角 SQL,SQL 的全称是 Structure Query Language ,结构化的查询语言,它是一种针对表关联关系所设计的一门语言,也就是说,学好 MySQL,SQL 是基础和重中之重。SQL 不只是 MySQL 中特有的一门语言,大多数关系型数据库都支持这门语言。

下面我们就来一起学习一下这门非常重要的语言。

查询语言分类

在了解 SQL 之前我们需要知道下面这几个概念

数据定义语言: 简称DDL (Data Definition Language),用来定义数据库对象:数据库、表、列等;

数据操作语言: 简称DML (Data Manipulation Language),用来对数据库中表的记录进行更新。关键字: insert、update、delete等

数据控制语言: 简称DCL(Data Control Language),用来定义数据库访问权限和安全级别,创建用户等。关键字: grant等

数据查询语言: 简称DQL(Data Query Language),用来查询数据库中表的记录,关键字: select from where等

DDL 语句

创建数据库

下面就开始我们的 SQL 语句学习之旅,首先你需要启动 MySQL 服务,我这里是 mac 电脑,所以我直接可以启动

mysql最佳入门_MySQL入门教学(看完必懂,图文详解!)_第1张图片

然后我们使用命令行的方式连接数据库,打开 iterm,输入下面

MacBook:~ mr.l$ mysql -uroot -p

就可以连接到数据库了

mysql最佳入门_MySQL入门教学(看完必懂,图文详解!)_第2张图片

在上面命令中,mysql 代表客户端命令,- u 表示后面需要连接的用户,-p 表示需要输入此用户的密码。在你输入用户名和密码后,如果成功登陆,会显示一个欢迎界面(如上图 )和 mysql> 提示符。

欢迎界面主要描述了这些东西

每一行的结束符,这里用 ; 或者 \g 来表示每一行的结束

Your MySQL connection id is 4,这个记录了 MySQL 服务到目前为止的连接数,每个新链接都会自动增加 1 ,上面显示的连接次数是 4 ,说明我们只连接了四次

然后下面是 MySQL 的版本,我们使用的是 5.7

通过 help 或者 \h 命令来显示帮助内容,通过 \c 命令来清除命令行 buffer。

然后需要做的事情是什么?我们最终想要学习 SQL 语句,SQL 语句肯定是要查询数据,通过数据来体现出来表的关联关系,所以我们需要数据,那么数据存在哪里呢?数据存储的位置被称为 表(table),表存储的位置被称为 数据库(database),所以我们需要先建数据库后面再建表然后插入数据,再进行查询。

mysql最佳入门_MySQL入门教学(看完必懂,图文详解!)_第3张图片

所以我们首先要做的就是创建数据库,创建数据库可以直接使用指令

CREATE DATABASE dbname;

进行创建,比如我们创建数据库 cxuandb

create database cxuandb;

注意最后的 ; 结束语法一定不要丢掉,否则 MySQL 会认为你的命令没有输出完,敲 enter 后会直接换行输出

mysql最佳入门_MySQL入门教学(看完必懂,图文详解!)_第4张图片

创建完成后,会提示 Query OK, 1 row affected,这段语句什么意思呢? Query OK 表示的就是查询完成,为什么会显示这个?因为所有的 DDL 和 DML 操作执行完成后都会提示这个, 也可以理解为操作成功。后面跟着的 **1 row affected ** 表示的是影响的行数,() 内显示的是你执行这条命令所耗费的时间,也就是 0.03 秒。

上图我们成功创建了一个 cxuandb 的数据库,此时我们还想创建一个数据库,我们再执行相同的指令,结果提示

447d1250bcf82d1e88ddd1e8e1c69971.png

提示我们不能再创建数据库了,数据库已经存在。这时候我就有疑问了,我怎么知道都有哪些数据库呢?别我再想创建一个数据库又告诉我已经存在,这时候可以使用 show databases 命令来查看你的 MySQL 已有的数据库

show databases;

执行完成后的结果如下

mysql最佳入门_MySQL入门教学(看完必懂,图文详解!)_第5张图片

因为数据库我之前已经使用过,这里就需要解释一下,除了刚刚新创建成功的 cxuandb 外,informationn_schema 、performannce_schema 和 sys 都是系统自带的数据库,是安装 MySQL 默认创建的数据库。它们各自表示

informationn_schema: 主要存储一些数据库对象信息,比如用户表信息、权限信息、分区信息等

performannce_schema: MySQL 5.5 之后新增加的数据库,主要用于收集数据库服务器性能参数。

sys: MySQL 5.7 提供的数据库,sys 数据库里面包含了一系列的存储过程、自定义函数以及视图来帮助我们快速的了解系统的元数据信息。

其他所有的数据库都是作者自己创建的,可以忽略他们。

在创建完数据库之后,可以用如下命令选择要操作的数据库

use cxuandb

这样就成功切换为了 cxuandb 数据库,我们可以在此数据库下进行建表、查看基本信息等操作。

mysql最佳入门_MySQL入门教学(看完必懂,图文详解!)_第6张图片

比如想要看康康我们新建的数据库里面有没有其他表

show tables;

果然,我们新建的数据库下面没有任何表,但是现在,我们还不进行建表操作,我们还是先来认识一下数据库层面的命令,也就是其他 DDL 指令

删除数据库

如果一个数据库我们不想要了,那么该怎么办呢?直接删掉数据库不就好了吗?删表语句是

drop database dbname;

比如 cxuandb 我们不想要他了,可以通过使用

drop database cxuandb;

进行删除,这里我们就不进行演示了,因为 cxuandb 我们后面还会使用。

但是这里注意一点,你删除数据库成功后会出现 0 rows affected,这个可以不用理会,因为在 MySQL 中,drop 语句操作的结果都是 0 rows affected。

创建表

下面我们就可以对表进行操作了,我们刚刚 show tables 发现还没有任何表,所以我们现在进行建表语句

CREATE TABLE 表名称

(

列名称1 数据类型 约束,

列名称2 数据类型 约束,

列名称3 数据类型 约束,

....

)

这样就很清楚了吧,列名称就是列的名字,紧跟着列名后面就是数据类型,然后是约束,为什么要这么设计?举个例子你就清楚了,比如 cxuan 刚被生出来就被打印上了标签

mysql最佳入门_MySQL入门教学(看完必懂,图文详解!)_第7张图片

比如我们创建一个表,里面有 5 个字段,姓名(name)、性别(sex)、年龄(age)、何时雇佣(hiredate)、薪资待遇(wage),建表语句如下

create table job(name varchar(20), sex varchar(2), age int(2), hiredate date, wage decimal(10,2));

事实证明这条建表语句还是没问题的,建表完成后可以使用 DESC tablename 查看表的基本信息

mysql最佳入门_MySQL入门教学(看完必懂,图文详解!)_第8张图片

DESC 命令会查看表的定义,但是输出的信息还不够全面,所以,如果想要查看更全的信息,还要通过查看表的创建语句的 SQL 来得到

show create table job \G;

mysql最佳入门_MySQL入门教学(看完必懂,图文详解!)_第9张图片

可以看到,除了看到表定义之外,还看到了表的 engine(存储引擎) 为 InnoDB 存储引擎,\G 使得记录能够竖着排列,如果不用 \G 的话,效果如下

mysql最佳入门_MySQL入门教学(看完必懂,图文详解!)_第10张图片

删除表

表的删除语句有两种,一种是 drop 语句,SQL 语句如下

drop table job

一种是 truncate 语句,SQL 语句如下

truncate table job

这两者的区别简单理解就是 drop 语句删除表之后,可以通过日志进行回复,而 truncate 删除表之后永远恢复不了,所以,一般不使用 truncate 进行表的删除。‘

修改表

对于已经创建好的表,尤其是有大量数据的表,如果需要对表做结构上的改变,可以将表删除然后重新创建表,但是这种效率会产生一些额外的工作,数据会重新加载近来,如果此时有服务正在访问的话,也会影响服务读取表中数据,所以此时,我们需要表的修改语句来对已经创建好的表的定义进行修改。

修改表结构一般使用 alter table 语句,下面是常用的命令

ALTER TABLE tb MODIFY [COLUMN] column_definition [FIRST | AFTER col_name];

比如我们想要将 job 表中的 name 由 varchar(20) 改为 varchar(25),可以使用如下语句

alter table job modify name varchar(25);

mysql最佳入门_MySQL入门教学(看完必懂,图文详解!)_第11张图片

也可以对表结构进行修改,比如增加一个字段

alter table job add home varchar(30);

mysql最佳入门_MySQL入门教学(看完必懂,图文详解!)_第12张图片

将新添加的表的字段进行删除

alter table job drop column home;

mysql最佳入门_MySQL入门教学(看完必懂,图文详解!)_第13张图片

可以对表中字段的名称进行修改,比如吧 wage 改为 salary

alter table job change wage salary decimal(10,2);

e4b7bec64fdef130ac66a74568761f9d.png

修改字段的排列顺序,我们前面介绍过修改语法涉及到一个顺序问题,都有一个可选项 **first | after ** column_name,这个选项可以用来修改表中字段的位置,默认 ADD 是在添加为表中最后一个字段,而 CHANGE/MODIFY 不会改变字段位置。比如

alter table job add birthday after hiredate;

mysql最佳入门_MySQL入门教学(看完必懂,图文详解!)_第14张图片

可以对表名进行修改,例如将 job 表改为 worker

alter table job rename worker;

DML 语句

有的地方把 DML 语句(增删改)和 DQL 语句(查询)统称为 DML 语句,有的地方分开,我们目前使用分开称呼的方式

插入

表创建好之后,我们就可以向表里插入数据了,插入记录的基本语法如下

INSERT INTO tablename (field1,field2) VALUES(value1,value2);

例如,向中插入以下记录

insert into job(name,sex,age,hiredate,birthday,salary) values("cxuan","男",24,"2020-04-27","1995-08-22",8000);

也可以不用指定要插入的字段,直接插入数据即可

insert into job values("cxuan02","男",25,"2020-06-01","1995-04-23",12000);

这里就有一个问题,如果插入的顺序不一致的话会怎么样呢?

对于含可空字段、非空但是含有默认值的字段、自增字段可以不用在 insert 后的字段列表出现,values 后面只需要写对应字段名称的 value 即可,没有写的字段可以自动的设置为 NULL、默认值或者自增的下一个值,这样可以缩短要插入 SQL 语句的长度和复杂性。

比如我们设置一下 hiredate、age 可以为 null,来试一下

insert into job(name,sex,birthday,salary) values("cxuan03","男","1992-08-23",15000);

fecb52c3810382c90fe12a7537354ab7.png

我们看一下实际插入的数据

mysql最佳入门_MySQL入门教学(看完必懂,图文详解!)_第15张图片

我们可以看到有一行两个字段显示 NULL。在 MySQL 中,insert 语句还有一个很好的特性,就是一次可以插入多条记录

INSERT INTO tablename (field1,field2) VALUES

(value1,value2),

(value1,value2),

(value1,value2),

...;

可以看出,每条记录之间都用逗号进行分割,这个特性可以使得 MySQL 在插入大量记录时,节省很多的网络开销,大大提高插入效率。

更新记录

对于表中已经存在的数据,可以通过 update 命令对其进行修改,语法如下

UPDATE tablename SET field1 = value1, field2 = value2 ;

例如,将 job 表中的 cxuan03 中 age 的 NULL 改为 26,SQL 语句如下

update job set age = 26 where name = 'cxuan03';

SQL 语句中出现了一个 where 条件,我们会在后面说到 where 条件,这里简单理解一下它的概念就是根据哪条记录进行更新,如果不写 where 的话,会对整个表进行更新

删除记录

如果记录不再需要,可以使用 delete 命令进行删除

DELETE FROM tablename [WHERE CONDITION]

例如,在 job 中删除名字是 cxuan03 的记录

delete from job where name = 'cxuan03';

a516c0e232a8ff026beb2d804cf3f597.png

在 MySQL 中,删除语句也可以不指定 where 条件,直接使用

delete from job

这种删除方式相当于是清楚表的操作,表中所有的记录都会被清除。

DQL 语句

下面我们一起来认识一下 DQL 语句,数据被插入到 MySQL 中,就可以使用 SELECT 命令进行查询,来得到我们想要的结果。

SELECT 查询语句可以说是最复杂的语句了,这里我们只介绍一下基本语

你可能感兴趣的:(mysql最佳入门)