MySQL语句学习第三篇_数据库

MySQL语句学习第三篇_数据库
专栏记录MySQL的学习,感谢大家观看。

本章的专栏📚➡️MySQL语法学习
本博客前一章节指向➡️MySQL语句学习第二篇
本人的博客➡️:如烟花般绚烂却又稍纵即逝的主页
在这里插入图片描述

文章目录

  • MySQL的基础操作(改与查)
      • 修改操作
      • 删除操作
  • 数据库约束
  • 查询操作的进阶
    • 聚合查询
      • 聚合分组查询
      • 聚合分组表达式查询
    • 联合查询/多表查询
  • index索引

MySQL的基础操作(改与查)

修改操作

修改指令:

通过update 表名 set 列名 修改的字段来修改数据,也可以增加条件(where/order by),指定修改行。

updata database_name set colName = val where conditions/order by;#for example1
update exam_result set math=math+10 where name='张三';
#for example2
update exam_result set math=math+30 order by chinese+english+math desc limit 3;

删除操作

删除操作:

delete from 表名 where条件/order by/limit;
不指定条件删除整张表内容(空表)。

delete from database_name where name ='张三';

数据库约束

1.NULL指令:

创建时添加not null/NOT NULL ,创建成功后,当插入或者修改字段时无法插入或者修改为空值。

create table table_name(colNmae type NOT NULL);
#for example
create table person(name varchar(10) not null,age int NOT NULL);

2.UNIQUE指令:

创建时将unique置入类型后面,不可再次重复插入或者修改为此类型的值。

create table table_name(colName type unique);
#for example
create table person(id int,name varchar(10) UNIQUE);

3.DEFAULT指令:

通过创建表,指定类型的默认值,在不赋值的情况下,插入或者修改指定的字段时,显示default默认值。

create table table_name(colName type default defaultName);
#for example
create table person(id int,name varchar(10) default '未命名');

4.PRIMARY KEY指令:

primary key主键的功能:在插入或者修改带有primary key 的类型字段时,不能为空,且不能有重复字段添加。
一个表中只能有一个primary key

create table table_name(colName type primary key);
#for example
create table person(age int primary key);

主键key的auto_increment自动增长指令:

通过自增方式通过数据库来自动分配字段,整数类型(int /bigint)

create table table_name(colName int primary key auto_increment);
#for example
create table person(id int primary key auto_increment);
##自动插入1,2
insert into person values(null),(null);

5.FOREIGN KEY指令:

foreign key 外键:描述两个表之间的关联关系(父表与子表)
父表约束子表,子表被约束。
当子表超出父表给定的关联值时,则会报错。需要搭配primary key来使用。
references 意思引用与父亲表中的val值。
当子表插入时,查看子表中的father_val1中的值在父表中是否存在,不存在则报错。
当父表中已经被子表引用,则无法删除或者修改,需要将子表删除后,在删除父表。

#父表
create table father(colName1 int primary key,colName2 varchar(10));
#子表
create table child2(colName int primary key 
,father_val1 int,
foreign key(father_val1) references father(colName1) );


查询操作的进阶

1.查询搭配插入使用:

将table2所有的查询结果插入table1中,可以在后面搭配表达式where来使用。
这里的两个表的类型和列数需要匹配,否则报错.

insert into table1 select*from table2;

聚合查询

sql中提供的聚合函数:

