mysql考试复习
基础创建
字段自动编号auto_increment
( 单词补充:increment 定期的加薪; 增量; 增加)
考点
添加自增
alter table [表名] modify [字段(id)] int primary key auto_increment
添加自增起始值
alter table t_test1 auto_increment = 1000;
栗子:https://www.cnblogs.com/fooobabar/p/11132926.html
查询
select distinct * from 表(对表去重复查询)
(单词补充:distinct 有区别的,明显的,独特的)
查询每个专业的男生人数、女生人数、总人数,已经学生总人数
select 专业名,性别,count(*) as '人数' from xs group by 专业名,性别 with rollup
(单词补充:rollup 归纳总和)
select 专业名,count(*) as '学生数' from xs group by 专业名 having count(*)>10;

case 字段
when 字段条件1 then '名字1'(满足后命名)
when 字段条件2 then '名字2'(满足后命名)
end (结束)
连接多表
表1 join 表2 on 表1.id=表2.id join 表3 on 表2.id=表3.id (注意三表链接中间表要和其他两表有关系)
例题
select Name,Address, case InCome
when InCome>3000 then '高收入'
when InCome<=3000 and InCome>=2000 then '中等收入'
when InCome>3000 then '高收入'
end as '收入水平'
from employees join salary on employees.employeesid=salary.employeesid;

