【mysql】sql语句的更新和截取

2024-08-26 22:38

本文主要是介绍【mysql】sql语句的更新和截取,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

更新

update 表名 set 字段 = 要修改的内容 where 条件

- 字符串拼接

UPDATE t_vbquestion SET Answer1=CONCAT(‘A. ‘,Answer1),Answer2=CONCAT(‘B. ‘,Answer2) where QuestionTypeID=1

- 批量更新

case when

UPDATE t_vbquestion SET ChapterID = (CASE ChapterID WHEN ‘第一章’ THEN ‘1’ WHEN ‘第二章’ THEN ‘2’ WHEN ‘第三章’ THEN ‘3’ ELSE ‘9’ END)

插入

我们一般写好sql脚本,执行批量插入操作,在执行过程中会出现因为有原纪录而中断的失败过程。使用ignore、replace、ON DUPLICATE KEY UPDATE 关键字可以有效的避免,但是前提是用主键primary或者唯一索引对记录进行了唯一性确定。

INSERT IGNORE INTO t_student(id,name) values(‘119030303’,’小红’);
假如数据库中有重复记录,直接返回影响的行数为0,也即没有进行插入

REPLACE INTO t_student(id,name) values(‘119030303’,’小红’);
假如新的记录和旧的记录同时存在,则旧的删除,新的插入。


截取

left() right()
select left(QuestionContent,4) from t_vbquestion

SUBSTRING
UPDATE t_vbquestion SET Answer1=SUBSTRING(Answer1,2)
where QuestionTypeID=1

ltrim() rtrim()
截断空格,没有trim()。

SUBSTRING_INDEX
UPDATE t_vbquestion SET Answer1=SUBSTRING(Answer1,2) where QuestionTypeID=1

存储过程批量更新

BEGIN
DECLARE studentcode char(50) ;
DECLARE enYeartime char(50) ;
DECLARE update_cur CURSOR FOR SELECT code,left(code,2) FROM >tb_student;
declare exit handler for sqlexception rollback;
– 定义一个游标
start transaction;
– 开启游标
OPEN update_cur;
– 遍历所找到的结果集中的所有元素
cursor_loop:loop
FETCH update_cur INTO studentcode,enYeartime;
update tb_student set entranceDate=(select >concat(‘20’,enYeartime,’-09-01’)) where code=studentcode;
end loop cursor_loop;
– 关闭游标
CLOSE update_cur;
commit;
END

基础的东西,平时经常用,会记得好,平时不用,也是会忘记的。

这篇关于【mysql】sql语句的更新和截取的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1109887

相关文章

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

Redis缓存问题与缓存更新机制详解

《Redis缓存问题与缓存更新机制详解》本文主要介绍了缓存问题及其解决方案,包括缓存穿透、缓存击穿、缓存雪崩等问题的成因以及相应的预防和解决方法,同时,还详细探讨了缓存更新机制,包括不同情况下的缓存更... 目录一、缓存问题1.1 缓存穿透1.1.1 问题来源1.1.2 解决方案1.2 缓存击穿1.2.1

Mysql DATETIME 毫秒坑的解决

《MysqlDATETIME毫秒坑的解决》本文主要介绍了MysqlDATETIME毫秒坑的解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 今天写代码突发一个诡异的 bug,代码逻辑大概如下。1. 新增退款单记录boolean save = s

mysql-8.0.30压缩包版安装和配置MySQL环境过程

《mysql-8.0.30压缩包版安装和配置MySQL环境过程》该文章介绍了如何在Windows系统中下载、安装和配置MySQL数据库,包括下载地址、解压文件、创建和配置my.ini文件、设置环境变量... 目录压缩包安装配置下载配置环境变量下载和初始化总结压缩包安装配置下载下载地址:https://d

MySQL中的锁和MVCC机制解读

《MySQL中的锁和MVCC机制解读》MySQL事务、锁和MVCC机制是确保数据库操作原子性、一致性和隔离性的关键,事务必须遵循ACID原则,锁的类型包括表级锁、行级锁和意向锁,MVCC通过非锁定读和... 目录mysql的锁和MVCC机制事务的概念与ACID特性锁的类型及其工作机制锁的粒度与性能影响多版本

Linux Mint Xia 22.1重磅发布: 重要更新一览

《LinuxMintXia22.1重磅发布:重要更新一览》Beta版LinuxMint“Xia”22.1发布,新版本基于Ubuntu24.04,内核版本为Linux6.8,这... linux Mint 22.1「Xia」正式发布啦!这次更新带来了诸多优化和改进,进一步巩固了 Mint 在 Linux 桌面

MYSQL行列转置方式

《MYSQL行列转置方式》本文介绍了如何使用MySQL和Navicat进行列转行操作,首先,创建了一个名为`grade`的表,并插入多条数据,然后,通过修改查询SQL语句,使用`CASE`和`IF`函... 目录mysql行列转置开始列转行之前的准备下面开始步入正题总结MYSQL行列转置环境准备:mysq

MySQL不使用子查询的原因及优化案例

《MySQL不使用子查询的原因及优化案例》对于mysql,不推荐使用子查询,效率太差,执行子查询时,MYSQL需要创建临时表,查询完毕后再删除这些临时表,所以,子查询的速度会受到一定的影响,本文给大家... 目录不推荐使用子查询和JOIN的原因解决方案优化案例案例1:查询所有有库存的商品信息案例2:使用EX

Linux(Centos7)安装Mysql/Redis/MinIO方式

《Linux(Centos7)安装Mysql/Redis/MinIO方式》文章总结:介绍了如何安装MySQL和Redis,以及如何配置它们为开机自启,还详细讲解了如何安装MinIO,包括配置Syste... 目录安装mysql安装Redis安装MinIO总结安装Mysql安装Redis搜索Red

Mysql8.0修改配置文件my.ini的坑及解决

《Mysql8.0修改配置文件my.ini的坑及解决》使用记事本直接编辑my.ini文件保存后,可能会导致MySQL无法启动,因为MySQL会以ANSI编码读取该文件,解决方法是使用Notepad++... 目录Myhttp://www.chinasem.cnsql8.0修改配置文件my.ini的坑出现的问题