Mysql--DDL

简单DDL:

DDL : 数据库定义语言

涉及的关键字 : create drop alter

alter

更改表名

alter table 表名 rename 新表名;

更改字段名

alter table 表名 change 列名 新列名 数据类型;

添加字段

alter table 表名add 列名类型;

删除字段

alter table 表名 drop 列名;

更改字段类型(尽量不要更改)

alter table 表名 modify 列名 新数据类型;

alter table 表名 modify 列名 数据类型 comment '该列的注释说明';  更改类型的同时,还能添加注释说明

查看建表语句

show create table 表名;

实体完整性(主键)

第一种 : 创建表语句时,添加主键约束

第二种 : 创建表完成之后,通过alter添加主键约束

alter table 表名 add primary key(列名,列名...);

主键自增:

第一种 : 建表时,添加自增

第二种 : 创建表之后,添加自增

语法 : alter table 表名modify 主键列名 类型 auto_increment;

关联完整性(外键)

第一种 : 创建表时添加外键约束

第二种 : 创建完表之后,添加外键约束

语法 : alter table 表名 add foreign key (外键列列名) references 指向的表名 (主键列列名);

唯一约束unique:

第一种 : 创建表时,添加unique约束

第二种 : 创建表之后,添加unique约束

alter table temp1 add unique (id);

非空约束 not null与 默认值 default

第一种 : 创建表时,添加约束

第二种 : 创建表之后,添加约束

语法 : alter table 表名 modify 列名 数据类型 not null  default 默认值;

基础DQL

DQL : Data Query Language,数据查询语言,主要用于查询表。

它通常用来从一张表或者多张表(视图或者子查询等)中按指定的条件筛选出某此记录。涉及到的命令有select。

语法 :

select 列限定 from 表限定 where 行限定;

and

且,和,的意思,一般用于 必须符合两个添加的判断,等同于java中的 &&

语法 :

select 列限定 from 表限定 where A表达式 and B表达式;

如 : 查询学生表中,name是张三且成绩大于90分

select * from student where name='张三' and score > 90;

只会查询出符合两个条件的学生

or

或的意思,一般用于 符合一个添加判断的情况下,等同于java中的 ||

语法 :

select 列限定 from 表限定 where A表达式 or B表达式;

如 : 查询学生表中,name是张三 或 成绩大于90分

select * from student where name='张三' or score > 90;

只要符合两个条件中的任何一个条件,就可以

注意 : 如果 一个语句中,同时出现了and和or的话,and优先级高

关系表达式

> , >= , <  , <= ,<>,=

> : 大于

< : 小于

>= : 大于等于

<= : 小于等于

= : 相等

<> : 不等于

注意 : = 和 <> 额外留意,和java中有所不同,java中判断相等用 == , 这里只用 = , java中判断不相等用 != , 这里使用 <>

between  and

在...之间

语法 :

select 列限定 from 表限定 where 列名 between 值1 and 值1;

如 : 查询学生表中 成绩在98到100之间 (包含98和100)

select * from student where score >= 98 and score<=100; 

等价于

select * from student where score between 98 and 100;

In

在指定数据中

语法 :

select 列限定 from 表限定 where 列名 in(值1,值2....);

如 : 给出一个数据集合(1,3,10,20),获取学生id在这个数据集合中的学生信息

select * from student where id in (1,3,10,20);

模糊查询like

我们经常会用到搜索功能,比如百度,搜索功能实现,就是使用like模糊查询技术点

其中 % 匹配任意个数的任意字符

 _ 匹配单个任意字符

语法 :

select 列限定 from 表限定 where 列名 like  '值' ;

Order by 排序

排序,望文知意,能够让我们查询的数据进行排序展示
       语法 :

select 列限定 from 表限定 order by 列名 asc/desc;

Asc : 升序

Desc : 降序

如 : 查询所有学生信息,以成绩降序

select * from student order by score desc;

如 : 查询所有学生信息,按成绩降序,如果成绩相同,按照id升序

select * from  student order by score desc , id asc;

Limit

限制条数,通常和order by一起使用,因为我们使用排序之后,再去获取前几条数据,比较有价值,比如成绩前三名

语法 :

select 列限定 from 表限定 limit 条数;

select 列限定 from 表限定 limit 开始值(不包含) ,条数;

如 : 查询学生表,分数前三名的信息

select * from  student order by score desc limit 3;

如 : 查询学生表,分数第二名和第三名

select * from  student order by score desc limit 1,2;

单表查询(组函数)
Group by Having

子查询

场景一 : select后面

注意 :

当位于SELECT后面时,要注意

1.一定要在两个表之间找好对应关系(teacher.id必须是主键或者必须保证teacher.id在teacher表中是唯一的)

2.子查询中只能有一个字段(子查询的结果必须是一行一列)

使用子查询的时候,建议大家养成使用别名的好习惯,这样可以让我们的查询语句更加清晰。别名可以用来命令新字段,也可以用来命名新表.

场景二 : from后面

注意 :

当位于FROM后面时,要注意

1.我们可以把子查询当成一张表

2.必须要有别名,因为子查询优先被执行,子查询的别名,可以让别的查询当做表或者列去操作

场景三 : where后面

如 : 在不知道teacher_id 和 老师名字的对应关系的情况下,想查询出张老师下面的所有学生信息

select * from student where teacher_id in (

select id from teacher where name='张老师'

);

注意 :

当位于WHERE后面时,要注意

多条数据要用in而不要用=,如果确定子查询的结果为一行一列的话,就可以用 = 等于
如果返回结果为多行一列的话 要用 in , 一列是必须的,必须是一列
3.子查询中的SELECT后面只能有一个字段(多个字段的话会报错)
 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值