当前位置: 首页 > news >正文

【数据库增删查改进阶版】保姆级教程带大家去学习更加复杂的sql语句,各种各样的约束以及各种各样的查询

前言:
大家好,我是良辰丫🍅🍅🍅,上一篇数据库我们一起学习了基础版本的增删查改,今天我们将接触更高级的增删查改,主要是学习一些约束条件,你们准备好了嘛?开始发车了。👒👒👒

🧑个人主页:良辰针不戳
📖所属专栏:数据库
🍎励志语句:生活也许会让我们遍体鳞伤,但最终这些伤口会成为我们一辈子的财富。
💦期待大家三连,关注,点赞,收藏。
💌作者能力有限,可能也会出错,欢迎大家指正。
💞愿与君为伴,共探Java汪洋大海。

在这里插入图片描述


目录

  • 1、数据库约束
    • 1.1 NULL约束
    • 1.2 unique约束
    • 1.3 default设置默认值
    • 1.4 主键约束
    • 1.5 自增主键
    • 1.6 外键
  • 2、表的设计
  • 3、查询结果作为新增数据
  • 4、进阶版查询
    • 4.1 聚合查询
      • 4.1.1 聚合函数
      • 4.1.2 group by子句
      • 4.1.3 having
    • 4.2 联合查询(多表查询)
      • 4.2.1 了解联合查询
      • 4.2.2 内连接
      • 4.2.3 外连接
      • 4.2.4 自连接
      • 4.2.5 子查询
      • 4.2.6 合并查询


1、数据库约束

所谓约束就是在使用数据库的时候对数据库中存储的数据提出一定的要求和限制。下面是一个约束条件表,先简单看一下,后面会有详细解释。

约束条件解释
NOT NULL指示某列不能存储 NULL 值
UNIQUE保证某列的每行必须有唯一的值
DEFAULT规定没有给列赋值时的默认值
PRIMARY KEY主键,就像身份证一样,唯一标识
FOREIGN KEY外键,保证一个表中的数据匹配另一个表中的值的参照完整性
CHECK保证列中的值符合指定的条件

1.1 NULL约束

创建表时,指定某个属性的性质,表名该属性不可以为空。下面我们来举一个简单的例子.

create table stu(id varchar(10) not null,name varchar(20));

上面的代码中我们创建了一个表,表的属性具有了约束条件,不能为空,如果我们填入的属性为null时就会报错.

在这里插入图片描述

我们来看一下我们创建的表结构.

在这里插入图片描述

1.2 unique约束

保证每列的每行具有唯一属性.

create table stu2 (id int unique,name varchar(20));

此时stu2的id属性只能唯一,当我们创建相同的id时,就会报错.
在这里插入图片描述

1.3 default设置默认值

规定没有给列赋值时的默认值

 create table stu3 (id int,name varchar(20) default '未知');insert into(id) stu3 values(5);

在这里插入图片描述

1.4 主键约束

唯一标识,象征你的唯一性,比如你的身份证,在学校你的学号…这些都是唯一标识

create table stu4 (id int primary key,name varchar(20));
insert into stu4 values(1,'叶良辰');
insert into stu4 values(1,'张三');

在这里插入图片描述

插入一条id为1的数据时候,它会正常插入,然而呢,第二次,插入id仍然为1的数据时,就会报错,这下大家明白主键的基本作用了吧.这时就引入了自增主键的概念.

1.5 自增主键

给自增主键插入数据的时候,我们可以自己指定一个主键,也可以插入一个空值,让他自己分配.

 create table stu5 (id int primary key auto_increment,name varchar(20));insert into stu5 values(null,'叶良辰'),(null,'李四');

在这里插入图片描述

我们指定的id为null,但是它默认给我们赋值,这就是自增主键.

1.6 外键

保证一个表中的数据匹配另一个表中的值的参照完整性,简而言之,就是父表与子表的约束关系.我们需要创建两张表来说明其中的联系.

create table class (classID varchar(20) primary key);
create table student(id int primary key auto_increment,classID varchar(20),foreign key(classID) references class(classID));

在这里插入图片描述

需要注意的是,父表中被依赖的属性必须是主键

insert into class values('一班');

在这里插入图片描述

在拥有一班的情况下会正常插入数据.

在这里插入图片描述

上述插入的数据是1班,class中没有1班的数据,所以会报错
注意
一班和1班不一样,一个是汉字一,一个是数字1哦.

父表在约束子表的同时,子表也在约束父表.

drop table class;

在这里插入图片描述

