当前位置: 首页 > news >正文

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

话不多说,直接上sql

用到的函数

SUBSTRING_INDEX:
用处:

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

语法:
SUBSTRING_INDEX(str,delim,count)
解释:

str是源字符串,delim是分隔符,count是指定需要分隔到什么位置。
count>0 表示从前往后第几个分隔符
count<0 表示从后往前(倒数)第几个分隔符
多个分隔符指定数字

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

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

语法:
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数据类型
-- DECIMAL(数值精度,小数点保留长度)
-- DECIMAL(10,1)可以存储最多具有8位整数和2位小数的数字
-- 精度与小数位数分别为10与1
-- 精度是总的数字位数,包括小数点左边和右边位数的总和
-- 小数位数是小数点右边的位数
-- 1.2
SELECT CAST('1.2' AS DECIMAL(10,1));
2.将值转换为DATETIME数据类型
-- 2025-04-01 00:00:00
SELECT CAST('2022-04-01' AS DATETIME); 

先查询下,SUBSTRING_INDEX

select SUBSTRING_INDEX(top_left_point,',',-1),SUBSTRING_INDEX(bottom_right_point,',',-1)  from map

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

-- 开启事务
START TRANSACTION; 
-- 在原有基础上 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';
-- -- 在原有基础上 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';
-- 两个同时操作 加和减

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';
-- 校验是否修改正确

SELECT 
    top_left_point, 
    bottom_right_point 
FROM map
WHERE tenant_id = '000031';
不管改的对不对,都别忘了释放事务哦
-- 提交事务(确定修改)
COMMIT
-- 回滚事务(取消修改)
ROLLBACK;

相关文章:

  • 43页可编辑PPT | 大数据管理中心设计规划方案大数据中心组织架构大数据组织管理
  • ⑧RBM(主备/主主)-二层部署案例
  • Web3.0隐私计算与云手机的结合
  • AI Agent 中的 MCP 模型上下文协议详解
  • 基于Matlab实现DCT数字水印添加提取和干扰测试
  • scGPT环境安装
  • 2025年企业级开源治理实践与思考
  • 边缘计算网关是什么?
  • JavaScript 深拷贝:手写一个简单可靠的 `deepClone` 函数
  • 2025华为软件精英挑战赛2600w思路分享
  • 互联网 Java 面试八股文汇总(2025 最新整理,持续更新)
  • 装饰器模式详解
  • 智能体项目实现AI对话流式返回效果
  • WebSocket原理详解(二)
  • 数据分析与应用3------数据清洗
  • 通过 Linux 网络命名空间实现路由器的方案与案例
  • PaddleX上线小目标检测模型产线,支持遥感分析、智能监控、智慧交通等领域高效应用
  • 今日八股——C++
  • 天气预报数据分析管理网站基于Spring Boot SSM原创
  • 青少年编程与数学 02-014 高中数学知识点 05课题、概率与统计
  • 新华时评:直播间里“家人”成“韭菜”,得好好管!
  • 上海楼市“银四”兑现:新房市场高端改善领跑,二手房量价企稳回升
  • 驱逐行动再加码?特朗普或向利比亚和卢旺达遣送非法移民
  • 金融监管总局:支持银行有序设立科技金融专门机构,推动研发机器人、低空飞行器等新兴领域的保险产品
  • 李云泽:支持小微企业、民企融资一揽子政策将从增供给、降成本、提效率、优环境4个方面发力
  • “穿越看洪武”,明太祖及其皇后像台北故宫博物院南院展出