灯塔:MYSQL笔记(2)函数

news2024/9/24 7:21:32

函数 是指一段可以直接被另一段程序调用的程序或代码。

字符串函数

SELECT 函数(参数);

 

数值函数

SELECT 函数(参数);

-- 生成一个六位验证码
select lpad(round(rand()*1000000,0) ,6,'0')as '验证码';

日期函数

流程函数

总结:

约束:

1. 概述:约束是作用于表中字段上的规则,用于限制储存在表中的数据

2. 目的:保证数据库中数据的正确、有效性和完整性。

3. 分类:

添加主键:

 ①在定义字段时直接添加

create table if not exist '表名'(        
            字段1 字段1类型 primary key auto_inncrement [comment 字段1注释],
            字段2 字段2类型 [comment 字段2注释],
            字段3 字段3类型 [comment 字段3注释],
            .......
) [comment 字段1注释];

②在创建完字段后选择主键字段

create table if not exist '表名'(        
            字段1 字段1类型  auto_inncrement [comment 字段1注释],
            字段2 字段2类型 [comment 字段2注释],
            字段3 字段3类型 [comment 字段3注释],
            .......
            primary key(字段名)
) [comment 字段1注释];

③通过alter table 添加

create table if not exist '表名'(        
            字段1 字段1类型  [comment 字段1注释],
            字段2 字段2类型 [comment 字段2注释],
            字段3 字段3类型 [comment 字段3注释],
            .......
) [comment 字段1注释];
alter table 表名 add constraint 自定义主键名 primary key (添加主键的字段);

删除主键:

如果主键自增 :

alter table 表名 change 字段名 新字段名 数据类型;
alter table 表名 drop primary key;

否则,

alter table 表名drop primary key;

外键:

 概念:

外键用来让两张表的数据之间建立连接,从而保证数据的一致性和完整性。

 语法:

添加外键:

删除/更新行为:

小结:

多表查询:

在项目开发中,再进行数据库表结构设计时,会根据业务模块之间的关系,分析并设计表结构,由于业务之间相互关联,所以各个表结构之间也存在着各种联系,基本上分为三种:

一对一:

案例:部门与员工的关系

关系:一个部门对应多个员工,一个员工对应一个部门

实现:在多的一方建立外键,指向一的一方的主键

多对多:

案例:学生与课程的关系

关系:一个学生可以选修多门课程,一门课程可以供多个学生选择

实现:建立第三张中间表,中间表中少包括两个外键,分别关联两个主键

一对一:

 案例:用户与用户详情的关系

关系:一对一关系,多用于单表拆分,将一张表的基础字段放在一张表中,其他详情字段放在另一张表中,以提升操作效率

实现:在任意一方加上外键,关联另一方的主键,并且设置外键为唯一的(UNIQUE)

多表查询概述:

连接查询-内连接:

内连接是查询左表和右表交集的部分

连接查询-外连接:

外连接会包含左表或右表的全部数据

select dept.name,emp1.* from dept right outer join emp1 on dept.id = emp1.dept_id;
select dept.name,emp1.* from dept  left  join emp1 on dept.id = emp1.dept_id;

上面这两条语句产生的效果是一样的,所以 右外连接通常可以改成左外连接。

自连接:

语法:

SELECT 字段列表FROM 表名A 别名A JOIN 表A 别名B ON 条件...;

自连接查询,可以是内连接查询,也可以是外连接查询。

-- 自连接 

-- 1. 查询员工 及其 所属领导的名字

-- 表结构:emp

select a.name,b.name from emp1 a ,emp1 b where a.managerid=b.managerid;

显示结果如下: 

-- 2. 查询所有员工  emp1 及其领导的名字 emp1 ,如果员工没有领导,也需要查询出来

-- 表结构 :emp a ,emp b

select a.name '员工',b.name '领导' from emp1 a left join emp1 b on a.managerid=b.id;

 显示结果如下:

联合查询-union,union all

对于联合查询的多张表的列数必须保持一致,字段类型也需要保持一致。

union :对两个结果集进行并集操作,不包括重复行,相当于distinct,同时进行默认规则的排序。

union all:对两个结果集进行并集操作,包括重复行。即所有的结果全部显示,不管重复与否。它也不会对获取结果进行排序操作。

例如:将薪资低于5000的员工,和年龄大于50的员工全部查询出来

union all

select *from emp where emp.age>50
union all
select *from emp where salary<5000;

 其结果显示如下:

