MySQL 某一列的值加入到另一列
0.背景
| 文件url | 文件名 |
|---|---|
| /usr/local/img/goods/1/2021-12-22-e05bb433bc7a451ca5d7cc9d505d8ed8.jpg | 酸枣糕.jpg |
| /usr/local/img/goods/2/2021-12-21-e05bb433bc7a451ca5d7cc9d505ffffffff.jpeg | x熊猫.可爱.jpeg |
最初的设计是文件名(中文)和文件路径分开,文件路径的文件名是日期+UUID,同时防止上传的文件重复(如果重复上传不会删除之前的,可能是文件名重复或者文件名和内容都重复了)。但下载的时候日期+UUID的文件名不利于阅读,所以做一个缝合怪。
文件url命名为:日期+UUID+文件名+后缀
2021-12-22-e05bb433bc7a451ca5d7cc9d505d8ed8-酸枣糕.jpg
1.分析
- 文件后缀有多重形式,doc、xls、xlsx、jpg、jpeg、pdf等。
- 文件名里面可能有多个
.,要找到最后一个
2.解决方法
sql批量处理,先去除多余空格;然后反转文件url的值,这样即使有多个.,但文件名后缀的.肯定是反转后遍历到的第一个;然后就定位到了位置;使用replace方法把后缀都去除;最后用concat将文件url和文件名进行拼接。
参考:https://blog.csdn.net/hr541659660/article/details/76619363
-- 移除多余空格
SELECT old_name,location,RIGHT(RTRIM(文件URL), LOCATE('.',REVERSE(RTRIM(文件URL)))) AS 文件名后缀,LOCATE('.',REVERSE(RTRIM(文件URL))) 句号的位置 FROM table_name
-- 移除右边多余空格
SELECT RTRIM(' barbar ') AS 移除右边多余空格;
-- 反转
SELECT REVERSE(RTRIM('abcde')) AS 反转;
-- locate(str1,str2) 定位str1出现的位置
SELECT LOCATE('d','abcde');
-- RIGHT(s,n) 函数返回字符串 s 最右边的 n 个字符
SELECT RIGHT('MySQL',3);
MySQL 某一列的值加入到另一列的更多相关文章
- 页面载入时通过获取GridView某行某列的值来控制某一列的控件属性
通过获取状态来控制"查看"button的Visible属性值. 在前台GridView中加入 OnRowDataBound="GridView1_RowDataBound ...
- 【ExtJs】在Ext.grid.Panel中,两列的值相乘作为第三列的值的实现
如: 商品总价=商品单价*商品数量 方法: 商品总价列,使用其renderer属性,为期定义一个方法,该方法将当前record中的另外两列中2个数据相乘后渲染到该商品总价列.
- sql server 将两列的值合并到另一列
select top 100 t2.FullName, * from Subject,(select id, isnull(first_name,'') +isnull(middle_name,'') ...
- innodb 自增列重复值问题
1 innodb 自增列出现重复值的问题 先从问题入手,重现下这个bug use test; drop table t1; create table t1(id int auto_increment, ...
- 学习笔记13—python DataFrame获取行数、列数、索引及第几行第几列的值
1. df=DataFrame([{‘A’:’11’,’B’:’12’},{‘A’:’111’,’B’:’121’},{‘A’:’1111’,’B’:’1211’}]) print df.column ...
- excel查找某一列的值在、不在另一列中
统计中遇到找出一列的值不在另一列的需求: 找出A列中不在B列的值 方法如下: 使用countif函数 比如找出A列中不在B列的值: 在C1中输入 COUNTIF(B:B,A1) 下拉单元格,在首行添加 ...
- 如何取得GridView被隐藏列的值
如何取得GridView被隐藏列的值 分类: ASP.net 2009-06-25 12:47 943人阅读 评论(1 ...
- MySQL 批量修改某一列的值为另外一个字段的值
mysql> select * from fruit; +----+--------+-------+ | id | name | price | +----+--------+-------+ ...
- mysql合并同一列的值
我有例如以下的查询条件显示: 我希望终于显示的效果如图: 将id同样的group_name合并到一行.实现方法:在group_name前面加keywordgroup_concat.然后在sql语句 ...
- 【拼接属性查询方式】MySql某一列属性值为拼接时的查询方式
数据库中某一列的值为 使用IN查询是无法查询到数据的,只能查询到IN(2)或者IN(2,3) 查询结果: , style_id) 正确方式:使用FIND_IN_SET函数 , style_id) , ...
随机推荐
- 053_Salesforce Lightning与Classic对比
Classic页面 Lightning页面 特点: 应用程序的切换更加方便 可以快速访问最近项目和备注等 新的记录页面布局 涡轮增压列表视图 仪表板有所变化 圆滑的报告视图 其中最重要的变化也当属 ...
- 安装robotframwork 报错Requirement already satisfied
pip install 的时候报错信息为,在这里插入图片描述对于这样的问题需要指定安装路径pip install --target=d:\python\python37\lib\site-packag ...
- docker-io安装报错
一般修改两个文件即可 1.文件 :/etc/docker/daemon.json { "storage-driver": "devicemapper" } 2. ...
- 标准c++中string类函数介绍
之所以抛弃char*的字符串而选用C++标准程序库中的string类,是因为他和前者比较起来,不必担心内存是否足够.字符串长度等等,而且作为一个类出现,他集成的操作函数足以完成我们大多数情况下(甚至是 ...
- kubectl使用方法及常用命令小结
Kubectl 是一个命令行接口,用于对 Kubernetes 集群运行命令.kubectl 在 $HOME/.kube 目录中寻找一个名为 config 的文件. kubectl安装方法详见:htt ...
- c++学习 4 运算符及其应用技巧
一 按位与运算符 "&"按位与运算符,全1为1,有0则0. 特点:和1相与保持不变,和0相与都变为0. 功能:将指定位置清0. example: 1000 1100 &am ...
- 智利SUBTEL更新WiFi 6技术法规!
2022年9月6日,智利电信监管机构(SUBTEL) 发布了第2844号豁免决议,更新了1985号豁免决议,即短程设备的固定技术标准. 主要更新如下: • 2.4 GHz频段已在医疗设备目录中删除,现 ...
- 关于在Eclipse中使用EclEmma
在LAB2中,要求使用EclEmma来统计JUnit测试用例的代码覆盖度.下面就来说说如何进行基本的使用来应付实验(bushi). 在这给出完全体,可以访问下面的网址进行学习. http://www. ...
- RocketMQ4.x本地源码部署教程
安装前提条件(推荐) 64bit OS, Linux/Unix/Mac (Windows不兼容)64bit JDK 1.8+; 快速开始 http://rocketmq.apache.org/docs ...
- Spring Boot中使用过滤器和拦截器
过滤器(Filter)和拦截器(Interceptor)是Web项目中常用的两个功能,本文将简单介绍在Spring Boot中使用过滤器和拦截器来计算Controller中方法的执行时长,并且简单对比 ...