数据表的完整性约束条件


AUTO_INCREMENT (自增长)

注意事项:

1.一个表中只能有一个自增长字段

2.必须配合主键使用



方法1:







方法2:



方法3:



指定自增长初始值的方法:



修改自增长值的方法:


NOT NULL (非空)

注意事项:

1.值不能为NULL

(比如建立网站时,要求用户输入用户名和密码时,就可以用NOT NULL


DEFAULT (默认值)

注意事项:

1.一般配合NOT NULL使用


UNIQUE KEY (唯一性)

注意事项:

1.一个表中可以有多个唯一

2.被标志上UNIQUE KEY字段的值不允许重复(NULL不算重复)

(UNIQUE KEY使用时,KEY可以省略不写)



修改表结构的操作


重命名数据表

方法1: <ALTER TABLE tbl_name RENAME [ TO|AS ] new_name;



方法2: RENAME TABLE tbl_name TO new_name;


添加和删除字段

添加字段:ALTER TABLE tbl_name ADD 字段名称 字段类型 [完整性约束条件] [ FIRST|AFTER 字段名称];



带有完整性约束条件的添加字段



在指定位置添加字段



一次添加多个字段的操作



 

 

删除字段:ALTER TABLE tbl_name DROP 字段名称;



一次删除多个字段



也可以同时进行添加删除字段的操作


修改字段类型和字段名称

修改字段类型:ALTER TABLE tbl_name MODIFY 字段名称 字段类型 [完整性约束条件] [ FIRST|AFTER 字段名称 ];



从上图可以看到原先email属性的NOT NULL约束条件和默认值在修改后都发生了变化,如果想修改时不让它发生变化,就要在命令中添加完整性约束条件



还可以改变字段的位置



同样,可以既修改字段类型,也改变字段位置

修改字段名称:ALTER TABLE tbl_name CHANGE 旧字段名称 新字段名称 字段类型 [完整性约束条件] [ FIRST|AFTER 字段名称 ];



还可以不修改字段名称,修改字段类型


添加删除默认值

添加默认值:ALTER TABLE tbl_name ALTER 字段名称 SET DEFAULT 默认值;



删除默认值:ALTER TABLE tbl_name ALTER 字段名称 DROP DEFAULT;


添加删除主键

添加主键:ALTER TABLE tbl_name ADD [ CONSTRAINT[ symbol ] ] PRIMARY KEY [index_type] (字段名称,…) ;



添加主键的完整语句



添加复合主键





删除主键:ALTER TABLE tbl_name DROP PRIMARY KEY;



有一种情况不能直接删除主键




添加删除唯一

添加唯一:ALTER TABLE tbl_name ADD [ CONSTRAINT [ symbol ] ] UNIQUE [ INDEX|KEY ] [索引名称] (字段名称,…);



用完整写法设置索引名称



还可以添加复合唯一

删除唯一:ALTER TABLE tbl_name DROP { INDEX|KEY } index_name


修改表的存储引擎

ALTER TABLE tbl_name ENGINE=存储引擎名称;


设置自增长值

ALTER TABLE tbl_name AUTO_INCREMENT=自增长值;



对数据的操作(DML)


插入数据

不指定具体的字段名:INSERT [INTO] tbl_name VALUES|VALUES(值…);



列出指定字段:INSERT [INTO] tbl_name(字段名称1,…) VALUES|VALUES(值1,…);



同时插入多条记录:INSERT [INTO] tbl_name[(字段名称…)] VALUES|VALUES(值…),(值…)…;



通过set形式插入记录:INSERT [INTO] tbl_name SET 字段名称=值,…;



将查询结果插入到表中:INSERT [INTO] tbl_name[(字段名称…)] SELECT 字段名称 FROM tbl_name [WHERE 条件];


更新数据

UPDATE tbl_name SET 字段名称=值 [WHERE 条件][ORDER BY 字段名称][LIMIT 限制条数];






删除数据

删除指定数据:DELETE FROM tbl_name [WHERE 条件][ORDER BY 字段名称][LIMIT 限制条数];



彻底清空数据表:TRUNCATE [TABLE] tbl_name;



查询数据的操作(DQL)


查询记录

单表查询:

查询表达式:

(查询整个数据表)SELECT * FROM tbl_name; / SELECT tbl_name. * FROM tbl_name;

(查询数据表中的某几个字段)SELECT 字段名称1,… FROM tbl_name;

(明确查询来自某个数据库的表时)SELECT 字段名称1,… FROM db_name.tbl_name;

(给表名起别名)SELECT 字段名称1,… FROM tbl_name AS alias_name;(别名一般为表名的缩写,不超过两个字母)

WHERE条件



用WHERE条件查询指定记录(比较运算符)













指定范围查询



指定集合查询







模糊查询

会用到两个符号:

%:代表零个一个或者多个任意字符

_:代表一个任意字符



分组查询(GROUP BY)







可以用GROUP BY配合GROUP_CONCAT()得到分组详情



聚合函数:

COUNT();  得到总计数







MAX();  得到记录最大值

MIN();  得到记录最小值

AVG();  得到记录平均值

SUM();  得到记录总和

GROUP BY配合WITH ROLLUP会对统计记录进行二次统计

简单来说,就像图中的

totalUsers是求记录计数总和,sumAge是求年龄总和,那么它们最下方ROLLUP产生的也是一个总和

而maxAge是求最大值,ROLLUP产生的也是几个统计记录中的最大值

minAge,avgAge同理

HAVING子句对分组结果进行二次筛选

MySQL基础总结(二)的更多相关文章

  1. MySQL基础(二)——DDL语句

    MySQL基础(二)--DDL语句 1.什么是DDL语句,以及DDL语句的作用 DDL语句时操作数据库对象的语句,这些操作包括create.drop.alter(创建.删除.修改)数据库对象. 2.基 ...

  2. Mysql基础(二)

    学习路线:数据约束-> 数据库的设计过程-> 存储过程的相关知识-> 触发器-> 权限管理 (一)数据约束 1.1.默认值的设置 创建员工表emp 将默认地址设置为'中国'my ...

  3. Linux系统——MySQL基础(二)

    # MySQL数据库完全备份与恢复## 数据库备份的分类1. 从物理与逻辑的角度,备份可以分为物理备份和逻辑备份.(1)物理备份:对数据库操作系统的物理文件(数据文件.日志文件)的备份.物理备份又可分 ...

  4. MySQL基础(二):视图、触发器、函数、事务、存储过程

    一.视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名称]即可获取结果集,并可以将其当作表来使用. 视图和上一篇学到的临时表搜索类似. ...

  5. Mysql基础(二):MySQL之存储引擎

    目录 MySQL之存储引擎 1.MySQL存储引擎介绍 2.MySQL结构 3.MySQL存储引擎分类 4.存储引擎的使用 5.总结 MySQL之存储引擎 1.MySQL存储引擎介绍 MySQL中的数 ...

  6. MySQL基础(二)(约束以及修改数据表)

    一,约束以及修改数据表 约束的作用?1.约束保证数据的完整性.一致性:2.约束分为表级约束.列级约束:3.约束类型包括:NOT NULL(非空约束).PRIMARY KEY(主键约束).UNIQUE ...

  7. MySQL基础之二:主从复制

    # mysql主从复制逻辑: 1.从库执行start slave 开启主从复制. 2.从库请求连接到主库,并且指定binlog文件以及位置后发出请求. 3.主库收到从库请求后,将信息返回给从库,除了信 ...

  8. mysql基础教程(二)-----分组函数、多表查询、常见函数

    分组函数 什么是分组函数 分组函数作用于一组数据,并对一组数据返回一个值. 组函数类型 • AVG() • COUNT() • MAX() • MIN() • SUM() 组函数语法 AVG(平均值) ...

  9. mysql基础(二)—— 简单sql

    查询 select * from company select c.code from company c; select m.bookname from myview m; (myview为视图) ...

  10. MySQL基础练习(二)

    第一个例子我们编写一个 SQL 查询,列出所有超过或等于5名学生的课. 先建表 CREATE TABLE courses( student ) NOT NULL, class ) NOT NULL ) ...