因为子表约束父表,因此上面的删除父表操作会失败.

在这里插入图片描述

删除一班这一行的数据也会报错.

2、表的设计

所谓表的设计,简单粗暴的理解就是如何去弄一个数据库,各个表进行联系等.数据库中,有几个表,每个表有怎样的属性,每个表的作用是什么等.
实体:在java中面向对象是找对象,在数据库中,面向对象是找实体,比如一个学生是一个实体,一个老师也是一个实体.

明确三种关系

  • 一对一:在学校中,一个学生只能有一个学号.
  • 一对多:一个班级中可以包含多个学生.
  • 多对多:一个学生可以选择多个课程,一个课程也可以提供给多个学生.

友情提示:
在设计表之前,一般需要画简图,去描述各个表的功能以及联系.

3、查询结果作为新增数据

insert into stu select * from stu;

在这里插入图片描述
在这里插入图片描述

4、进阶版查询

4.1 聚合查询

查询过程中,表的行与行进行一定的运算,聚合查询依赖于聚合函数.

4.1.1 聚合函数

函数说明
count数据的数量
sum数据总和(非数据没有意义)
avg平均值(非数据没有意义)
max最大值(非数据没有意义)
min最小值(非数据没有意义)
create table stu (id int,name varchar(20));
insert into stu values(1,'张三'),(2,'李四');
select count(id) from stu;

在这里插入图片描述

由于聚合函数方法比较简单,我只列举了一个例子,大家可以自己尝试写一下,熟能生巧,不能眼高手低哦.

聚合函数可以与表达式进行连接哦!!!

select sum(chinese + math) from student;

4.1.2 group by子句

  • 进行分组查询时,SELECT 指定的字段必须是“分组依据字段”,其他字段若想出现在SELECT中则必须包含在聚合函数中.
  • group by指定一个列,就会把相同的属性放到一个组中.

下面创建了一个工资表

create table salary(id int,name varchar(20),role varchar(20),salary numeric(10,2));
insert into salary values(1,'张三','老板',50000),
(2,'李四','员工',3000),
(3,'王五','员工',3500),
(4,'赵六','厨师',8000),
(5,'刘大宝','厨师',7000);

查询该公司各个职业的平均工资

在这里插入图片描述

4.1.3 having

接下来,我们需要搞清楚,分组的条件是分组前还是分组后.

  • where是分组之前的
  • having是分组之后的

使用having进行条件判定

在这里插入图片描述

同时使用having和where进行条件判定

在这里插入图片描述

4.2 联合查询(多表查询)

把多个表联合在一起进行查询,在学习联合查询之前,我们需要了解笛卡尔积,联合查询就行基于笛卡尔积.(其实就是所谓的组合)

4.2.1 了解联合查询

1. 商品编号表

nameid
钢笔1
圆珠笔2

2. 商品价格表

idprice
115
28

3. 两表进行笛卡尔积

nameididprice
钢笔1115
钢笔128
圆珠笔2115
圆珠笔228

大家可以清楚的看到,笛卡尔积之后会产生大量无效数据,那么,什么是无效数据呢?比如上面钢笔,第三张表中,第二个钢笔的id不同,这时它就是无效数据,下图红色圈住的都是无效数据.

在这里插入图片描述

因此呢,我们使用联合查询将多表联系在一起的时候需要使用一定的条件去掉无效数据.
笛卡尔积 + 条件 = 联合查询

 create table goods(name varchar(20),id int);create table price(id int,price int);insert into goods values('钢笔',1),('圆珠笔',2);insert into price values(1,15),(2,8);

笛卡尔积的结果

在这里插入图片描述

联合查询的结果

在这里插入图片描述

join…on也可以进行笛卡尔积运算

在这里插入图片描述

4.2.2 内连接

select 字段 from 表1 别名1 [inner] join 表2 别名2 on 连接条件 and 其他条件;
select 字段 from 表1 别名1,表2 别名2 where 连接条件 and 其他条件;
其实上述的普通笛卡尔积运算就是内连接
如果是三张表,两两合并,前两个合并在与第三张表合并.

4.2.3 外连接

左外连接,以左边表作为参考,如果左边表没有的属性,连接后将不再显示.

在这里插入图片描述

右外连接,以右边表作为参考,如果右边表没有的属性,连接后将不再显示.

在这里插入图片描述

4.2.4 自连接

自己和自己做笛卡尔积,把行转成列进行一系列的操作.

下面会报错,因为自连接需要指定一下表的别名(规定)

在这里插入图片描述

指定别名后就可以正常输出

