话不多说,直接上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;