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;
相关推荐
UIUV38 分钟前
RAG技术学习笔记(含实操解析)
javascript·langchain·llm
华仔啊1 小时前
Stream 代码越写越难看?JDFrame 让 Java 逻辑回归优雅
java·后端
ray_liang1 小时前
用六边形架构与整洁架构对比是伪命题?
java·架构
Ray Liang2 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
颜酱2 小时前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法
Java水解3 小时前
Java 中间件:Dubbo 服务降级(Mock 机制)
java·后端
FansUnion3 小时前
我如何用 Next.js + Supabase + Cloudflare R2 搭建壁纸销售平台——月成本接近 $0
javascript
左夕4 小时前
分不清apply,bind,call?看这篇文章就够了
前端·javascript
滕青山5 小时前
文本行过滤/筛选 在线工具核心JS实现
前端·javascript·vue.js
时光不负努力5 小时前
编程常用模式集合
前端·javascript·typescript