在这里插入图片描述

在这里插入图片描述

4.2.5 子查询

其实就是套娃操作,把多个查询语句合在一起.

1. 单行子查询

select name from goods where id = (select id from price where price = 8);

在这里插入图片描述
2. 多行子查询

select * from goods where id in (select id from price where price = 8 or price = 15);

下面查找id为1和2的商品
在这里插入图片描述
下面为多行子查询

在这里插入图片描述

需要注意的是,多行子查询需要关键词in,in后面加条件.

exists关键字也可以多行子查询(了解一下)

在这里插入图片描述

4.2.6 合并查询

所谓合并查询,就是把两个查询的语句合并在一起,通过关键字union来实现.

1. 通过or查询两条语句

在这里插入图片描述

2. 通过union来合并查询两条语句

在这里插入图片描述

注意:
union不会去重,union all会自动去重

后序:
今天的数据库学习就到这里了,期待大家的三连,希望小小的文章可以帮助到大家,我会不断努力,去更新内容,真诚希望与大家一起进步.💞💞💞

在这里插入图片描述

相关文章:

【数据库增删查改进阶版】保姆级教程带大家去学习更加复杂的sql语句,各种各样的约束以及各种各样的查询

前言: 大家好,我是良辰丫🍅🍅🍅,上一篇数据库我们一起学习了基础版本的增删查改,今天我们将接触更高级的增删查改,主要是学习一些约束条件,你们准备好了嘛?开…...

【C#基础】C# 正则表达式

序号系列文章7【C#基础】C# 常用数据结构8【C#基础】C# 面向对象编程9【C# 基础】C# 异常处理操作文章目录前言1,Regex 的概念2,Regex 的创建3,Regex 常用操作4,Regex 类的使用5,学习资源推荐结语前言 🌼 h…...

企业活动直播如何设置VIP观看席?

阿酷tony / 2023-2-28 / 长沙 / 多图内容企业活动直播如何设置VIP观看席?有意思吧,直播也能设vip席位。在直播间可以分设尊享嘉宾席、特邀VIP以及观众席三个区域,为企业提供多种用户接待模式,不仅能为嘉宾营造尊享VIP体验&#xf…...

线性代数学习-2

线性代数学习-2矩阵消元消元回代消元矩阵置换矩阵逆矩阵本文转载于https://herosunly.blog.csdn.net/article/details/88713747 该文章本人认为十分有用,便自己敲一遍笔记加固印象原文链接 原文这个笔记感觉比我老师讲的更加透彻,清晰。很好的展示了线性…...

Java 类

Java类是Java编程语言中的基本概念之一,用于描述对象的属性和方法。本文将详细介绍Java类的作用、定义和使用,以及在实际工作中的应用。 什么是Java类? Java类是一种用于描述对象的模板或蓝图。它定义了一个对象的属性和方法,以…...

GO中sync 包的 RWMutex 读写互斥锁

文章目录背景RWMutex 简介代码验证多个协程请求读锁 RLock() 和 RLock()读写交错 RLock() 和 Lock()写入的时候读取读取的时候写入请求多个写Lock() 和 Lock()背景 Mutex 互斥锁是严格锁定读和写,如果我们需要单独对读或者写添加锁需要使用 sync包的RWMutex 针对读…...

糖化学试剂55520-67-7,5-vinyl-2-deoxyuridine,5-乙烯基-2-脱氧尿苷特点分析说明

5-vinyl-2-deoxyuridine(5-VdU),5-vinyl-2-deoxyuridine,5-Vinyldeoxyuridine5-乙烯基-2-脱氧尿苷 | CAS:55520-67-7 | 纯度:95%试剂信息:CAS:55520-67-7所属类别:糖化学分子量:C11H…...

五年携手共话,FISCO BCOS为数实相生注入新动能

2月24日,作为深圳国际金融科技节系列活动之一,由深圳市地方金融监督管理局指导,微众银行、金链盟主办的“2022产业区块链年度峰会暨FISCO BCOS五周年生态大会”(下称“大会”)在深圳顺利召开。本次大会以“数实相生&am…...

特征可视化技术t-SNE

特征可视化技术t-SNE 一、理论介绍 想要了解t-SNE的数学原理可以参考t-SNE完整笔记 关于t-SNE的使用过程中有以下几点需要注意: t-SNE算法并不是每次都能产生相似结果。 t-SNE算法使得距离的概念适应于数据集中的区域密度变化。因此,它自然而然地扩大…...

.NET 导入导出Project(mpp)以及发布后遇到的Com组件问题