仅仅是将两条语句的执行结果统一列了出来, 结果会有重复的数据,不一定会存在对着两条语句都成立的结果。

union:

select *from emp where emp.age>50
union 
select *from emp where salary<5000;

结果如下:

子查询:

标量子查询:

子查询返回的结果是单个值(数值、字符串、日期等),最简单的形式,这种子查询成为标量子查询。

常用的操作符: =  <>  >  >=  <  <=

- 标量子查询
-- 1. 查询“销售部”的所有员工信息
-- a 查询 “销售部”部们ID
select id from dept where dept.name='销售部';

-- b. 根据销售部部门ID,查询员工信息
select * from emp1 where dept_id=(select id from dept where dept.name='销售部');

-- 2.查询“赵敏”入职之后的员工信息
-- a 查询 赵敏 的入职日期
select emp1.entrydate from emp1 where name='赵敏';

-- b 查询指定入职的员工信息
select *from emp1 where emp1.entrydate> (select emp1.entrydate from emp1 where name='赵敏');
列子查询:

子查询返回的结果是一列(可以是多行),这种子查询称为列子查询。

常用操作符: IN ,NOT IN , ANY , SOME , ALL

-- 列子查询
-- 1 查询 销售部 和市场部 的所有员工信息
-- a 查询 销售部 和 市场部 的部门ID
    select id from dept where name='销售部' or name='市场部';
-- b 根据部门ID 查询员工信息
    select *from emp1 where dept_id in (select id from dept where name='销售部' or name='市场部');

-- 2 查询比销售部所有人工资都高得员工信息
--  a 查询所有 销售部的员工工资
select  id from dept  where name='销售部';
select salary from emp1 where dept_id=(select  id from dept  where name='销售部');

-- b 比销售部所有人工资都高得员工信息
    select * from emp1 where salary >(select salary from emp1 where dept_id=(select  id from dept  where name='销售部'));
-- 3.查询比销售部其中任意一人工资高的员工信息
-- a 查询销售部的所有人的工资
select salary from emp1 where dept_id=(select id from dept where name='销售部' );

-- b 比销售部其中任意一人工资高的员工信息
select *from emp1 where salary > all (select salary from emp1 where dept_id=(select  id from dept  where name='销售部'));
行子查询:

子查询返回的结果是一行(可以是多列),这种子查询称为行子查询。

常用的操作符:= 、<> 、IN 、NOT 、IN

-- 行子查询
-- 1.查询与赵敏 的薪资及直属领导相同的员工信息
-- a 查询 赵敏 的薪资及直属领导
select salary ,managerid from emp1 where name='赵敏';

-- b 查询 与赵敏 的薪资及直属领导相同的员工信息
select * from emp1 where (salary,managerid )=(select salary ,managerid from emp1 where name='赵敏');
表子查询:

子查询返回的结果是多行多列,这种查询称为表子查询

常用的操作符:IN

-- 表子查询
-- 1. 查询与 鹿杖客 ,赵敏 职位和薪资相同的员工
select salary ,dept_id from emp1 where name='鹿杖客' or name='赵敏';
select * from emp1 where (salary,dept_id)in (select salary ,dept_id from emp1 where name='鹿杖客' or name='赵敏');
-- 2.查询入职日期 2006-01-01 之后的员工信息 及其部门信息
select *from emp1 where emp1.entrydate>'2006-01-01';
select *from (select *from emp1 where emp1.entrydate>'2006-01-01') e left join dept on dept_id=dept.id;
多表小结:

 事务:

事务是一种操作集合,它是不可分割的工作单位,事务会把所有的操作作为一个整体一起向系统提出或撤销操作请求,即这些操作要么同时成功,要么同时失败

默认MySQL的事务是自动提交的,也就是说,当执行一条DML语句时,MySQL会立即隐式提交事务。

事务操作:  

查看/设置事务提交方式

select @@autocommit;
set @@autocommit=0;

提交事务

commit;

回滚事务

rollback;

开启事务

start transaction 或 begin;

 提交事务

commit;

 回滚事务

rollback;
事务四大特性 

并发事务问题
问题描述
脏读一个事务读到另一个事务还没有提交的数据
不可重复读一个事务先后读取同一条记录,但两次读取的数据不同,称之为不可重复读
幻读一个事务按照条件查询数据时,没有对应的数据行,但是在插入数据时,又发现这行数据已经存在,好像出现了”幻影“
 事务隔离级别
隔离级别脏读不可重复读幻读
Read uncommitted
Read committed×
Repeatable Read(默认)××
Serializable×××