事务
show variables like 'autocommit';查看自动提交事务autocommit
两种
第一种
1.设置为不自动提交事务
set autocommit=0;
2.可以设置回滚点(保存点)rollback to 回滚点--回滚点下面的事务就不执行
savepoint 名1;
rollback 名1;
3.用commit;提交事务
4.set autocommit=1;根据条件修改回来
第二种
1.用begin;语句开始
2.可以设置回滚点(保存点)rollback to 回滚点--回滚点下面的事务就不执行(同上)
3.用commit提交事务
约束
唯一约束 unique
主键约束 primary key
外键约束 constraint 外键名 foreign key( 列名 ) references 外表( 列名 )
DROP TABLE IF EXISTS students;
CREATE TABLE students(
id INT ,
s_name VARCHAR(10) not null,# 非空约束
s_sex CHAR(1) default '男', # 默认约束
s_seat INT,
age INT ,
teacher_id INT ,
#上面是列级约束,下面有表级约束
CONSTRAINT pk PRIMARY KEY(id), #主建约束,pk是起的名,后面一样
CONSTRAINT uq UNIQUE(s_seat), #唯一约束
CONSTRAINT ck CHECK(s_sex='男' OR s_sex='女'), #检查约束
考点
CONSTRAINT fk_students_teacher FOREIGN KEY(teacher_id) REFERENCES teacher(id) #外键约束
);
这里是修改时两边修改。
栗子:https://blog.csdn.net/qq_42402854/article/details/84714934
视图注意事项:
1有表 2有权限 3不含form子查询 4表的视图和表只能有一个order by ,5 limit也是
create or replace view view_name[(字段1...)]
as
select语句
存储过程
delimiter //
create procedure do_query(in num1 integer,in num2 integer,out c1 char(6))
begin
if num1>num2 then
set c1='大于';
elseif num1<num2 then
set c1='小于';
else set c1='等于';
end if;
end//
delimiter ;
call do_query()
select...into
select 列名 into 变量名 from 表 where...
把列值赋值给变量
case when then
delimiter $$
create procedure xscj.result
(in str varchar(4), out sex varchar(4) )
begin
case str
when 'm' then set sex='男';
when 'f' then set sex='女';
else set sex='无';
end case;
end$$
delimiter ;
或者
case
when str='m' then set sex='男';
when str='f' then set sex='女';
else set sex='无';
end case;
mysql考试复习的更多相关文章
- Unity3D学习笔记(十三):委托、考试复习
委托:比较什么时候用委托好 下课案例:不用下课铃 1.ClassManager需要拿到所有教室的引用,课堂管理者应该只负责计时并告知每间教室 2.每间教室应该是由当班老师负责是否需要下课,而课堂管 ...
- python期末考试复习
期末考试复习 补修的python跟着大一一起学,考试肯定不会出难,于是就敲了一些代码,把他们放到博客上,来记录一下 代码都是一段一段的,且python代码不是很多,所以我都写到了一个文件里,作为练习 ...
- Mysql 索引复习笔记
之前学习索引后由于一直没怎么用,所以也只是粗略看了一下,最近发现索引的用处很大,并且也很多知识点,在此做复习记录. 什么是索引? 百度百科是这样描述的: 索引是为来加速对表中数据行中的检索而创建的一种 ...
- mysql基础复习(SQL语句的四个分类),
( ...
- MYSQL 函数复习
数学函数 ABS(X) 返回X的绝对值 SQRT(x) 返回非负数X的二次方根 MOD(x,y) 返回x被y除后的余数 CEIL(x) ...
- mysql - 语法复习与学习
//本月的第一天,最后一天 $start=date('Y-m-01', strtotime(date("Y-m-d"))); echo date('Y-m-d', strtotim ...
- MySQL基础复习
三范式定义 1NF:每个数据项都是最小单元,不可分割,其实就是确定行列之后只能对应一个数据. 2NF:每一个非主属性完全依赖于候选码(属性组的值能唯一的标识一个元组,但是其子集不可以). 3NF: ...
- mysql总复习
目录 数据库操作 库操作 表操作 数据行操作 表关系操作 单表操作 外键创建 多表联查 pymysql模块 索引 主键索引 唯一索引 普通索引 数据库操作 库操作 create database 库名 ...
- mysql高级复习
MySQL官方对索引的定义为:索引(Index)是帮助MySQL高效获取数据的数据结构.可以得到索引的本质:索引是数据结构,可以简单理解为“排好序的快速查找数据结构”. 数据本身之外,数据库还维护着一 ...
随机推荐
- linux运维、架构之路-全网备份项目方案
一.项目需求说明 某公司有多台服务器,里面的数据很重要,如果磁盘坏了,数据就会丢失,所以公司要求把重要服务器数据备份以便出现问题时可以进行恢复,要求:每天晚上00点整在所有服务器上打包备份系统配置文件 ...
- CSS-动画,让图片上的图形有涨起来的效果(逐渐变高)和(逐渐变长)
效果图: html: <div class="inner3"> <div class="over"> <img src=" ...
- HTML中的marquee标签实现滚动效果
一.标签<marquee>简介 通过开始标签<marquee>和结束标签</marquee>的共同配合而实现滚动效果,<marquee>滚动的内容< ...
- ASP.NET上传一个文件夹
之前仿造uploadify写了一个HTML5版的文件上传插件,没看过的朋友可以点此先看一下~得到了不少朋友的好评,我自己也用在了项目中,不论是用户头像上传,还是各种媒体文件的上传,以及各种个性的业务需 ...
- HDU 6153 A Secret ( KMP&&DP || 拓展KMP )
题意 : 给出两个字符串,现在需要求一个和sum,考虑第二个字符串的所有后缀,每个后缀对于这个sum的贡献是这个后缀在第一个字符串出现的次数*后缀的长度,最后输出的答案应当是 sum % 1e9+7 ...
- 【bzoj2064】【分裂】状态压缩表示合并子集
(上不了p站我要死了,画师当然是wlop大大啦) 感觉这个做法还是挺难想的. 但还是总结一下思路吧.. "只可意会不可言传的状压dp"(乱说) Description 背景: 和久 ...
- POJ Knight Moves 2243 x
Knight Moves Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 13974 Accepted: 7797 Des ...
- 【bzoj1176】[Balkan2007]Mokia
题目描述: 维护一个W*W的矩阵,初始值均为S.每次操作可以增加某格子的权值,或询问某子矩阵的总权值.修改操作数M<=160000,询问数Q<=10000,W<=2000000. 输 ...
- Leetcode 2. Add Two Numbers(指针和new的使用)结构体指针
---恢复内容开始--- You are given two non-empty linked lists representing two non-negative integers. The di ...
- TCP报文段首部格式详解
TCP首部格式 格式字段详解 源端口.目标端口: 计算机上的进程要和其他进程通信是要通过计算机端口的,而一个计算机端口某个时刻只能被一个进程占用,所以通过指定源端口和目标端口,就可以知道是哪两 ...