随机推荐

  1. 绝地求生模拟登陆!高难度JS解密教程,Python高级爬虫开发,

    前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. PS:如有需要Python学习资料的小伙伴可以加点击下方链接自行获取htt ...

  2. Mysql:小主键,大问题

    今日格言:让一切回归原点,回归最初的为什么. 本篇讲解 Mysql 的主键问题,从为什么的角度来了解 Mysql 主键相关的知识,并拓展到主键的生成方案问题.再也不怕被问到 Mysql 时只知道 CR ...

  3. CSS- 一些少用的

    1. 字体间距 1.)word-spacing: 2.)letter-spacing: 3.)text-indent 4.)text-align-last: justify; 和 text-align ...

  4. 控制反转IOC,依赖注入DI理解

    IOC:控制反转,常规下,高层依赖低层,项目是不稳定的.我们则应该把高层对低层的依赖去掉,换成对抽象的依赖,细节交给第三方来决定,这就是控制反转,反转的目的是为了降低依赖,增强扩展性. DI:依赖注入 ...

  5. 关于unix环境高级编程、Linux程序设计两部书浅谈

    unix环境高级编程的术语很多,概念内容,也很多,不过学习概念性质.标准规则类的东西,想必都是这样吧——需要进行拓展的内容很多. Linux程序设计,图文并茂,代码量够足,看起来,感觉难度还可以. l ...

  6. git工具上传项目到码云

    首先,你需要在本地安装git客户端,此处简单易懂,略过然后,在本地建好文件夹,以本人为例,我的路径为 E:\git_project,此时需要通过鼠标右键选择:git bush here 如图所示然后会 ...

  7. java 8 Stream中操作类型和peek的使用

    目录 简介 中间操作和终止操作 peek 结论 java 8 Stream中操作类型和peek的使用 简介 java 8 stream作为流式操作有两种操作类型,中间操作和终止操作.这两种有什么区别呢 ...

  8. Spring5参考指南:依赖注入

    文章目录 依赖注入 依赖注入的配置详解 depends-on lazy-init 自动装载 方法注入 依赖注入 依赖注入就是在Spring创建Bean的时候,去实例化该Bean构造函数所需的参数,或者 ...

  9. AIX如何点亮HBA卡

    不要选中分区,选择系统管理下的服务器即可 LED状态----->启动Advanced System Management(ASM) UserID:  admin Password:admin S ...

  10. 【React踩坑记三】React项目报错Can't perform a React state update on an unmounted component

    意思为:我们不能在组件销毁后设置state,防止出现内存泄漏的情况 分析出现问题的原因: 我这里在组件加载完成的钩子函数里调用了一个EventBus的异步方法,如果监听到异步方法,则会更新state中 ...