表的增删改查 进阶(二)

这篇具有很好参考价值的文章主要介绍了表的增删改查 进阶(二)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

表的增删改查 进阶(二),MySql,数据库

  • 🎥 个人主页:Dikz12
  • 🔥个人专栏:MySql
  • 📕格言:那些在暗处执拗生长的花,终有一日会馥郁传香
  • 欢迎大家👍点赞✍评论⭐收藏

目录

3.新增

 4.查询

聚合查询 

聚合函数 

GROUP BY子句

 HAVING

 联合查询 

内连接(重点)

外连接(重点)

 左外连接

右外连接 

自连接

子连接 

合并查询 


3.新增

  •  先创建两个列数,类型相匹配的表

表的增删改查 进阶(二),MySql,数据库

  • 在第一张表(student)里添加一些数据 

表的增删改查 进阶(二),MySql,数据库

  •  把查询语句的查询结果,作为插入的数据

表的增删改查 进阶(二),MySql,数据库

此处操作,要求查询出来的结果集合的列数和类型必须要和插入的表相匹配!

 4.查询

聚合查询 

表达式查询,是针对 列 和 列之间进行运算的;聚合函数,相当于是在 行 与 行 之间进行运算。 

聚合函数 

函数 说明
COUNT([DISTINCT] expr) 返回查询到的数据的 数量
SUM([DISTINCT] expr) 返回查询到的数据的 总和,不是数字没有意义
AVG([DISTINCT] expr) 返回查询到的数据的 平均值,不是数字没有意义
MAX([DISTINCT] expr) 返回查询到的数据的 最大值,不是数字没有意义
MIN([DISTINCT] expr) 返回查询到的数据的 最小值,不是数字没有意义
  • COUNT

表的增删改查 进阶(二),MySql,数据库 表的增删改查 进阶(二),MySql,数据库

先执行select * ,在针对结果集合进行统计(看看具体有几行);、

count(*)和count(列名)这两种计算方式,如果有空null,计算的count就不同了。

表的增删改查 进阶(二),MySql,数据库

 指定具体列,是可以进行去重的;

表的增删改查 进阶(二),MySql,数据库

  • SUM 

把这一列的若干行,给进行求和.(算术运算)只能针对数字类型使用;字数串可以相加,不会报错,但不是算术运算,没有意义。

表的增删改查 进阶(二),MySql,数据库表的增删改查 进阶(二),MySql,数据库

 sum(表达式) 查询; sum,avg,max,min基本相同;

表的增删改查 进阶(二),MySql,数据库

GROUP BY子句

针对指定的列进行分组,把这一列中,相同的行,分到一组中,得到若干组,针对这些组使用聚合函数。

select 列名, sum(列名), ... from 表名 group by 列名;

 表的增删改查 进阶(二),MySql,数据库

使用group by 往往还是要搭配聚合函数,否则查询的结果,基本都是没有意义的!

使用group by 时,还可以搭配条件.需要区分是你该条件是分组之前的还是分组之后的.

  • 查询每个岗位的平均工资,排除张三

 这个就是分组之前的,使用WHERE 即可. 写在group by的前面。

表的增删改查 进阶(二),MySql,数据库

 HAVING

GROUP BY 子句进行分组以后,需要对分组结果再进行条件过滤时,不能使用 WHERE 语句,而需要用HAVING.

  • 查询每个岗位的平均工资,排除平均工资超过2w的结果

 表的增删改查 进阶(二),MySql,数据库

 联合查询 

联合查询也称为多表查询;前面的查询都是针对一个表,有些查询,则是要一次性从多个表中进行查询.联合查询的关键思路,在于理解“笛卡尔积”工作过程。会把所有情况都穷举一遍,也包含了一些非法数据无意义的数据。进行多表查询就是根据一些条件要把有意义的数据筛选出来保留,无意义的数据过滤掉。

                                 表的增删改查 进阶(二),MySql,数据库 

