MySQL在文本列中更改文件扩展名

MySQL-pro的一个简单问题.我有一个表中包含文件名的字段(只是文件名,没有额外的文本).我需要将所有文件扩展名从“.png”更改为“.jpg”,我知道有一种方法可以使用PHP或Java等编程语言进行查询和编写脚本.

为了以防万一,删除“show create table”输出

CREATE TABLE `photos` (
  `id` bigint(20) NOT NULL,`owner_id` int(11) DEFAULT NULL,`photo_name` varchar(255) DEFAULT NULL,`comment` text,`normal_file_name` varchar(255) DEFAULT NULL,`thumb_file_name` varchar(255) DEFAULT NULL,`full_file_name` varchar(255) DEFAULT NULL,`photo_order` int(11) DEFAULT NULL,`gallery_file_name` varchar(255) DEFAULT NULL,`photo_type` varchar(255) DEFAULT NULL,PRIMARY KEY (`id`),KEY `FK_photos_OWNER_ID` (`owner_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 |

normal_file_name,thumb_file_name,gallery_file_name和full_file_name是包含文件路径的字段.

提前感谢您的帮助!

// Juriy

最佳答案
在UPDATE语句中使用REPLACE function

UPDATE PHOTOS
   SET normal_file_name = REPLACE(normal_file_name,'.png','.jpg'),thumb_file_name = REPLACE(thumb_file_name,gallery_file_name = REPLACE(gallery_file_name,full_file_name = REPLACE(full_file_name,'.jpg')

如果没有匹配,则不会进行替换.

相关文章

目录MySQL卸载环境查看是否已安装MySQL卸载mysql服务查看是否...
目录数据类型数据类型分类数值类型以TINYINT认识整型族有符号...
目录表的约束空属性非空约束(NOT NULL Constraint)默认值定...
目录函数时间日期函数:字符串函数数学函数其他函数 函数 时间...
目录使用C语言连接库的安装C APImysql_initmysql_real_conne...
目录用户用户管理查询所有用户查看当前用户查看当前连接数创...