MySQL 的 SQL语句

1、SQL语句
2、库相关
3、表相关
4、查询语句
1、SQL

Structured Query Language,结构化查询语言,当然是对数据库进行操作的语言。
虽然被称为查询语言,但是数据查询、数据定义、数据操纵和数据控制样样俱全。
MySQL里,SQL语句都要以或者\G\g结尾。

2、库相关的SQL语句

1)查看所有的库:show databases;
在这里插入图片描述
2)创建库:create database database_name;
3)删除库:rm -rf,哦不对,跨行了
正确的,drop database dabase_name;
4)选择某个数据库:use database_name;
在这里插入图片描述
如图表示成功切换数据库,如果不成功就会有各种各样的错误,这你不用担心哦。
5)展示当前库下所有的表:show tables;
在这里插入图片描述
数据库跟数据库中表的关系;
在这里插入图片描述

3、表相关的SQL语句

1)创建表

create table table_name (
属性名 数据类型 完整性约束(可有可无),
属性名 数据类型 完整性约束,
......
属性名 数据类型 完整性约束
);

注意:创建表时要选取合适的数据类型,而且要按照用途添加不同的完整性约束。
完整性约束有:primary key 、foreign key 、not null 、unique 、auto-increment 、default
见名知义。
约束的概念性知识

2)查看表,两种方式
desc table_name,展示了表的属性名、数据类型、完整性约束
在这里插入图片描述
show create table table_name,比上面的多展示了表的存储引擎和字符集编码
分号结尾:
在这里插入图片描述
\G结尾:
在这里插入图片描述
这里要说一下,MySQL插入中文失败的处理方法,别人的详细的处理网址,值得说的是,如果当前表已经建好,需要更改当前表的编码;要不就重新建表即可。

3)修改表
①修改表名:
alter table old_table_name rename (to) new_name;
②修改表中某个属性的数据类型
alter table table_name modify 属性名 新的数据类型;
③修改表中某个属性的名字,这个SQL语句同时可修改该属性的数据类型
alter table table_name change 旧属性名 新属性名 新数据类型;
④增加新的字段
alter table table_name add 属性名 数据类型 (完整性约束) (first/after 属性名2);
(first/after 属性名2),嗯,可以指定该属性跟其它属性的位置前后关系。
⑤修改属性的排列位置
alter table table_name modify 属性名 数据类型 (first/after 属性名2);
⑥删除某个属性
alter table table_name drop 属性名;
⑦修改表的存储引擎
alter table table_name engine = (Innodb/Myisam);
MySQL默认引擎是innodb
4)表中插数据
insert into table_name (属性名1,属性名2,...,属性名n) values (各个属性对应的值);
批量插入:

insert into table table_name (属性名1,属性名2...,属性名n) values 
(各个属性对应的值),
(各个属性对应的值),
...
(各个属性对应的值);

5)删除表:
drop table tabel_name;

4、一些简单的查询语句

突然发现为了演示截了好多图,那就把这些简单的语句、结论放在上面,感兴趣的童鞋可以下翻好好看看每个SQL语句的展示。
1)基础查询
select 属性列表 from table_name (where 条件);
2)带in的子查询
(not) in+某几个筛选条件
select * from table_name where 属性名 in (?,?,?);
3)带 (not) between and的范围查找
select * from table_name where 属性名 (not) between 条件1 and 条件2;
这个条件是包括条件1和条件2在内的,而且条件1的要小于条件2。
4)带like的匹配查询
比如说某些时候,你只知道某个属性名的部分
可以,用 like +
_,代替一个字符
%,代替一堆
无论什么类型数据,使用模糊查询都要放在''里面
select * from goods where name like '海上灵_';
select * from goods where num like '_0';
select * from goods where name like '%杀%';
5)空值查询,某个字段没有值称为空值
is (not) null
select * from table_name where 属性名 is (not) null;
6)带and的多条件查询,and条件都要满足才能筛选出来
select * form table_name where 属性名1 条件1 and 属性名1 条件2 and 属性名n 条件n;
7)带or的多条件查询,只要满足or条件的都会被筛选出来
select * from table_name where 属性名1 条件1 or 属性名1 条件2 or 属性名n 条件n;
8)去重复查询
select distinct 属性名 from table_name;
9)对结果排序
order by 属性名 (asc、升序(默认)/desc、降序)
select * from table_name order by 属性名 (asc/desc);
10)分组查询
group by 属性名 having 条件
select * from goods group by 属性名 having 条件;
分组查询就是相同的属性名的值只会出现一次,而且是表中第一次出现的。
11)limit分页查询
select * from table_name limit n;表示查找该表的前n个,下标从0开始
select * from table_name limit n,m;表示从该表第n行开始,查找m行,依旧从0开始
多表查询
12)内连接
select * from 表1 inner join 表2 on 连接条件 where 条件;
将连接的两个表存在的相等的属性名获取

外连接
13)左连接
将左表对应的数据全部显示,这些数据,左表存在、右表不存在的,将右表对应的属性名(字段名)的值全部填充为NULL
14)右连接
将右表对应的数据全部显示,这些数据中,右表存在、左表不存在的,将左表对应的属性名(字段名)的值全部填充为NULL
详细展示
1)基础查询

select 属性列表 from table_name (where 条件); 

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
2)带in的子查询
(not) in+某几个筛选条件

select * from table_name where 属性名 in (?,?,?);

符合这几个问号的条件就会被搞出来。
在这里插入图片描述
在这里插入图片描述
3)带 (not) between and的范围查找

select * from table_name where 属性名 (not) between 条件1 and 条件2;

在这里插入图片描述
在这里插入图片描述

4)带like的匹配查询
比如说某些时候,你只知道某个属性名的部分
可以,用 like +
_,代替一个字符
%,代替一堆
无论什么类型数据,使用模糊查询都要放在''里面
like:

select * from goods where name like '海_灵光';
select * from goods where name like '_上灵光';
select * from goods where name like '海上灵_';
select * from goods where num like '_0';

_一次只能代替一个字符
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
%代替好几个

select * from goods where price like '%0';
select * from goods where name like '%杀%';
select * from goods where name like '演%';
select * from goods where name like '%养';

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
5)空值查询,某个字段没有值称为空值
is (not) null

select * from table_name where 属性名 is (not) null;

6)带and的多条件查询,and条件都要满足才能筛选出来

select * form table_name where 属性名1 条件1 and 属性名1 条件2 and 属性名n 条件n;

在这里插入图片描述

7)带or的多条件查询,只要满足or条件的都会被筛选出来

select * from table_name where 属性名1 条件1 or 属性名1 条件2 or 属性名n 条件n;

在这里插入图片描述

8)去重复查询

select distinct 属性名 from table_name;

在这里插入图片描述
9)对结果排序
order by 属性名 (asc、升序(默认)/desc、降序)
升序:

select price from goods order price;//升序

在这里插入图片描述
降序:

select * from goods order by price desc;

在这里插入图片描述

10)分组查询
group by 属性名 having 条件

select * from table_name group by 属性名 having 条件;

在这里插入图片描述
11)limit分页查询

select * from table_name limit n;
select * from tabel_name limit n, m;

表的前两行:
在这里插入图片描述
实际上是表中的第二行开始,查找4行数据
在这里插入图片描述
从第一行开始,查找3行数据
在这里插入图片描述

sc 跟 teacher 表
在这里插入图片描述
12)内连接,两表共有的
在这里插入图片描述
13)左连接,左表有右表没得
在这里插入图片描述
14)右连接,右表有左表亦没得
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值