MySQL的事务,函数和索引

事务

数据库的事务是一种机制,一种操作序列,包含了一组数据库的操作命令

简单了解:如果一个包含多个步骤的业务操作,被业务管理,要么这些操作同时操作成功,要么同时操作失败

事务是一个不可分割的工作逻辑单元,可以在事务中写多种sql语句

MYSQL的事务机制

1.自动提交(默认)

        每执行一行SQL语句,就开启一个事务,SQL提交完成,事务提交(一行SQL一个事务)

2.手动提交(自己写代码)

        先开启事务,在执行多条SQL语句,提交事务(回滚)

事务的使用操作机制

1.开启事务

START TRANSACTION

2.执行多行sql语句

COMMIT

3.提交事务(成功) | 回滚事务(失败)

ROLLBACK

create table people
(
    id int primary key auto_increment,
    name varchar(10),
    money int
);
insert into mysql_day2.people (id, name,money) VALUE (null,'小何',1000),(null,'小美',500);

-- 1.开启事务
start transaction;

-- 2.转账
update people set money=money-500 where name ='小何';
update people set money=money+500 where name ='小美';


-- 3.提交事务,不提交不改变
commit ;

-- 3.回滚事务(回到原来的情况)
rollback;

 事务的四大特性(ACID)

1.持久性(Durability)

当事务提交或回滚后,数据库会持久化的保存数据

2.隔离性(Isolation)

多个用户并发的访问数据库时,一个用户的事务不能被其他用户的事务干扰,多个并发的事务之间相互隔离

3.原子性(Atomicity)

原子是不可分割的最小操作单位,事务要么同时成功,要么同时失败

4.一致性(Consistency)

事务操作前后,数据总量不变

事务的隔离级别

事务在操作时的理想状态,多个事务之间相互不影响,如果隔离级别设置不当就可能引发1并发访问问题,一个事务就相当与一个线程

并发访问的问题含义
脏读一个事务读取到了另一个事务尚未提交的数据
不可重复读一个事务多次读取时数据是不一致的,这是其他事务update时引发的问题(已经commit)
幻读(虚读)一个事务内读取到别的事务插入或删除的数据(别的事务commit后),导致前后读取记录行数不同,这是insert和delete时引发的问题

因此MYSQL数据库规范规定了4种隔离级别,用于解决上述出现的事务并发问题

级别名字隔离级别脏读不可重复读幻读数据库默认隔离级别
1读未提交read uncommited
2读已提交read commitedOracle,SQL server
3可重复读repeatable readMySQL
串行化(相当与单线程)serializable

函数

日期函数

 

 

-- 获得系统当前的日期和时间
select now();
-- 获取系统当前的日期
select curdate();
-- 获取系统当前的时间
select curtime();
create table people
(
    id int primary key auto_increment,
    name varchar(10),
    birthday date
);
insert into people (id, name, birthday) VALUE (null,'aaa',curdate());

-- 获取年月日
select year(curdate());
select month(curdate());
select day(curdate());

-- 获取一年的第几周
select week(curdate());

-- 获取学生的生日日期(不包括年)
select name,month(birthday),day(birthday) from people;

-- 把月日连在一起,使用函数concat()
select name,concat(month(birthday),'月',day(birthday),'日') from people;

select name,month(birthday),day(birthday) from people;的结果

 select name,concat(month(birthday),'月',day(birthday),'日') from people;的结果

 判断函数:casewhen

语法

case 列 

        when 条件一 then 结果一

        when 条件二 then 结果二

        ....

        else

                结果N

end;

如果没有写else且不满足上述条件返回null

create table people2
(
    id int primary key auto_increment,
    name varchar(10) not null unique,
    sex int default 0
);
insert into people2 values(null,'aaa',1),(null,'bbb',1),(null,'ccc',2),(null,'ddd',1);

select id, name,
    case sex
        when 1 then '男'
        when 2 then '女'
        else '保密'
    end AS gender
from people2;

 

字符函数

-- 获取字符串长度
select char_length('iamyou');
select char_length(name) from people2;

 

-- 拼接字符串
select concat('i','love','you');
select concat(id,'号',name) from people2;

 


-- 转大小写
select lower('IAM');
select upper('yyy');
select concat(id,'号',upper(name)) from people2;

-- 截取字符串
select substr('iamhhhh',4,4);-- 索引从1开始,从四位置开始截取长度为4的字符串,结果是hhhh

-- 去除字符串的前后空格,中间空格不会去除
select trim('    iam  y   ');-- iam  y

 数学函数

-- 从0到1取一个随机数
select rand();

-- 四舍五入保留几位小数
select round(3.123445,3);

