【数据库】CRUD常用函数UNION 和 UNION ALL
文章目录
- 一、CRUD
- 二、函数
- 2.1 字符函数 (Character Functions):
- 2.2 数字函数 (Numeric Functions):
- 2.3 日期函数 (Date Functions):
- 2.4 流程控制函数:
- 2.5 聚合函数:
- 三、UNION 和 UNION ALL
- 3.1 UNION:
- 3.2 UNION ALL
- 3.3 注意事项
一、CRUD
CRUD 是指数据库操作的四个基本动作:创建(Create)、读取(Read)、更新(Update)和删除(Delete)。这四个操作对应了数据库中的数据管理和维护的基本需求。下面是 MySQL 中实现 CRUD 操作的语法及其含义:
-
创建(Create) - 插入数据到表中:
INSERT INTO table_name (column1, column2, column3, ...) VALUES (value1, value2, value3, ...);table_name是要插入数据的表名。column1, column2, column3, ...是要插入数据的列名。value1, value2, value3, ...是要插入的具体数值。
-
读取(Read) - 查询数据:
-
查询所有列的所有行:
SELECT * FROM table_name; -
查询特定列的所有行:
SELECT column1, column2, ... FROM table_name; -
带条件查询:
-
-- 选择所有列或特定字段(用 <column> 替换)
SELECT *|<column>
-- 从一个或多个表中选择数据(用 <column1>,<column2> 替换)
FROM <table_name1>, <table_name2>, ...
-- 可选:指定筛选条件
WHERE <表达式>
-- 可选:对结果进行分组(用 <group by definition> 替换)
GROUP BY <group by definition>
-- 可选:对分组结果进行过滤条件判断(用 <expression> 替换)
HAVING <expression> [{<operator> <expression>} ...]
-- 可选:对结果进行排序(用 <order by definition> 替换)
ORDER BY <order by definition>
-- 可选:限制结果集的行数,可包括偏移量(用 <offset> 和 <row count> 替换)
LIMIT [<offset>] <row count>;
-
更新(Update) - 更新表中的数据:
UPDATE table_name SET column1 = value1, column2 = value2, ... WHERE condition;- 更新指定列的值,可以同时更新多个列。
condition是指定要更新的行的条件。
-
删除(Delete) - 从表中删除数据:
DELETE FROM table_name WHERE condition;- 删除满足条件的行,如果不指定条件,则会删除表中所有数据。
二、函数
2.1 字符函数 (Character Functions):
-
LOWER(): 转小写 - 将字符串中的字母全部转换为小写。
SELECT LOWER('SQL Course'); -- 输出 'sql course' -
UPPER(): 转大写 - 将字符串中的字母全部转换为大写。
SELECT UPPER('SQL Course'); -- 输出 'SQL COURSE' -
CONCAT(): 拼接 - 将多个字符串连接在一起。
SELECT CONCAT('Hello','World'); -- 输出 'HelloWorld' -
SUBSTRING(): 截取 - 从字符串中获取指定位置和长度的子串。
SELECT SUBSTRING('HelloWorld', 1, 5); -- 输出 'Hello' -
LENGTH(): 长度 - 返回字符串的长度。
SELECT LENGTH('HelloWorld'); -- 输出 10 -
INSTR(): 字符出现索引值 - 返回指定字符在字符串中第一次出现的位置。
SELECT INSTR('HelloWorld','W'); -- 输出 6 -
TRIM(): 字符截取后半段 - 从字符串开头去掉指定字符。
SELECT TRIM('H' FROM 'HelloWorld'); -- 输出 'elloWorld' -
REPLACE(): 字符替换 - 将字符串中的指定字符替换为另一个字符。
SELECT REPLACE('abcd','b','m'); -- 输出 'amcd'
2.2 数字函数 (Numeric Functions):
-
ROUND(): 四舍五入 - 将数字四舍五入到指定的小数位数。
SELECT ROUND(88.886, 2); -- 输出 88.89 -
TRUNCATE(): 截断 - 截断数字到指定的小数位数。
SELECT TRUNCATE(88.886, 2); -- 输出 88.88 -
MOD(): 求余 - 返回两个数相除的余数。
SELECT MOD(1600, 300); -- 输出 100
2.3 日期函数 (Date Functions):
-
NOW(): 获取当前日期和时间。
SELECT NOW(); -- 返回当前日期和时间 -
STR_TO_DATE( ): 将日期格式的字符转换成指定格式的日期。
SELECT STR_TO_DATE('9-18-1997', '%m-%d-%Y'); -- 输出 '1997-09-18' -
DATE_FORMAT(): 将日期转换成字符,指定格式。
SELECT DATE_FORMAT('2020/1/1', '%Y年%m月%d日'); -- 输出 '2020年01月01日'
2.4 流程控制函数:
-
CASE WHEN … THEN … ELSE … END: 类似于编程语言中的
switch语句。SELECT CASE WHEN score >= 90 THEN 'A'WHEN score >= 80 THEN 'B'ELSE 'C'END AS grade FROM student_scores; -
IF(condition, true_value, false_value): 条件判断函数。
SELECT IF(score >= 60, 'Pass', 'Fail') AS result FROM student_scores;
2.5 聚合函数:
-
SUM(column): 求和 - 计算指定列的总和。
SELECT SUM(sales) FROM sales_data; -
AVG(column): 平均值 - 计算指定列的平均值。
SELECT AVG(price) FROM product_prices; -
MAX(column): 最大值 - 获取指定列的最大值。
SELECT MAX(temperature) FROM weather_data; -
MIN(column): 最小值 - 获取指定列的最小值。
SELECT MIN(quantity) FROM inventory; -
COUNT(column): 计算个数 - 统计指定列的非空值数量。
SELECT COUNT(customer_id) FROM customers;
三、UNION 和 UNION ALL
UNION 和 UNION ALL 是 SQL 中用于合并两个或多个查询结果的操作符。它们主要用于合并具有相似结构的多个查询的结果集。下
3.1 UNION:
-
去重:
UNION操作符会合并两个查询的结果集,并且会自动去除重复的行,确保最终的结果集中不包含重复的行。 -
语法:
SELECT column1, column2, ... FROM table1 WHERE condition UNION SELECT column1, column2, ... FROM table2 WHERE condition; -
示例:
SELECT city FROM customers WHERE country = 'USA' UNION SELECT city FROM suppliers WHERE country = 'USA';上述示例将返回所有来自
customers和suppliers表中位于美国的城市,并确保每个城市只出现一次。
3.2 UNION ALL
-
不去重:
UNION ALL同样合并两个查询的结果集,但不去除重复的行,即它保留所有的行,包括重复的。 -
语法:
SELECT column1, column2, ... FROM table1 WHERE condition UNION ALL SELECT column1, column2, ... FROM table2 WHERE condition; -
示例:
SELECT city FROM customers WHERE country = 'USA' UNION ALL SELECT city FROM suppliers WHERE country = 'USA';上述示例将返回所有来自 customers 和 suppliers 表中位于美国的城市,包括重复的行。
3.3 注意事项
-
UNION和UNION ALL要求两个查询的结果集具有相同的列数和相似的数据类型。 -
UNION的性能可能会稍逊于UNION ALL,因为它需要额外的步骤去重。 -
如果你确定结果集不包含重复行,或者你希望保留重复行,可以使用
UNION ALL来获得更好的性能。
相关文章:
【数据库】CRUD常用函数UNION 和 UNION ALL
文章目录 一、CRUD二、函数2.1 字符函数 (Character Functions):2.2 数字函数 (Numeric Functions):2.3 日期函数 (Date Functions):2.4 流程控制函数:2.5 聚合函数: 三、UNION 和 UNION ALL3.1 UNION:3.2 UNION ALL3.3 注意事项 一、CRUD CRUD 是指数据库操作的四…...
Adding Conditional Control to Text-to-Image Diffusion Models——【论文笔记】
本文发表于ICCV2023 论文地址:ICCV 2023 Open Access Repository (thecvf.com) 官方实现代码:lllyasviel/ControlNet: Let us control diffusion models! (github.com) Abstract 论文提出了一种神经网络架构ControlNet,可以将空间条件控制添加到大型…...
Python与人工智能
Python 是一种广泛用于人工智能(AI)开发的编程语言。Python具有简洁的语法和强大的库支持,使其成为数据科学、机器学习和深度学习的理想选择。 Python中有许多库可以帮助实现人工智能,其中最流行的包括TensorFlow和PyTorch。这些…...
【Docker】Docker基础
文章目录 安装使用帮助启动命令镜像命令容器命令 安装 # 卸载旧版本 sudo yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine # 设置存储库 sudo yum install -y yum-utils …...
linux异常情况,排查处理中
登录客户环境后,发现一个奇怪情况如下图,之前也遇到过,直接fuser -ck /backup操作的话,主机将会重启,因数据库运行中,等待停机维护时间,同时也在想办法不重启的情况下解决该问题 [rootdb ~]# f…...
Spring Boot参数校验方案
NotNull:值不能为null;NotEmpty:字符串、集合或数组的值不能为空,即长度大于0;NotBlank:字符串的值不能为空白,即不能只包含空格;Size:字符串、集合或数组的大小是否在指…...
【漏洞复现】ActiveMQ反序列化漏洞(CVE-2015-5254)
Nx01 产品简介 Apache ActiveMQ是Apache软件基金会所研发的开放源代码消息中间件。ActiveMQ是消息队列服务,是面向消息中间件(MOM)的最终实现,它为企业消息传递提供高可用、出色性能、可扩展、稳定和安全保障。 Nx02 漏洞描述 Re…...
面试题:MySQL误删表数据,如何快速恢复丢失的数据?
相信后端研发的同学在开发过程经常会遇到产品临时修改线上数据的需求,如果手法很稳那么很庆幸可以很快完成任务,很不幸某一天突然手一抖把表里的数据修改错误或者误删了,这个时候你会发现各种问题反馈接踵而来。 如果身边有BDA或者有这方面经…...
李沐之神经网络基础
目录 1.模型构造 1.1层和块 1.2自定义块 1.3顺序块 1.4在前向传播函数中执行代码 2.参数管理 2.1参数访问 2.2参数初始化 3.自定义层 3.1不带参数的层 3.2带参数的层 4.读写文件 4.1加载和保存张量 4.2加载和保存模型参数 1.模型构造 1.1层和块 import torch fr…...
【docker】使用 Dockerfile 构建镜像
一、什么是Dockerfile Dockerfile 是用于构建 Docker 镜像的文本文件。它包含了一系列的指令,用于描述如何构建镜像的步骤和配置。 通过编写 Dockerfile,您可以定义镜像的基础环境、安装软件包、复制文件、设置环境变量等操作。Dockerfile 提供了一种可…...
计算机网络—— 概述
概述 1.1 因特网概述 网络、互联网和因特网 网络由若干结点和连接这些结点的链路组成多个网络还可以通过路由器互联起来,这样就构成了一个覆盖范围更大的网络,即互联网(或互连网)。因特网(Internet)是世…...
“超人练习法”系列06:如何更好地掌握技能?
01 掌握的阶段 关于人类学习新事物的最生动、最精妙的比喻,我是从笑来老师那里学到的。 他指出,学习新知识、新概念犹如在构建自己大脑皮层,每个习得的概念就像是大脑皮层上的一个个微小神经元。 一个看似聪明、博学的人,总能在各…...
【华为OD机试真题2023CD卷 JAVAJS】字符串拼接
华为OD2023(C&D卷)机试题库全覆盖,刷题指南点这里 字符串拼接 知识点数组递归 时间限制:1s 空间限制:256MB 限定语言:不限 题目描述: 给定M(0<M<=30)个字符(a-z),从中取出任意字符(每个字符只能用一次)拼接成长度为N(0<N<=5)的字符串,要求相同的字…...
【算法】链表-20240109
这里写目录标题 一、141. 环形链表二、876. 链表的中间结点三、面试题 02.01. 移除重复节点 一、141. 环形链表 简单 给你一个链表的头节点 head ,判断链表中是否有环。 如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中…...
机器学习系列--R语言随机森林进行生存分析(2)
随机森林(Breiman 2001a)(RF)是一种非参数统计方法,需要没有关于响应的协变关系的分布假设。RF是一种强大的、非线性的技术,通过拟合一组树来稳定预测精度模型估计。随机生存森林(RSF࿰…...
Flutter GetX 之 状态管理
上一篇文章为大家介绍了 GetX的 路由管理,让大家对GetX有了初步了解,今天为大家介绍一下GetX的 状态管理。 StatelessWidget 和 StatefulWidget 介绍 在介绍之前,先简单介绍一下 Flutter 页面的 StatelessWidget 和 StatefulWidget ,其实Flutter的本质是万物都是Widget,…...
e2studio开发磁力计LIS2MDL(1)----轮询获取磁力计数据
e2studio开发磁力计LIS2MDL.1--轮询获取磁力计数据 概述视频教学样品申请源码下载速率新建工程工程模板保存工程路径芯片配置工程模板选择时钟设置UART配置UART属性配置设置e2studio堆栈e2studio的重定向printf设置R_SCI_UART_Open()函数原型回调函数user_uart_callback ()prin…...
C++ 字符串大小写转换,替换,文件保存 方法封装
此示例程序方法已经封装好使用std::islower()函数可以检查一个字符是否是小写字母,使用std::isupper()函数可以检查一个字符是否是大写字母。 如果传入的字母是小写字母,则使用std::toupper()函数将其转换为大写字母,并输出转换后的结果。 如果输入的字母是大写字母,则使…...
计算机基础面试题 |19.精选计算机基础面试题
🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6 🍨 阿珊和她的猫_CSDN个人主页 🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》 🍚 蓝桥云课签约作者、已在蓝桥云…...
mysql 添加用户并分配select权限
1.root用户先登录或者在可执行界面 1.1 选择mysql 点击mysql 或者在命令行 use mysql 1.2创建用户 CREATE USER username% IDENTIFIED BY password; 备注1:%替换为可访问数据库的ip,例如“127.0.0.1”“192.168.1.1”,使用“%”表示不限制…...
别再为答辩 PPT 秃头了!PaperXie 的 AI PPT 功能,让你把时间花在更重要的地方
paperxie-免费查重复率aigc检测/开题报告/毕业论文/智能排版/文献综述/AI PPThttps://www.paperxie.cn/ppt/createhttps://www.paperxie.cn/ppt/create 距离毕业论文答辩只剩半个月,你的 PPT 还停留在 “空白文档” 阶段吗? 我见过太多同学在这个阶段陷…...
OpenFOAM-dev后处理与数据可视化:ParaView与fieldFunctionObjects实战指南
OpenFOAM-dev后处理与数据可视化:ParaView与fieldFunctionObjects实战指南 【免费下载链接】OpenFOAM-dev OpenFOAM Foundation development repository 项目地址: https://gitcode.com/gh_mirrors/op/OpenFOAM-dev OpenFOAM-dev作为开源CFD领域的核心工具&a…...
职慧AI陪练产品全景解析:六大训练模式如何覆盖销售培养全场景
摘要:市面上的AI陪练产品大多只能做"话术对练",真正能覆盖销售能力培养全链路的产品长什么样?本文深度拆解职行力职慧AI陪练的六大训练模式——话术陪练、情景对话、智能考试、微课学习、AI专家问答、训练官带教,以及背…...
5分钟上手iFakeLocation:无需越狱的iOS虚拟定位神器
5分钟上手iFakeLocation:无需越狱的iOS虚拟定位神器 【免费下载链接】iFakeLocation Simulate locations on iOS devices on Windows, Mac and Ubuntu. 项目地址: https://gitcode.com/gh_mirrors/if/iFakeLocation iFakeLocation是一款强大的跨平台开源工具…...
【Zotero-Perplexity协同系统白皮书】:基于127个真实科研场景验证的整合失败率下降91.6%的工程化方案
更多请点击: https://intelliparadigm.com 第一章:Zotero-Perplexity协同系统白皮书概览 Zotero-Perplexity协同系统是一个面向学术研究者的智能文献工作流增强框架,它将Zotero本地文献管理能力与Perplexity AI的实时语义检索、上下文感知问…...
机器学习在芯片电容提取中的应用与挑战
1. 电容提取的技术挑战与机器学习机遇在芯片设计流程中,电容提取是决定最终产品性能的关键环节。当设计进入物理实现阶段,工程师需要精确计算互连结构中导体间的寄生电容,这些数据直接影响时序收敛和功耗分析。传统基于数值求解器的方法&…...
百度网盘直链解析:打破速度限制的智能解决方案
百度网盘直链解析:打破速度限制的智能解决方案 【免费下载链接】baidu-wangpan-parse 获取百度网盘分享文件的下载地址 项目地址: https://gitcode.com/gh_mirrors/ba/baidu-wangpan-parse 你是否曾经面对百度网盘的缓慢下载速度感到无奈?等待一个…...
【数字孪生实战案例】怎样设置数据筛选条件,精准控制电子地图飞线的呈现效果?~山海鲸可视化
在数据可视化大屏应用里,电子地图飞线是展示跨地域关联数据的重要载体。当飞线数据量大、维度繁杂时,通过配置数据条件对地图飞线做精准筛选,能够过滤冗余信息、聚焦核心数据,让地图呈现更简洁直观,有效提升整体可视化…...
告别单调!用LVGL Button控件打造3种高级交互动效(附完整C代码)
用LVGL Button控件实现高级交互动效的实战指南 在嵌入式设备上打造流畅、生动的用户界面一直是开发者的挑战。LVGL作为轻量级图形库,其Button控件的基础功能虽然简单,但通过巧妙运用样式和动画API,可以实现媲美移动端的高级交互效果。本文将深…...
ARM PMU性能监控架构与寄存器详解
1. ARM PMU性能监控架构概述 性能监控单元(Performance Monitoring Unit, PMU)是现代处理器中用于硬件级性能分析的关键模块。作为ARM架构的重要组成部分,PMU通过一组可编程计数器来记录处理器运行过程中发生的各类微架构事件,为系统性能分析和优化提供数…...
