Mysql 字段值批量自增或自减(坐标系数据,(x,y))

话不多说,直接上sql

用到的函数

SUBSTRING_INDEX:
用处:

到达分隔符之前从给定的字符串(str)返回一个子字符串

语法:
sql 复制代码
SUBSTRING_INDEX(str,delim,count)
解释:

str是源字符串,delim是分隔符,count是指定需要分隔到什么位置。

count>0 表示从前往后第几个分隔符

count<0 表示从后往前(倒数)第几个分隔符

多个分隔符指定数字

举例:
1.以,为分隔符,到第一个,结束,输出结果就是112.000,
sql 复制代码
SELECT SUBSTRING_INDEX('112.000,113.000', ',', 1);
2.以,为分隔符,到最后1个,结束,输出结果就是113.000,
sql 复制代码
SELECT SUBSTRING_INDEX('112.000,113.000', ',', -1);
3.多个,分隔符 取中间,多个函数拼接即可,先截取正数第二个分隔符之前的,然后再截取倒数第一个分隔符之前的
sql 复制代码
SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('112.000,114.000,113.000','.', 2),'.',-1);
CAST:
用处:

将任何类型的值转换为具有指定类型的值

语法:
sql 复制代码
CAST(**value** AS **datatype**)
解释:

value是字段值(要转换的),datatype是转换类型,AS关键字用于分隔两个参数。

datatype参数取值

值类型 说明
DATE 将value转换成'YYYY-MM-DD'格式
DATETIME 将value转换成'YYYY-MM-DD HH:MM:SS'格式
TIME 将value转换成'HH:MM:SS'格式
CHAR 将value转换成CHAR(固定长度的字符串)格式
SIGNED 将value转换成INT(有符号的整数)格式
UNSIGNED 将value转换成INT(无符号的整数)格式
DECIMAL 将value转换成FLOAT(浮点数)格式
BINARY 将value转换成二进制格式
举例:
1. 将值转换为DECIMAL数据类型
sql 复制代码
-- DECIMAL(数值精度,小数点保留长度)
-- DECIMAL(10,1)可以存储最多具有8位整数和2位小数的数字
-- 精度与小数位数分别为10与1
-- 精度是总的数字位数,包括小数点左边和右边位数的总和
-- 小数位数是小数点右边的位数
-- 1.2
SELECT CAST('1.2' AS DECIMAL(10,1));
2.将值转换为DATETIME数据类型
sql 复制代码
-- 2025-04-01 00:00:00
SELECT CAST('2022-04-01' AS DATETIME); 

先查询下,SUBSTRING_INDEX

sql 复制代码
select SUBSTRING_INDEX(top_left_point,',',-1),SUBSTRING_INDEX(bottom_right_point,',',-1)  from map

建议先开启事务,以防万一

sql 复制代码
-- 开启事务
START TRANSACTION; 
sql 复制代码
-- 在原有基础上 Y轴减去183
UPDATE map
SET
    top_left_point = CONCAT(
        SUBSTRING_INDEX(top_left_point, ',', 1), 
        ',', 
        CAST(SUBSTRING_INDEX(top_left_point, ',', -1) AS DECIMAL(10,1)) - 183
    ),
    bottom_right_point = CONCAT(
        SUBSTRING_INDEX(bottom_right_point, ',', 1), 
        ',', 
        CAST(SUBSTRING_INDEX(bottom_right_point, ',', -1) AS DECIMAL(10,1)) - 183
    )
WHERE tenant_id = '000031';
sql 复制代码
-- -- 在原有基础上 X轴加上 101
UPDATE map
SET
    top_left_point = CONCAT(
        CAST(SUBSTRING_INDEX(top_left_point, ',', 1) AS DECIMAL(10,1)) + 101,  
        ',',
        SUBSTRING_INDEX(top_left_point, ',', -1)
    ),
    bottom_right_point = CONCAT(
        CAST(SUBSTRING_INDEX(bottom_right_point, ',', 1) AS DECIMAL(10,1)) + 101,
        ',',
        SUBSTRING_INDEX(bottom_right_point, ',', -1) 
    )
WHERE tenant_id = '000031';
sql 复制代码
-- 两个同时操作 加和减

UPDATE map
SET
    top_left_point = CONCAT(
        CAST(SUBSTRING_INDEX(top_left_point, ',', 1) AS DECIMAL(10,1)) + 101,  
        ',',
        CAST(SUBSTRING_INDEX(top_left_point, ',', -1) AS DECIMAL(10,1)) - 183  
    ),
    bottom_right_point = CONCAT(
        CAST(SUBSTRING_INDEX(bottom_right_point, ',', 1) AS DECIMAL(10,1)) + 101, 
        ',',
        CAST(SUBSTRING_INDEX(bottom_right_point, ',', -1) AS DECIMAL(10,1)) - 183 
    )
WHERE tenant_id = '000031';
sql 复制代码
-- 校验是否修改正确

SELECT 
    top_left_point, 
    bottom_right_point 
FROM map
WHERE tenant_id = '000031';
不管改的对不对,都别忘了释放事务哦
sql 复制代码
-- 提交事务(确定修改)
COMMIT
-- 回滚事务(取消修改)
ROLLBACK;
相关推荐
程序无bug1 分钟前
手写Spring框架
java·后端
程序无bug3 分钟前
Spring 面向切面编程AOP 详细讲解
java·前端
zhanshuo3 分钟前
鸿蒙UI开发全解:JS与Java双引擎实战指南
前端·javascript·harmonyos
JohnYan3 分钟前
模板+数据的文档生成技术方案设计和实现
javascript·后端·架构
全干engineer14 分钟前
Spring Boot 实现主表+明细表 Excel 导出(EasyPOI 实战)
java·spring boot·后端·excel·easypoi·excel导出
Fireworkitte24 分钟前
Java 中导出包含多个 Sheet 的 Excel 文件
java·开发语言·excel
撰卢27 分钟前
如何提高网站加载速度速度
前端·javascript·css·html
10年前端老司机32 分钟前
在React项目中如何封装一个可扩展,复用性强的组件
前端·javascript·react.js
GodKeyNet42 分钟前
设计模式-责任链模式
java·设计模式·责任链模式
a_Dragon11 小时前
Spring Boot多环境开发-Profiles
java·spring boot·后端·intellij-idea