最近公司项目有一个对Project导入导出的操作,现在市面上能同时对Project进行导入导出的除了微软自带的Microsoft.Office.Interop.MSProject,还有就是Aspose.Tasks for .NET。但因为后者是收费软件且破解版的现阶段只到18.11,只支持.net Frame…...

centos 8安装配置 yum/dnf镜像源 以及 docker相关操作

Docker简介 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux或Windows操作系统的机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。 Docker组成部分: 镜…...

java基础之线程池

线程池1.线程池1.1 线程状态介绍1.2 线程池-基本原理1.3 线程池-Executors默认线程池1.4 线程池-Executors创建指定上限的线程池1.5 线程池-ThreadPoolExecutor1.6 线程池-参数详解1.7 线程池-非默认任务拒绝策略2. 原子性2.1 volatile-问题2.2 volatile解决2.3 synchronized解…...

Substrate 基础 -- 教程(Tutorials)

官网 github DOC 面向未来的区块链框架 Substrate 使开发人员能够快速、轻松地构建适合任何用例的未来 证明区块链(future proof blockchains)。 Substrate 文档包括区块链构建器(blockchain builders)和parachain 项目团队的概念、过程和参考信息。…...

一个线程两次调用start()方法会出现什么情况?

第17讲 | 一个线程两次调用start()方法会出现什么情况? 今天我们来深入聊聊线程,相信大家对于线程这个概念都不陌生,它是 Java 并发的基础元素,理解、操纵、诊断线程是 Java 工程师的必修课,但是你真的掌握线程了吗&am…...

看完再拿五分,软考高项时政提分必备

时事政治题作为软考信息系统项目管理师当中的必考题,每年都让不少考生头疼,主要吧,它一不在教材里,二考的又很随意,如果不是平时积累,专门注意去看,有时候很难答得对,弄得这几分就完…...

界面开发(1) --- PyQt5环境配置

PyQt5环境配置 第一步:首先安装社区版Pycharm 下载地址:https://www.jetbrains.com/pycharm/download/#sectionwindows 第二步:安装Anaconda3,配置虚拟环境 下载地址:https://www.anaconda.com/ 第三步&#xff1…...

shield分析

本文仅供学习交流,只提供关键思路不会给出完整代码,严禁用于非法用途,若有侵权请联系我删除!技术交流合作请私信! 熟练打开Fiddler设置好手机代理,摆弄半天一直抓不到包,应该是小红书监测到了F…...

Javaweb增删改查之【查】

Javaweb增删改查之【查】1.前端页面2.java链接数据库——集成mybatis2.1 建立层2.2 实体层entity2.3 mapper(dao层)2.4 mybatis配置文件2.5工具层util3.后台功能3.1servlet前几天跟着b站up主学javaweb登录,突然还是觉得这几年学了c是真的挺好…...

C++ STL:迭代器 Iterator

文章目录1、迭代器的类型2、traitsiterator_traitstype_traits泛化的指针,容器与算法的桥梁。提供一种方法,按照一定顺序访问一个聚合对象中各个元素,而又不暴露该对象的内部表示。既能对容器进行遍历,又可以对外隐藏容器的底层实…...

【C++】泛型编程——模板初阶

文章目录1. 泛型编程2. 函数模板2.1 函数模板的概念2.2 函数模板的使用2.3 函数模板的原理2.4 函数模板的实例化隐式实例化显式实例化2.5 模板参数的匹配原则3. 类模板1. 泛型编程 首先我们来思考一个问题:如何实现一个通用的交换函数呢? 即我们想交换两…...

数据结构入门--时间 空间复杂度

数据结构入门 时间 空间复杂度解析 目录 一. 算法效率 二. 时间复杂度 2.1 时间复杂度的概念 2.2 大O的渐进表示法 2.3 题目练习 题目一 题目二 题目三 题目四 题目五 题目六 题目七 三. 空间复杂度 3.1 题目练习 题目一 题目二 题目三 一. 算法效率 算法效率…...

计算机操作系统第一章

操作系统引论1.1操作系统的目标和作用定义:操作系统是控制管理计算机系统的硬软件,分配调度资源的系统软件。目标:方便性,有效性(提高系统资源的利用率、提高系统的吞吐量),可扩充性&#xff0c…...

ARM LDREX/STREX指令以及独占监控器详解

一、目的Linux驱动开发中有一个特别重要的知识点必须掌握,即并发、竞态以及同步。什么是并发?多个执行单元(进程、线程、中断)同时对一个共享资源的进行访问;此处的共享资源可以是外设、内存或者软件层面的全局变量静态…...

