热饭面试复习:【sql相关】-高级 (上)

简介: 热饭面试复习:【sql相关】-高级 (上)

sql作为一门古老的语言,学习起来性价比超高!几十年都不用更新!本节内容为进阶高级复习题!


创建数据库/表

create database 数据库名
create table 表名 (
字段1 varchar(255) 约束,
字段2 类型 约束,
primary key (字段1)
...
)


约束

not null 不能为null
unique 唯一
primary key 主键
foreign key 外键
default 默认
check 选择


删除数据库/表

drop table 表名
drop database 数据库名
只清空:
delete from 表
truncate table 表


返回前xxx条数据

select top 5 字段 from 表
select 字段 from 表 limit 5


like 模糊搜索

select 字段 from 表 where 字段2 like "%结尾"
%代表任意字符
not like 代表不包含这个模糊搜索


通配符

% 代表0个或多个字符
_ 代表一个字符
REGEXP [1,2,'a'] 代表内部任何单一字符
REGEXP ^[A-H] 不包含任何单一大写字母
REGEXP ![^字符列表] 不包含任何单一字符


IN 选取多个规定内的

select 字段 from 表 where 字段 in (值1,值2)
not in 不在


between 在一个区间内选择

select 字段 from 表 where 字段 between 值1 and 值2
not between 不属于


别名 as

select 字段 as 新字段名 from 表
select 字段 from 表 as 新表名


多表链接 join on

内链接 inner join

image.png

select * from 表1 inner join 表2 on 表1.字段1 = 表2.字段2


左右链接 left/right join

image.pngimage.png

select * from 表1 lect/right join 表2 on 表1.字段1=表2.字段2


完全链接 full join

image.png

select * from 表1 full join 表2 on 表1.字段1=表2.字段2


outer join

可以用在左右全中,如left outer join,可以返回不包含的内容


join去重

image.png

在 on 后加where 
如 select * from 表1 left join 表2 on 表1.字段1=表2.字段2 where 表2.字段 is null


合并查询结果 union

select * from 表1 union select * from 表2


允许重复合并结果 union all

select * from 表1 union all select * from 表2


复制数据到其他表

create table 新表 as select * form 旧表
insert into 新表 select * from 旧表
insert into 新表 (字段名) select * from 旧表


创建索引 create index

create index 索引名 on 表名 (字段名-可不写)
创建不允许值重复的唯一索引
create unique index 索引名 on 表名


删除索引 drop index

alert table 表名 drop index 索引名
相关文章
|
4月前
|
SQL 数据库
SQL面试50题------(初始化工作、建立表格)
这篇文章提供了SQL面试中可能会遇到的50道题目的建表和初始化数据的SQL脚本,包括学生、教师、课程和成绩表的创建及数据插入示例。
SQL面试50题------(初始化工作、建立表格)
|
4月前
|
SQL
sql面试50题------(1-10)
这篇文章提供了SQL面试中的前10个问题及其解决方案,包括查询特定条件下的学生信息、教师信息和课程成绩等。
sql面试50题------(1-10)
|
1月前
|
SQL 缓存 监控
大厂面试高频:4 大性能优化策略(数据库、SQL、JVM等)
本文详细解析了数据库、缓存、异步处理和Web性能优化四大策略,系统性能优化必知必备,大厂面试高频。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:4 大性能优化策略(数据库、SQL、JVM等)
|
4月前
|
SQL
sql面试50题------(11-20)
这篇文章提供了SQL面试中的50道题目,其中详细解释了11至20题,包括查询与学号为“01”的学生所学课程相同的学生信息、不及格课程的学生信息、各科成绩统计以及学生的总成绩排名等问题的SQL查询语句。
|
4月前
|
SQL
sql面试50题------(21-30)
这篇文章是SQL面试题的21至30题,涵盖了查询不同老师所教课程的平均分、按分数段统计各科成绩人数、查询学生平均成绩及其名次等问题的SQL查询语句。
sql面试50题------(21-30)
|
5月前
|
存储 SQL 索引
面试题MySQL问题之使用SQL语句创建一个索引如何解决
面试题MySQL问题之使用SQL语句创建一个索引如何解决
54 1
|
5月前
|
SQL 数据处理 数据库
SQL SELECT语句的高级应用与技巧
SQL SELECT语句的高级应用与技巧
|
6月前
|
SQL 存储 Java
SQL数据库学习指南:从基础到高级
SQL数据库学习指南:从基础到高级
|
6月前
|
SQL 大数据
常见大数据面试SQL-每年总成绩都有所提升的学生
一张学生成绩表(student_scores),有year-学年,subject-课程,student-学生,score-分数这四个字段,请完成如下问题: 问题1:每年每门学科排名第一的学生 问题2:每年总成绩都有所提升的学生
|
5月前
|
SQL Java 关系型数据库
Java面试题:描述JDBC的工作原理,包括连接数据库、执行SQL语句等步骤。
Java面试题:描述JDBC的工作原理,包括连接数据库、执行SQL语句等步骤。
78 0

热门文章

最新文章