基础创建

字段自动编号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考试复习的更多相关文章

  1. Unity3D学习笔记(十三):委托、考试复习

    委托:比较什么时候用委托好   下课案例:不用下课铃 1.ClassManager需要拿到所有教室的引用,课堂管理者应该只负责计时并告知每间教室 2.每间教室应该是由当班老师负责是否需要下课,而课堂管 ...

  2. python期末考试复习

    期末考试复习 补修的python跟着大一一起学,考试肯定不会出难,于是就敲了一些代码,把他们放到博客上,来记录一下 代码都是一段一段的,且python代码不是很多,所以我都写到了一个文件里,作为练习 ...

  3. Mysql 索引复习笔记

    之前学习索引后由于一直没怎么用,所以也只是粗略看了一下,最近发现索引的用处很大,并且也很多知识点,在此做复习记录. 什么是索引? 百度百科是这样描述的: 索引是为来加速对表中数据行中的检索而创建的一种 ...

  4. mysql基础复习(SQL语句的四个分类),

                                                                                                       ( ...

  5. MYSQL 函数复习

    数学函数    ABS(X)    返回X的绝对值    SQRT(x)        返回非负数X的二次方根    MOD(x,y)    返回x被y除后的余数    CEIL(x)         ...

  6. mysql - 语法复习与学习

    //本月的第一天,最后一天 $start=date('Y-m-01', strtotime(date("Y-m-d"))); echo date('Y-m-d', strtotim ...

  7. MySQL基础复习

    三范式定义 1NF:每个数据项都是最小单元,不可分割,其实就是确定行列之后只能对应一个数据. 2NF:每一个非主属性完全依赖于候选码(属性组的值能唯一的标识一个元组,但是其子集不可以).  3NF: ...

  8. mysql总复习

    目录 数据库操作 库操作 表操作 数据行操作 表关系操作 单表操作 外键创建 多表联查 pymysql模块 索引 主键索引 唯一索引 普通索引 数据库操作 库操作 create database 库名 ...

  9. mysql高级复习

    MySQL官方对索引的定义为:索引(Index)是帮助MySQL高效获取数据的数据结构.可以得到索引的本质:索引是数据结构,可以简单理解为“排好序的快速查找数据结构”. 数据本身之外,数据库还维护着一 ...

随机推荐

  1. linux运维、架构之路-jumpserver

    一.jumpserver介绍           是一款由python编写开源的跳板机(堡垒机)系统,实现了跳板机应有的功能.基于ssh协议来管理,客户端无需安装agent. 特点: 完全开源,GPL ...

  2. SQL Server死锁问题:事务(进程 ID x)与另一个进程被死锁在 锁 | 通信缓冲区资源上并且已被选作死锁牺牲品。请重新运行该事务。

    ### The error occurred while setting parameters### SQL: update ERP_SCjh_zzc_pl set IF_TONGBU=1 where ...

  3. extjs计算两个DateField所间隔的月份(天数)

    需求:两个DateField控件,分别为开始时间和结束时间.当选择完结束时间后,自动计算这两个时间段所间隔的月或天数. 需要解决的问题: 1.直接使用Ext.getCmp('endDate').get ...

  4. HDU 4300 Clairewd's message ( 拓展KMP )

    题意 : 给你一个包含26个小写字母的明文密文转换信息字符串str,第一个表示'a'对应的密文是str[0].'b'对应str[1]……以此类推.接下来一行给你一个另一个字符串,这个字符串由密文+明文 ...

  5. luogu P1068 分数线划定 x

    P1068 分数线划定 题目描述 世博会志愿者的选拔工作正在 A 市如火如荼的进行.为了选拔最合适的人才,A 市对 所有报名的选手进行了笔试,笔试分数达到面试分数线的选手方可进入面试.面试分数线根 据 ...

  6. 手动写Makefile编译Android NDK的so

    之所以摒弃NDK,是因为NDK编译出来的so太大,而且导出表总有一些没用的符号.而且手动编译的话,可以得到编译过程中间的.i和.s文件,可以删除一些没用的汇编代码.现在代码列出来:我的NDK C的代码 ...

  7. WebServices 实现跨应用程序进行通信和跨平台进行通信

    SOA ,即Service Oriented Architecture ,中文一般理解为面向服务的架构, 既然说是一种架构的话,所以一般认为 SOA 是包含了运行环境,编程模型, 架构风格和相关方法论 ...

  8. ECharts插件介绍(图表库)

    ECharts是一个非常好用的插件,用于进行 树状图,折线图,饼图,地图等等,系列视图的绘制.(详情看官网) 了解: AMD:模块化开发方式: 引入文件后:console.log(echarts) / ...

  9. 图像bayer格式介绍【转】

    本文转载自:http://www.cnblogs.com/whw19818/p/6223143.html 1 图像bayer格式介绍 bayer格式图片是伊士曼·柯达公司科学家Bryce Bayer发 ...

  10. Centos 7下安装nginx,使用yum install nginx,提示没有可用的软件包

    Centos 7下安装nginx,使用yum install nginx,提示没有可用的软件包. 18 (flaskApi) [root@67 flaskDemo]# yum -y install n ...