函数说明 (可以添加去重操作distinct
COUNT()使用*或者指定字段在查询计算结构中出现的个数(不指定情况下包含NULL值指定不包含NULL值)
SUM()只适用于数字类型的字段或变量(算数运算)。不包含NULL值
MAX()适用于数值类型、字符串类型、日期时间类型的字段(或变量)不包含NULL值
MIN()适用于数值类型、字符串类型、日期时间类型的字段(或变量)不包含NULL值
AVG()只适用于数值类型的字段或变量。不包含NULL值

1.COUNT指令:

查询行数(也可以通过运算符来计算获取值)
如果字符串为数字则转换为double类型的数字来进行计算
sum可以将每个列和行相加,获得一个最终的总和。

#先执行select(*)在进行统计具体几行.
#*来获取所有行
select count(*) from table;#当输入的是字段属性时,获取的是不为null的行数select count(colName) from table_name;# 指定列

2.SUM指令:

针对数字类型进行求和的算数运算

select sum(colName'数字类型的字段') from table_name;

3.AVG 指令:

支持数字类型进行平均值的算数运算

select sum(colName'数字类型的字段') from table_name;

4.MAX和MIN指令:

获取最大值和最小值

#max
select max(colName) from table_name;
#min
select min(colName) from table_name;

聚合分组查询

使用group by进行分组,针对每个分组,在分别进行聚合查询。
通过将valName相同的值来分组,将每个组获进行计算。

elect colName,avg(colName'整数') from emp group by colName;

聚合分组表达式查询

where表达式聚合查询:

先通过表达式来筛选,表达式需要在分组之前进行。
先执行where条件 在进行分组 在进行聚合。

select colName ,avg(salary) from emp where name!='张三' group by valName;

having表达式聚合查询:

通过分组后,然后进行条件筛选,最后进行聚合查询。表达式在分组之后
先执行分组 在进行筛选 在最后进行聚合。

select colName,avg(salary) from emp group by colName having avg(salary)<20000;

分组中可以包含两个表达式(包含分组前where和分组后having)。


联合查询/多表查询

笛卡尔积:两个集合(表)进行合并后的乘积,两张表的记录中表记录与另一张表的所有记录进行记录排列组合。在这里插入图片描述在这里插入图片描述
继续进行继续筛选
在这里插入图片描述

而这时候会出现许多非法的字段,无意义的数据,这时候对笛卡尔积需要限定条件,让每张表进行关联。

#笛卡尔积
select *from colName1,colName2;
# 筛选有效数据
select *from colName1,colName2, where table_name1.colName1=table_name2.colName2;# and 接表达式继续筛选
select *from colName1,colName2, where 
table_name1.colName1=table_name2.colName2 and.....;#having表达式,进行分组之后的表达式
select *from colName1,colName2, where
table_name1.colName1=table_name2.colName2 and.....
group by colName1 having ...;

当数据库使用select查询的时候
首先遍历表,然后将当前行带入到条件中,看条件是否成立,当条件成立后保留。
当表存储非常大的时候,这样的遍历成本比较高,时间复杂度为O(N)
当数据库把数据存储在硬盘上,而每次读取一个数据都需要读取硬盘,消耗非常大。


index索引

首先索引是针对查询操作引入的优化手段,可以通过索引来加快查询的速度,避免对表的遍历。

而索引能提高查询的速度,但是也有一定的代价。
生成索引需要一系列的数据结构,以及一系列额外的数据,存储到硬盘空间中的。
降低插入修改删除的速度。当进行这一系列操作时,也要计算索引的位置。
primary 、foreign 、unique 中在mysql中自动生成索引(主动生成的索引不能被删除)。

查找index指令:

show index from `表名`;

创建index指令:

当创建索引时,需要遍历表中数据,需要提前规划。

create index `索引名` on `表名()`;

删除index指令:

drop index `索引名` on '表明';

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/63665.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

windows将文件推给Android真机/实机

记录一下 因为以前只试过从真机实机中将文件推给windows 但是从windows只简单复制粘贴的话会一直报错。 1.电脑安装adb 2.手机开启开发者模式 usb调试 3.usb连接选择文件传输 4.推送命令adb push 文件路径 /sdcard/download 步骤1和2和3不作赘述&#xff0c;可以搜相关配置教程…

C语言——验证“哥德巴赫猜想”

问题描述&#xff1a; 验证"哥德巴赫猜想" 任何一个大于2的偶数都可以表示为两个质数之和。例如&#xff0c;4可以表示为22&#xff0c;6可以表示为33&#xff0c;8可以表示为35等 //验证"哥德巴赫猜想" //任何一个大于2的偶数都可以表示为两个质数之和…

利用 360 安全卫士极速版关闭电脑开机自启动软件教程

在使用电脑的过程中&#xff0c;过多的开机自启动软件会严重拖慢电脑的开机速度&#xff0c;影响我们的使用体验。本教程中简鹿办公将详细介绍如何使用 360 安全卫士极速版关闭电脑开机自启动软件&#xff0c;让您的电脑开机更加迅速流畅。 一、打开 360 安全卫士极速版 在电…

分布式搜索引擎之elasticsearch基本使用2

分布式搜索引擎之elasticsearch基本使用2 在分布式搜索引擎之elasticsearch基本使用1中&#xff0c;我们已经导入了大量数据到elasticsearch中&#xff0c;实现了elasticsearch的数据存储功能。但elasticsearch最擅长的还是搜索和数据分析。 所以j接下来&#xff0c;我们研究下…

[ACTF2020 新生赛]Include

感觉毫无头绪e一下&#xff0c;发现要使用伪协议 伪协议&#xff1a;是PHP自己支持的一种协议与封装协议&#xff0c;简单说就是PHP定义的一种特殊访问资源的方法。 2.什么时候用PHP伪协议? 可能遇到的文件包含函数&#xff1a; 1、include 2、require 3、include_once 4、r…

vue3使用Eachart图表库踩坑记录

前言 大家好我是没钱的君子下流坯&#xff0c;用自己的话解释自己的知识。很久很更新了&#xff0c;最近一直在加班&#xff0c;今天记录一个eachar图表报警告说过去不到当前DOM节点的宽高导致页面中的图表宽高不正确的坑。 案例 就是一些基础的图形的使用&#xff0c;一个后…

【系统架构核心服务设计】使用 Redis ZSET 实现排行榜服务

目录 一、排行榜的应用场景 二、排行榜技术的特点 三、使用Redis ZSET实现排行榜 3.1 引入依赖 3.2 配置Redis连接 3.3 创建实体类&#xff08;可选&#xff09; 3.4 编写 Redis 操作服务层 3.5 编写控制器层 3.6 测试 3.6.1 测试 addMovieScore 接口 3.6.2 测试 g…

架构15-服务网格

零、文章目录 架构15-服务网格 1、透明通信的涅槃 &#xff08;1&#xff09;服务网格 概念 服务网格是一种处理程序间通信的基础设施&#xff0c;主要由数据平面和控制平面组成。它通过边车代理和控制程序管理程序间的通信&#xff0c;弥补了容器编排系统对分布式应用细粒…

constexpr、const和 #define 的比较

constexpr、const 和 #define 的比较 一、定义常量 constexpr 定义&#xff1a;constexpr用于定义在编译期可求值的常量表达式。示例&#xff1a;constexpr int x 5;这里&#xff0c;x的值在编译期就确定为5。 const 定义&#xff1a;const表示变量在运行期间不能被修改&…

C# RSA加密和解密,RSA生成私钥和公钥

C# RSA加密和解密&#xff0c;RSA生成私钥和公钥&#xff08;使用XML格式秘钥&#xff09; 目录 前言生成xml格式的公钥和私钥 PrivateKeyPublicKey测试加密、解密 方案1&#xff1a;RSA公钥加密&#xff0c;RSA私钥解密方案2&#xff1a;RSA私钥加密&#xff0c;RSA私钥解密…

Linux命令进阶·软链接命令(ln)、查看系统时间命令(date)、自动校准系统时间程序(ntp)

目录 1. 软链接——ln命令 2. 查看系统时间——date命令 3. 自动校准系统时间——ntp程序 1. 软链接——ln命令 在系统中创建软链接&#xff0c;可以将文件、文件夹链接到其他位置。作用相当于windows中的快捷方式。 语法&#xff1a;ln -s 参数1 参数2 -s选项&#xff…

NanoLog起步笔记-7-log解压过程初探

nonolog起步笔记-6-log解压过程初探 再看解压过程建立调试工程修改makefile添加新的launch项 注&#xff1a;重新学习nanolog的README.mdPost-Execution Log Decompressor 下面我们尝试了解&#xff0c;解压的过程&#xff0c;是如何得到文件头部的meta信息的。 再看解压过程 …

人工智能大模型LLM开源资源汇总(持续更新)

说明 目前是大范围整理阶段&#xff0c;所以存在大量机翻说明&#xff0c;后续会逐渐补充和完善资料&#xff0c;减少机翻并增加说明。 Github上的汇总资源&#xff08;大部分英文&#xff09; awesome-production-machine-learning 此存储库包含一系列精选的优秀开源库&am…

C++实现排序算法:冒泡排序

目录 前言 冒泡排序性质 C代码实现冒泡排序 冒泡图解 第一趟排序 第二趟排序 第三趟排序 排序结果 结语 前言 冒泡排序的基本思想是通过从前往后&#xff08;从后往前&#xff09;两两比较&#xff0c;若为逆序&#xff08;即arr[i] < arr[i 1]&#xff09;则交换…

中介者模式的理解和实践

一、中介者模式概述 中介者模式&#xff08;Mediator Pattern&#xff09;&#xff0c;也称为调解者模式或调停者模式&#xff0c;是一种行为设计模式。它的核心思想是通过引入一个中介者对象来封装一系列对象之间的交互&#xff0c;使得这些对象不必直接相互作用&#xff0c;从…

PlantUML——类图

背景 类图是UML模型中的静态视图&#xff0c;其主要作用包括&#xff1a; 描述系统的结构化设计&#xff0c;显示出类、接口以及它们之间的静态结构和关系。简化对系统的理解&#xff0c;是系统分析与设计阶段的重要产物&#xff0c;也是系统编码和测试的重要模型依据。 在U…

入选国家数据局案例!浙江“一体化智能化公共数据平台”总体架构详解~

国家数据局在2024中国国际大数据产业博览会上发布了首批50个数字中国建设典型案例。案例涉及数据基础设施、数据资源、数字技术创新、数字政府、数字经济、数字社会、数字文化、数字生态文明等领域&#xff0c;集中反映了近年来数字中国建设的实践和成效。 其中&#xff0c;由…

vscode IntelliSense Configurations

IntelliSense 是一个强大的代码补全和代码分析功能&#xff0c;它可以帮助开发者提高编程效率。图中显示的是 VSCode 的 IntelliSense 配置界面&#xff0c;具体配置如下&#xff1a; Compiler path&#xff08;编译器路径&#xff09;: 这里指定了用于构建项目的编译器的完整路…

同三维TL200H2S6 6机位精品教育录播主机

录制点播、直播导播、互动、音频处理器、中控等多功能为一体 8路视频输入:6路SDI1路HDMI1(4K30)1路(3选1:HDMI2/2路VGA) 2路视频输出&#xff1a;1路HDMI1(4K30)1路&#…

技术型企业如何高效搭建企业博客以增强品牌影响力和市场竞争力

在数字化时代&#xff0c;技术型企业面临着激烈的市场竞争和快速变化的行业环境。为了在这场竞争中脱颖而出&#xff0c;企业需要寻找新的营销渠道和品牌建设工具。企业博客作为一种低成本、高效率的在线内容平台&#xff0c;已经成为技术型企业增强品牌影响力和市场竞争力的重…