--查看事务的隔离级别

select @@transaction_isolation;

--设置事务隔离级别

set[session | global] transaction isolation level{
        read uncommitted | read committed | repeatable read | serializable}

注意:事务隔离级别越高,数据越安全,但是性能越低。

事务小结:

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

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

相关文章

vim 安装与配置教程(详细教程)

vim就是一个功能非常强大的文本编辑器&#xff0c;可以自己DIY的那种 &#xff0c;不但可以写代码 &#xff0c;还可编译 &#xff0c;可以让你手不离键盘的完成鼠标的所有操作。 如果想要了解vim的的发展历史和详细解说&#xff0c;可以自行上网搜索&#xff0c;我主要是记录一…

第T10周:数据增强

>- **&#x1f368; 本文为[&#x1f517;365天深度学习训练营](https://mp.weixin.qq.com/s/0dvHCaOoFnW8SCp3JpzKxg) 中的学习记录博客** >- **&#x1f356; 原作者&#xff1a;[K同学啊](https://mtyjkh.blog.csdn.net/)** 在本教程中&#xff0c;你将学会如何进行数…

【NLP自然语言处理】文本处理的基本方法

目录 &#x1f354;什么是分词 &#x1f354;中文分词工具jieba 2.1 jieba的基本特点 2.2 jieba的功能 2.3 jieba的安装及使用 &#x1f354;什么是命名实体识别 &#x1f354;什么是词性标注 &#x1f354;小结 学习目标 &#x1f340; 了解什么是分词, 词性标注, 命名…

Java笔试面试题AI答之JDBC(3)

文章目录 13. 编写JDBC连Oracle的程序?14. 简述JDBC的主要组件有哪些 &#xff1f;15. JDBC中如何防止SQL注入攻击&#xff1f;1. 使用预处理语句&#xff08;PreparedStatement&#xff09;2. 避免在SQL查询中直接拼接用户输入的数据总结 16. JDBC的脏读是什么&#xff1f;哪…

Windows下Python和PyCharm的应用(一)__第一个测试程序

1、下载Python安装包 直接从官网下载&#xff0c;百度里搜出来的Python下载&#xff0c;很多是别的公司的商业广告&#xff0c;千万要注意&#xff0c;不要乱点进去&#xff0c;免得浪费时间。 从官网下载&#xff0c;链接&#xff1a;Download Python | Python.org 2、安装Pyt…

网络编程day03(网络体系结构、调试命令、TCP/IP对比)

目录 1》网络的体系结构 1> OSI模型 2> TCP/IP模型 3> 常见网络协议 4> DNS域名解析协议 2》 网络调试命令 1> ping&#xff1a;测试网络连通性&#xff08;ICMP&#xff09; 2> netstat 3》Dos &#xff08;拒绝式服务&#xff09;攻击&#xff1f;…

怎么在mathtype中打空格 MathType空格键不能用

MathType是一款数学公式编辑器&#xff0c;可以帮助用户创建复杂的数学公式和方程式。它提供了一个用户友好的界面&#xff0c;使得编辑和排版数学公式变得更加容易和高效。用户可以直接在其界面中输入公式&#xff0c;也可以将已有的公式从其他文档中复制粘贴过来进行编辑。在…

【2024数模国赛赛题思路公开】国赛B题第二套思路丨附可运行代码丨无偿自提

2024年数模国赛B题解题思路 B 题 生产过程中的决策问题 一、问题1解析 问题1的任务是为企业设计一个合理的抽样检测方案&#xff0c;基于少量样本推断整批零配件的次品率&#xff0c;帮助企业决定是否接收供应商提供的这批零配件。具体来说&#xff0c;企业需要依据两个不同…

秋燥拜拜,中秋润起来,酒茶香中秋有“礼”

话说这初秋啊&#xff0c;真是个让人又爱又恨的季节&#xff01; 爱它的秋高气爽&#xff0c;恨它的天干物燥。就像是我们刚刚结束了一个炎热的夏天&#xff0c;身体还没来得及适应&#xff0c;就被秋天的干燥给来了个“突然袭击”。鼻子干、嘴唇干、喉咙干&#xff0c;感觉整个…

hcip什么时候考试?一文带您了解hcip考试报名与预约流程

其他考试一般都会有固定的时间&#xff0c;但hcip不一样&#xff0c;它的考试时间并不固定&#xff0c;这就让考生很是疑惑&#xff1a;hcip什么时候考试呢?除了知道考试时间之外&#xff0c;还要了解hcip的报名条件、报名流程等相关内容。关于这些问题的答案&#xff0c;小编…