-- 不四舍五入保留几位小数
select truncate(3.12342,2);

-- 获取最小值
select least(1,2,3);-- 1
-- 获取最大值
select greatest(1,2,3);-- 3

索引

索引是帮助MySQL高效获取数据的数据结构(B+树)

 索引是创建在表中的某些列种

创建索引语法

1)创建索引

1.创建普通索引

create index 索引名 on 表名(字段);

2.创建唯一索引

create unique index 索引名 on 表名(字段);

3.创建普通组合索引

create index 索引名 on 表名(字段1,字段名2...);

4.创建唯一组合索引

create unique index 索引吗 on 表名(字段名1,字段名2...); 

注意:

1.如果在一张表中创建多个索引,要保证索引名是不能重复的

2.主键索引 primary key 无法通过此方式创建

主键索引,默认在创建表时指定主键列(primary key),就自动添加了

2)在已有表的字段上修改表时指定

1.添加一个主键,这意味着索引值必须是唯一的,且不为null

alter table 表名 primary key(字段)--默认索引名:primary

2.添加唯一索引(除了null可以出现多次)

alter table add unique (字段);--默认索引名:字段名

3.添加普通索引,索引值可以出现多次

alter table 表名 add index(字段);-- 默认索引吗:字段名

create table people3
(
    id int primary key auto_increment,-- 主键索引
    tel varchar(20) unique,-- 唯一索引
    name varchar(10)
);
-- 给名字字段添加普通索引
create index idx_people3_name on people3(name);

索引的数据结构

B+Tree:

B+Tree将树分为叶子节点和非叶子节点,其中非叶子节点只存储索引+指针,而叶子节点存储索引+数据。

创建索引的原则

1.字段内容的可识别度不能低于70%,字段内数据唯一值的个数不能低于70%,如age字段,不同的内容就有很多,而sex(性别)的内容就只有两种,不适合创建索引

2.经常使用where条件搜索的字段,例如id,name字段

3.经常使用表连接的字段(内连接,外连接),可以加快连接的速度

4.经常排序的字段 order by ,因为索引已经排序过。

索引失效

  1. 模糊查询(like)走的是表查询(一个一个查),索引失效
  2. 在索引列上进行运算操作(函数),索引失效
  3. 范围查询右边的列,不能使用索引
  4. 字符串不加单引号,索引失效
  5. 用or分割开的条件,如果or前的条件的列有索引,or后面的列没有索引,那么涉及的索引都不会用到
  6. is null,is not null有时索引失效
  7. in走索引,not in 索引失效

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

HTTP网络协议,接口请求的内容类型 content-type(2024-04-27)

1、简介 Content-Type(内容类型),一般是指网页中存在的 Content-Type,用于定义网络文件的类型和网页的编码,决定浏览器将以什么形式、什么编码读取这个文件,这就是经常看到一些 PHP 网页点击的结果却是下载…

【Kylin】V10系统在VMware中分辨率太小,无法通过GUI修改分辨率的解决方法

【Kylin】V10系统在VMware中分辨率太小,无法通过GUI修改分辨率的解决方法 解决办法1.打开终端方法1:方法2 2.输入 xrandr 命令,查询分辨率支持的列表3.选择适合的分辨率 。 例如:xrandr -s 1440x900_60 问题如下图: 保…

C++感受10-Hello Object 生死版•下

搞懂以下三个重要知识点: 对象生命周期对象内存模型对象的可见性 ff12-HelloObject-生死版-下 1. 生命周期 只要是数据,就需要占用内存空间。程序将内存分成多个区,其中最重要的是栈区和堆区。放在栈区的数据,称为栈数据或栈对象&…

uniapp分包,以及通过uni-simple-router进行分包

先说一下uniapp的直接分包方式,很简单: 配置分包信息 打开manifest.json源码视图,添加 “optimization”:{“subPackages”:true} 开启分包优化 我们在根目录下创建一个pagesA文件夹,用来放置需要分包的页面 然后配置路由 运行到…

开源啦!一键部署免费使用!Kubernetes上直接运行大数据平台!

市场上首个K8s上的大数据平台,开源啦! 智领云自主研发的首个 完全基于Kubernetes的容器化大数据平台 Kubernetes Data Platform (简称KDP) 开源啦🚀🚀 开发者只要准备好命令行工具,一键部署 Hadoop,Hi…

【论文笔记】Language Models are Few-Shot Learners B部分