吉林大学 程序设计基础 2022级 实验复盘 2.23

本人能力有限,发出只为帮助有需要的人。 以下为实验课的复盘,内容会有大量失真,请多多包涵。 此次实验限时一个小时,时间很紧张,很多内容可能并不准确。 1.输出有规律的字母串 输入输出如下; 输入&…...

Linux系列 常用命令(目录和文件管理)vi和vim 编辑使用,(笔记)

作者简介:一名云计算网络运维人员、每天分享网络与运维的技术与干货。 座右铭:低头赶路,敬事如仪 个人主页:网络豆的主页​​​​​​ 目录 前言 一.常用命令(目录和文件管理) 1.查看文件内容 2.统计…...

OpenCV入门(一)Python环境的搭建

OpenCV入门(一)Python环境的搭建 因为有点Python基础,并且Python是比较好入门的编程语言,所以,机器视觉后面打算在Python这个平台下进行。 Windows平台OpenCV的Python开发环境搭建 1、Python 的下载与安装 Python是…...

3.查找算法:顺序查找和二分查找

查找查找,是指在一些数据元素中,通过一定的方法找出与给定关键字相同的数据元素的过程。列表查找(线性表查找):从列表中查找指定元素输入:列表,待查找元素输出:元素下标(…...

攻不下dfs不参加比赛(七)

标题 为什么练dfs题目总结重点为什么练dfs 相信学过数据结构的朋友都知道dfs(深度优先搜索)是里面相当重要的一种搜索算法,可能直接说大家感受不到有条件的大家可以去看看一些算法比赛。这些比赛中每一届或多或少都会牵扯到dfs,可能提到dfs大家都知道但是我们为了避免眼高手…...

精确光度预测计算工具:AGi32 Crack

什么是AGi32? AGi32首先是一种用于精确光度预测的计算工具:一种技术工具,可以计算任何情况下的照度,协助灯具放置和瞄准,并验证是否符合任意数量的照明标准。 然而,要增强对光度学结果的理解,还…...

47个SQL性能优化技巧,看到就是赚到

1、先了解MySQL的执行过程 了解了MySQL的执行过程,我们才知道如何进行sql优化。 (1)客户端发送一条查询语句到服务器; (2)服务器先查询缓存,如果命中缓存,则立即返回存储在缓存中的…...

河北网络公司网站建设/网络营销与直播电商学什么

文章目录1.什么是AOP2.springboot使用aop1.什么是AOP AOP就是通过动态为项目中某些类在运行过程中动态创建代理对象,在对象中完成附加功能,保证在处理业务时更加专注于自己的业务逻辑开发。 有以下几个概念: 1.通知(Advice)——给目标方法添…...

织梦后台怎么换网站模板/哪里可以学企业管理培训

Vue学习三之vue组件 本节目录 一 什么是组件二 v-model双向数据绑定三 组件基础四 父子组件传值五 平行组件传值六 xxx七 xxx八 xxx 一 什么是组件 首先给大家介绍一下组件(component)的概念 我们在进行vue开发的时候,还记得我们自己创建的vm对象吗,这个…...

wordpress服务器配置文件/网站排名怎么做上去

“Switch/case”算子的组要作用就是匹配一个字段中的所有值,符合条件的发送给下一个算子,这里以不同班级的学生为例子,以班级做区分分别发送给不同的算子,这里为了方便后续算子都使用“空操作(什么也不做)”算子。 完整的流程如图…...

广西新农村建设工作专题网站/软件关键词排名

先把杯子倒空,在灌水。学习先摆正自己的位置,再开始学习。刚开始接触新领域,不求完美。做好每天该做的事,学每天该学的知识。贵在坚持! http://kb.cnblogs.com/page/566528/转载于:https://www.cnblogs.com/xunzhaoren…...

佛山h5建站模板/智慧教育

关于多个线程同时调用单例模式的对象,该对象中方法的局部变量是否会受多个线程的影响对于那些会以多线程运行的单例类,例如Web应用中的Servlet,每个方法中对局部变量的操作都是在线程自己独立的内存区域内完成的,所以是线程安全的…...

运维网站制作/百度app下载安装官方免费版

分级聚类、K均值聚类 案例 假设有你一批博客数据,请根据博客内容进行聚类,分别用分级聚类和K-均值聚类查看博客的分组情况。 假设你使用API已经爬取了相关数据,并且已经整好数据格式如下: blogname,china,kids,music,yahoo,se…...