内连接(重点)

select ... from 表1,表2 where 条件
-- inner可以缺省
select ... from 表1 [inner] join 表2 on 条件 
  • 例如:查询 许仙同学的成绩 

1. 先把这两个表进行笛卡尔积。

 表的增删改查 进阶(二),MySql,数据库

 表的增删改查 进阶(二),MySql,数据库

2.加上连接条件,筛选出有效数据

本体示例连接条件:

学生表的id = 分数表的seudent_id .(建议写作表名.列名

表的增删改查 进阶(二),MySql,数据库

3. 结合需求,进一步添加条件,得到自己想要的结果

表的增删改查 进阶(二),MySql,数据库

 注意:一旦表的数据量很大,或者表数目很多,此时得到的笛卡尔积就会非常庞大;因此,如果针对表进行笛卡尔积(多表查询),就会生成大量的临时结果,这个过程是非常消耗时间的,此时,sql就会非常复杂,可读性大大降低。

外连接(重点)

-- 左外连接,表1完全显示
select 字段名 from 表名1 left join 表名2 on 连接条件;
-- 右外连接,表2完全显示
select 字段 from 表名1 right join 表名2 on 连接条件;

 如果两个表,里面的记录都是存在对应关系,则内连接和外连接的结果是一致;不存在对应关系,结果就会有一些差别。

表的增删改查 进阶(二),MySql,数据库 

表的增删改查 进阶(二),MySql,数据库 (内连接

 左外连接

 左外连接,就是以左侧为基准,保证左侧表的每个数据都会出现在最终结果里;如果在右侧表中不存在,对应的列就填成null。

表的增删改查 进阶(二),MySql,数据库 

表的增删改查 进阶(二),MySql,数据库

右外连接 

表的增删改查 进阶(二),MySql,数据库 

表的增删改查 进阶(二),MySql,数据库 

自连接

自连接,就是一张表,自己跟自己进行笛卡尔积;sql里写个条件,都是列与列之间进行比较,但是有的时候可能会涉及到需求是进行行与行之间进行比较.就需要使用自连接,把行的关系转换成列的关系.

 注意:在进行笛卡尔积时,不能直接用表名,要对表进行起别名。

表的增删改查 进阶(二),MySql,数据库

表的增删改查 进阶(二),MySql,数据库 

在根据自己需要的结果,找到连接条件,筛选数据 

子连接 

就是把多个简单的SQL拼成一个复杂的SQL;平时写代码都时把复杂的拆分成多个简单的,违背了一贯的编程原则;子连接很少使用,简单了解一下,即可。 

 单行子查询:表的增删改查 进阶(二),MySql,数据库

合并查询 

把多个sql查询结果集合,合并到一起。关键字:union.

合并两个sql结果集的列是要匹配的,列的个数和类型,是要一致的,合并的时候是会去重的,不想去重可以使用union all。

表的增删改查 进阶(二),MySql,数据库

  文章来源地址https://www.toymoban.com/news/detail-806881.html

到了这里,关于表的增删改查 进阶(二)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • node+vue3+mysql前后分离开发范式——实现对数据库表的增删改查

    大家好,我是yma16,本文分享关于 node+vue3+mysql前后分离开发范式——实现对数据库表的增删改查。 技术选型 前端:vite+vue3+antd 后端:node koa 数据库:mysql koa是一个现代的Node.js框架,可以用来构建Web应用程序。 Vue.js 是一款用于构建用户界面的开源JavaScript框架。Vue.js 3 是 Vu

    2024年02月20日
    浏览(38)
  • MySQL表的增删改查(进阶)

    目录 数据库约束 约束的定义 约束类型 null约束 unique:唯一约束 default:默认值约束 primary key:主键约束(重要) foreign key:外键约束(描述两个表之间的关联) 表的设计 一般思路 三大范式 一对一 一对多 ​编辑 多对多 ​编辑 新增 查询 聚合查询 聚合函数 group by字句 having 联合查询

    2024年02月05日
    浏览(44)
  • MySQL--MySQL表的增删改查(进阶)

    check 聚合查找 count sum average max min 我们这里先构造出多张表 查询lisi同学的成绩 来自student和来自score c 增加名字这一条件 查询所有同学的总成绩以及个人信息 来自score和来自student 查询所有同学的各科成绩以及个人信息 来自student,course和score 简化后的结果如下: 除了上述的

    2024年02月09日
    浏览(39)
  • 4.MySQL表的增删改查(进阶)

    大家好,我是晓星航。今天为大家带来的是 MySQL表的增删改查(进阶) 相关的讲解!😀 NOT NULL - 指示某列不能存储 NULL 值。 UNIQUE - 保证某列的每行必须有 唯一 的值。 DEFAULT - 规定没有给列赋值时的默认值。 PRIMARY KEY - NOT NULL 和 UNIQUE 的结合。确保某列(或两个列多个列的结

    2024年02月09日
    浏览(52)
  • 【MySql】数据库的增删改查

    本篇的主要目的:对于数据库如何去增加删除查询修改 主要细节在于选项问题,编码选项 说明: 大写的表示 [] 是可选项 CHARACTER SET: 指定数据库采用的字符集 COLLATE: 指定数据库字符集的校验规则 查看当前用户数据库的列表show databases; 创建数据库create database db_name; 当

    2024年02月12日
    浏览(46)
  • 【MYSQL数据库的增删改查操作-超市管理系统】

    MYSQL数据库的增删改查 创建数据库 选择数据库 删除数据库 创建数据表 删除数据表 插入数据 更新数据 查找数据 以超市管理系统为例,包含员工表,库存表,仓库表 数据库:db_supermarket 数据表:s_employee #员工表;s_stock #库存表;s_storehouse #仓库表 插入数据之后生成表如下:

    2024年02月09日
    浏览(49)
  • 【MySQL】数据库的增删改查、备份、还原等基本操作

    大写的表示 [] 是可选项 CHARACTER SET: 指定数据库采用的字符集 COLLATE: 指定数据库字符集的校验规则 创建数据库的时候,有两个编码集: 1.数据库编码集——数据库未来存储数据 2.数据库校验集——支持数据库进行字段比较使用的编码,本质也是一种读取数据库中数据采

    2024年02月08日
    浏览(74)
  • MySql学习2:SQL分类、数据库操作、表操作、数据的增删改查

    SQL分类: DDL:数据定义语言,用来定义数据库对象(数据库、表、字段) DML:数据操作语言,用来对数据库表中的数据进行增删改 DQL:数据库查询语言,用来查询数据库表中的记录 DCL:数据控制语言,用来创建数据库用户、控制数据库的访问权限 查询所有数据库 查询当前

    2024年02月11日
    浏览(51)
  • Django学习记录:使用ORM操作MySQL数据库并完成数据的增删改查

    数据库操作 MySQL数据库+pymysql Django开发操作数据库更简单,内部提供了ORM框架。 安装第三方模块 ORM可以做的事: 1、创建、修改、删除数据库中的表(不用写SQL语句)。【无法创建数据库】 2、操作表中的数据(不用写SQL语句)。 1、自己创建数据库 1)启动MySQL服务 2)自带

    2024年02月14日
    浏览(59)
  • 表的增删改查 进阶(二)

    🎥 个人主页:Dikz12 🔥个人专栏:MySql 📕格言:那些在暗处执拗生长的花,终有一日会馥郁传香 欢迎大家👍点赞✍评论⭐收藏 目录 3.新增  4.查询 聚合查询  聚合函数  GROUP BY子句  HAVING  联合查询  内连接(重点) 外连接(重点)  左外连接 右外连接  自连接 子连接  合并

    2024年01月20日
    浏览(45)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包