Language Models are Few-Shot Learners B 部分 回顾一下第一代 GPT-1 : 设计思路是 “海量无标记文本进行无监督预训练少量有标签文本有监督微调” 范式;模型架构是基于 Transformer 的叠加解码器(掩码自注意力机制、残差、Layernorm&#…

【win10相关】更新后出现未连接到互联网的问题及解决

问题背景 在win10更新完系统之后,第二天电脑开机后,发现无法上网,尝试打开百度,但是出现以下图片: 经过检查,发现手机是可以上网的,说明网络本身并没有问题,对防火墙进行了一些设置…

采用前后端分离Vue,Ant-Design技术开发的(手麻系统成品源码)适用于三甲医院

开发环境 技术架构:前后端分离 开发语言:C#.net6.0 开发工具:vs2022,vscode 前端框架:Vue,Ant-Design 后端框架:百小僧开源框架 数 据 库:sqlserver2019 系统特性 麻zui、护理、PACU等围术期业务全覆…

【机器学习】集成学习---Bagging之随机森林(RF)

【机器学习】集成学习---Bagging之随机森林(RF) 一、引言1. 简要介绍集成学习的概念及其在机器学习领域的重要性。2. 引出随机森林作为Bagging算法的一个典型应用。 二、随机森林原理1. Bagging算法的基本思想2. 随机森林的构造3. 随机森林的工作机制 三…

3. uniapp开发工具的一些事

前言 新的一天,又要开始卷起来了,开发程序开发当前离不开开发工具,一个好的开发工具办事起来那必然是事倍功半的...本文主要分享了关于uniapp里开发工具的一些事~ 概述 阅读时间:约5~7分钟; 本文重点&am…

Web程序设计-实验04 JavaScript对象

题目 【实验主题】 个人所得税计算 【实验任务】 1、根据【任务提示】和【参考资源】材料,自学2012版月工资、年终奖个人所得税计算规则。 2、新建 .js文件,以JSON格式定义个人所得税对象。 其中属性涉及三个层次: 1)第一层…

03-MVC执行流程-参数解析与Model

重要组件 准备Model,Controller Configuration public class WebConfig {ControllerAdvicestatic class MyControllerAdvice {ModelAttribute("b")public String bar() {return "bar";}}Controllerstatic class Controller1 {ResponseStatus(H…

CUDA的基础知识

文章目录 数据精度CUDA概念线程&线程块&线程网络&计算核心GPU规格参数内存 GPU并行方式数据并行流水并行张量并行混合专家系统 数据精度 FP32 是单精度浮点数,用8bit 表示指数,23bit 表示小数;FP16 是半精度浮点数,用…

SpringBoot常用注解与注意事项

Spring Boot 是一个用于快速开发、运行和管理 Spring 应用程序的框架。它大量使用了注解(Annotations)来简化配置和开发流程。 以下是一些 Spring Boot 中常用的注解及其注意事项: 1.常用注解 SpringBootApplication 这是一个组合注解&#…

OpenHarmony 项目实战:智能体重秤

一、简介 本 demo 基于 OpenHarmony3.1Beta 版本开发,该样例能够接入数字管家应用,通过数字管家应用监测体重秤上报数据,获得当前测量到的体重,身高,并在应用端形成一段时间内记录的体重值,以折线图的形式…

vivado Aurora 8B/10B IP核(4)-数据流接口(Streaming Interface)

Streaming 接口 Transmitting and Receiving Data(发送和接收数据) 流式接口允许将Aurora 8B/10B通道用作管道。 初始化后,通道始终可用于写入,除非发送时 钟补偿序列。 核心数据传输符合AXI4-Stream协议。当s_axi_tx_tvalid被取…

OpenHarmony 实战开发——分布式购物车案例展示~

简介 分布式购物车demo 模拟的是我们购物时参加满减活动,进行拼单的场景;实现两人拼单时,其他一人添加商品到购物车,另外一人购物车列表能同步更新,且在购物车列表页面结算时,某一人结算对方也能实时知道结…

基于单片机的多功能电子万年历系统

摘要:该题目要求学生综合运用单片机原理、低频电子线路、数字电路与逻辑设计等相关知识,设计完成多功能电子万年历系统。通过完成设计任务,使学生掌握单片机设计开发的基本流程,增强学生动手实践能力,培养学生分析和解决实际问题的能力,为后续课程的学习和工作打下良好基础。 关…

特征的前期融合与后期融合在召回、粗排、精排应用

前期融合:先对所有特征做concat,再输入DNN,一般常见于精排模型 特点:线上推理代价大,若有n个候选item需要做n次模型计算 后期融合:把用户和物品特征分别输入不同的神经网络,不对用户和物品做融…

基于Springboot的玩具租赁系统(有报告)。Javaee项目,springboot项目。

演示视频: 基于Springboot的玩具租赁系统(有报告)。Javaee项目,springboot项目。 项目介绍: 采用M(model)V(view)C(controller)三层体系结构&…