blender图像如何分层导出?blender动画云渲染

在blender渲染时产品会被其他物体影响&#xff0c;这时候就可以用到blender中的阻隔&#xff1b;分层导出图像到PS中进行校色等后期处理。 在分层前&#xff0c;我们需要先打开渲染属性-胶片-透明&#xff0c;这样导出的图像才是透明背景的&#xff0c;反之会变成黑色底。 第一…

使用GPU加速及配置

配置CUDA 英伟达 https://developer.nvidia.com/cuda-downloadsPython python要求3.8.x版本以上 python下载 https://www.python.org/getit/使用pytorch 查询地址&#xff1a; https://pytorch.org/index.html给出建议&#xff1a; 可以直接 pip3 install torch torchv…

如何实现思维导图简单漂亮?其实并不难

如何实现思维导图简单漂亮&#xff1f;思维导图是一种非常有效的思考和组织工具&#xff0c;它通过图形化的方式帮助我们梳理信息、激发创意。一个简单又漂亮的思维导图不仅能提高工作效率&#xff0c;还能让人赏心悦目。为了帮助你在学习和工作中更加得心应手&#xff0c;下面…

win10任务栏颜色怎么调?分享几个简单操作,附上详细图文教程

win10任务栏颜色怎么调&#xff1f;相信在大家的日常生活中&#xff0c;电脑是不可或缺的一部分。我们平时上班都需要使用到电脑&#xff0c;最近有个小伙伴问&#xff1a;Win10系统的任务栏颜色可以调整吗&#xff1f;答案当然是可以的。任务栏颜色调整可以帮助我们提高桌面美…

828华为云征文|部署电影收藏管理器 Radarr

828华为云征文&#xff5c;部署电影收藏管理器 Radarr 一、Flexus云服务器X实例介绍1.1 云服务器介绍1.2 应用场景1.3 性能模式 二、Flexus云服务器X实例配置2.1 重置密码2.2 服务器连接2.3 安全组配置 三、部署 Radarr3.1 Radarr 介绍3.2 Docker 环境搭建3.3 Radarr 部署3.4 R…

C++11: 智能指针(unique_ptr,shared_ptr和weak_ptr的使用及简单实现)

目录 1. 为何需要智能指针&#xff1f; 1.1 抛异常场景 1.2 什么是内存泄漏 2. 智能指针的原理 2.1 RAII技术 2.2 补充实现 3. auto_ptr 4. unique_ptr 4.1 使用及原理 4.2 定制删除器 5. shared_ptr 5.1 shared_ptr简介及使用 5.2 shared_ptr简单实现 5.2.1 基本…

CentOS7 部署 Zabbix 监控平台———监控网络设备,Linux 主机、Windows 主机

Node 有自己的配置文件和数据库&#xff0c;其要做的是将配置信息和监控数据向 Master 同步。 当 Master 发生故障或损坏&#xff0c; Node 可以保证架构的完整性。 3&#xff09;Server-Prxoy-Client 架构 Proxy 是 Server、Client 之间沟通的桥梁&#xff0c;Proxy 本身没…

Cortex-M3架构学习:存储器系统

存储系统功能 CM3 的存储器系统与从传统 ARM 架构的相比&#xff0c;进行如下改革&#xff1a; 它的存储器映射是预定义的&#xff0c;并且还规定好了哪个位置使用哪条总线。 CM3 的存储器系统支持所谓的“位带”&#xff08;bit-band&#xff09;操作。通过它&#xff0c;实…

超详细!!!electron-vite-vue开发桌面应用之创建新窗口以及主进程和子进程的通信监听(十二)

云风网 云风笔记 云风知识库 一、新建打开窗口 1、在electron/main.ts中加入主进程打开窗口逻辑代码 import { ipcMain } from "electron"; ipcMain.handle("open-win", (_, arg) > {const childWindow new BrowserWindow({webPreferences: {preloa…

代码执行漏洞-Log4j2漏洞

1.执行以下命令启动靶场环境并在浏览器访问 cd log4j/CVE-2021-44228docker-compose up -ddocker ps 2.先在自己搭建的DNSLOG平台上获取⼀个域名来监控我们注⼊的效果 3.可以发现 /solr/admin/cores?action 这⾥有个参数可以传&#xff0c;可以按照上⾯的原理 先构造⼀个请求…