首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

修改MySQL varchar类型字段排序规则

记录一个在工作中遇到的问题,也不算是问题,为的是找一种简便的方法批量修改数据表字段排序规则,在MySQL中叫collation,常常和编码CHARACTER一起出现的。...collation有三种级别,分辨是数据库级别,数据表级别和字段级别。...网上搜到的解决办法,都提到了修改数据表级别collation排序规则。...但是我遇到的场景是数据表级别已经是utf8_unicode_ci,而字段级别是utf8_general_ci,(这里我们关心的字段类型是varchar)。...由于需要修改的字段太多了,手工修改肯定是费时费力的。自然也想到了用脚本的方式批量修改,但是发现这种通过查找MySQL信息表、过滤、拼接生成批量修改的语句太好用了,而且还能做到针对varchar类型。

4.6K30

特定场景下才能复现的bug案例分享之--前端排序字段的锅

果不其然,在服务器上找到了报错的日志,日志的大概内容是打印出了一大段查询sql,其中可以看到有个很明显的sql报错是找不到某个排序字段xxx 3、通过日志查看,基本已确认,报错跟排序字段有关 ,我本地又没有复现...,那就应该是前端传参的问题了,通过报错日志,对比报错页面,发现页面本来就没有字段xxx,这个时候,我猜测应该是前端页面交互太复杂,然后把上一个访问页面的排序字段给带到当前访问的这个页面来了 4、找一下该模块下哪个明细页面有显示字段...xxx,并且可以排序的 ,然后依次进入某个明细页面按照字段xxx排序后,再返回访问报错的页面,查看是否可以复现问题。...最终,经过以上步骤的尝试,发现确实是前端的bug,前端在访问同一模块的不同指标的明细页面,点击过页面的排序字段后,有的页面一进去的时候没有清空之前上一页页面的排序字段 ,导致后端查询sql报错。

59820

Mysql8之获取JSON字段

问题是这样的,接到一个需求:         要从其它系统数据库中导出一些数据,发现其中有个字段是json字符串,而需求要的是该JSON字符串中某个key对应的value。    ...需求有了,这个如果只用SQL来处理,能否实现呢,SQL能否处理JSON数据呢,这个数据库是Mysql,看了下版本,发现是8.x,Mysql8中有json函数支持json的处理,so开工探索。..."key": { "innerKey": "This is test" ... }, ... } ]     字段的json如List-1所示,对应的用json_extract...要注意的是该字段中不能含有非json字符串的,不然json_extract会报错。如下List-2是SQL例子。...select column1,column2,json_extract(,'$[0].key.innerKey') as column3 from table Reference https://dev.mysql.com

6.6K10

MySQL排序字段数据相同不能分页问题

MySQL排序字段数据相同不能分页问题,最近同事遇到一个列表的分页有bug,点击第1行,第2行数据会出现重复的,初步怀疑是数据重复了,通过SQL查询,确认数据都没重复。...不过分页时候会出现重复,所以怀疑是分页问题,因为我之前遇到过order by的字段有null的情况,排序也会有问题,所以通过经验去排查排序字段数据,发现并没有null的数据。...只是数据很多都是一样的,因为是通过批量导入的,新增时间都保存为一样的,然后分页再根据这个新增时间去排序,就会出现好像“数据重复”的现象 通过查询MySQL官方的资料,https://dev.mysql.com...大致意思是,如果order by排序字段有相同的数据,则服务器可以自由地以任何顺序返回这些行,并且可能会根据整体执行计划以不同的方式返回。...所以,问题就知道了,通过官网资料,可以知道可以在order by后面加上一个唯一的id mysql> SELECT * FROM ratings ORDER BY category, id; +---

2.3K40

MYSQL用法(十六) MySQL按指定字段自定义列表排序

一、 ORDER BY 排序 要求:按照字段IS_NEW_PROJ的降序、字段LOAN_APR的降序、字段GMT_BUY_START的升序排序 sql语句如下: SELECT b.PROJECT_ID...二、 ORDER BY FIELD排序(自定义排序规则) 要求:按照字段PROJECT_STATUS指定的顺序排序 sql语句如下: SELECT b.PROJECT_ID AS project_id...三、 ORDER BY FIELD排序升级(多条件组合排序) 要求:按照字段IS_NEW_PROJ降序、字段PROJECT_STATUS指定的顺序排、字段LOAN_APR降序、字段GMT_BUY_START...四、 ORDER BY 排序终极版(多条件组合排序+自定义排序) 要求:按照字段IS_NEW_PROJ降序、字段PROJECT_STATUS指定的顺序排序字段GMT_BUY_START降序、字段PROJECT_STATUS...指定的顺序排序 sql语句如下: SELECT b.PROJECT_ID AS project_id, b.PROJECT_TITLE AS project_title, b.PROJECT_STATUS

2.5K30

mysql学习—查询数据库中特定对应的表

遇到一个问题,我将问题抽象简单描述如下: 循环查询数据库所有表,查出字段中包含tes的表,并且将test修改为hello?...因为自己不才找了很久也没有找到很好的方法,又对mysql的游标等用法不是很了解,在时间有限的情况下,发现了下面的方法,分享给大家: 1:查找 (1)使用工具 我使用的mysql的Navicat...for MySQL的工具 (2)使用sql的语法 这个方式暂时我还是不会,等我熟悉语法之后在补充。...2:替换 替换也有很多方法,这里我介绍我使用的方式: UPDATE 表名 SET 字段名=REPLACE(字段名, '原内容', '替换的内容'); UPDATE t_about SET pic=REPLACE...toProduct', '/product') WHERE generateHtml REGEXP ('\/front\/product\/toProduct[Kyu]{0,4}\/'); 3.单表的全字段查询某个

7.5K10
领券