首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

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 varchar类型字段排序规则

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

4.6K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL 排序规则

    排序规则是一组用于比较字符集中的字符的规则。 每个 MySQL 字符集可以支持一个或者多个排序规则,用于定义每个字符的比较规则,包括是否区分大小写,是否区分重音等。...这是排序规则的唯一标识符,您可以在创建或更改表时使用它来指定表的排序规则。 Charset:字符集的名称。排序规则是与特定字符集关联的,该列显示了该排序规则适用的字符集。 Id:排序规则的内部编号。...如果没有指定排序规则MySQL 会基于字符集设置一个默认的排序规则。...当我们使用 CREATE DATABASE 或者 ALTER DATABASE 时,可以指定一个排序规则。...charset_name] [[DEFAULT] COLLATE collation_name] 同样,对于 CREATE TABLE 和 ALTER TABLE 语句,也可以为表或者字符类型的字段指定一个排序规则

    42620

    MySQL 批量修改所有表字段字符集及排序规则

    Liscense过期,所以验证的时候,验证过期了,所以每次启动之后就core dump了,所以想着重新申请了License,替换下 Jira的证书是在数据表productlicense中LICENSE字段存储的...报错数据库排列规则不是推荐的,但其实并没有修改数据库排列规则,之前是可以用的,这都不重要,那就改吧 先查看一番数据库的排序规则 ? 确实不是utf8_bin,接着看下该库里面表中字段排序规则 ?...同样是utf8_general_ci,没办法,只能改了 数据库里面还有其他库在用,所以没办法直接全局修改数据库的排序规则,只能单独修改这个库的所有表的所有字段排序规则 查看了下这个库,有300多张表...接下来就简单了,将得到的命令执行就可以了,将上面的查询结果通过mysql -e或select info outfile导出为.sql文件之后,直接导入.sql文件即可 ?...导入完成后,再去查看原来表的排序规则 ? 修改完毕,下班回家

    5.5K20

    展示斗地主扑克牌,支持出牌规则排序!支持大小排序

    而展示牌有3种排序方式: 不排序,列表是什么,就展示什么。(发牌、底牌常用) 按照大小排序。(手牌常用) 按照出牌规则排序。...所以,我们要按数字大小排列,数字相同时,固定花色顺序排列。 只要修改一下StaticPokerList,对它的ids参数做一个排序即可。 排序依据是什么呢?需要手写函数嘛? 答案是:当然不需要!...第4步,按照规则排序 上面大小排序还是太简单,只有结合了游戏规则排序,才是最难的! 我根据斗地主规则,总结了这样的排序算法: 输入:ids,即你出的牌的列表(前提:是符合斗地主规则的一串牌)。...输出:sortedIds,出牌规则排好序的列表。 统计每个数字的出现次数。 按照出现次数排序,出现频次高的,放在前面。 如果频次相同,按照数字大小排序。数字小的,放在在前。...pokerRuleMap同样有小数部分,是为了同数字时花色排序

    2K30

    Java 二维数组指定排序(一)

    参考链接: Java中的final数组 | Final arrays Java 二维数组指定排序(一)  简介: 在做项目时,需要对一个二维数组,按照指定的列进行排序。 ...Java 二维数组指定排序(二)升序 or 降序  效果图:  代码实现:      public static void main(String[] args) {         int[][]...("排序后:");         // 先根据第1列比较,若相同则再比较第0列         sortByColumn(nums, new int[] {1, 0});         printArr...[j] = (int) (Math.random() * 100);             }         }         return arr;     }     /**      * 排序...     * @param ob 待排序的数组      * @param order 列排序的优先级, 如:new int{1, 2} 先根据第一列比较,若相同则再比较第二列      */

    2.1K00

    MySQL order by的不同排序规则

    explain语句执行的结果中,Extra项中含有Using filesort表示需要排序MySQL会给每个线程分配一块内存用于排序,称为sort_buffer。...对sort_buffer中的数据order by条件快速排序。 按照排序结果取数据返回。 rowid排序 rowid排序涉及磁盘IO,需要一次回表操作,不受内存大小限制。...当排序字段较多时,内存可放下的行数很少,需要分成很多个临时文件,排序性能很差,即MySQL认为排序的单行长度太大会使用rowid排序。...对sort_buffer中的数据order by的条件进行排序。 遍历排序结果,取数据返回。...使用覆盖索引时,explain语句的Extra字段会多了个"Using index",表示使用索引覆盖。 MySQL的一个设计思想:如果内存够,就要多利用内存,尽量减少磁盘访问。

    30540

    多个字段中如何其中两个进行排序(二次排序

    多个字段中如何其中两个进行排序(二次排序) 1 原理     二次排序就是首先按照第一字段排序,然后再对第一字段相同的行按照第二字段排序,注意不能破坏第一次排序的结果。     ...这里主要讲如何使用一个Mapreduce就可以实现二次排序。Hadoop有自带的SecondarySort程序,但这个程序只能对整数进行排序,所以我们需要对其进行改进,使其可以对任意字符串进行排序。...            String line = value.toString();             // 调用java自己的工具类StringTokenizer(),将map输入的每行字符串规则进行分割成每个字符串...,这些规则有\t\n\r\f,基本上分割的结果都可以保证到最细的字符串粒度             StringTokenizer tokenizer = new StringTokenizer(line...IntPair.class, true);         }         // Compare two WritableComparables.         // 重载 compare:对组合键第一个自然键排序分组

    4.8K80

    MySQL 的字符集与排序规则

    排序规则 创建库的时候,我们经常会使用语句: CREATE DATABASE dbname DEFAULT CHARSET utf8 COLLATE utf8_general_ci; 既然我们知道了CHARSET...它代表着排序规则。...概念 MySQl排序规则(collation),一般指对字符集中字符串之间的比较、排序制定的规则, MySLQ排序规则特征: o 两个不同的字符集不能有相同的校对规则; o 每个字符集有一个默认校对规则...其实对于排序规则的细节问题,我们关注较少,反而对排序规则中是否涉及大小写敏感关注较多。 例如,系统使用 utf8 字符集,若使用 utf8_bin 排序规则,执行 SQL 查询时区分大小写。...使用 对于一种语言仅当使用 utf8_unicode_ci 排序做的不好时,才执行与具体语言相关的utf8字符集 校对规则

    2.4K20

    php自定义排序uasort函数示例【二维数组指定键值排序

    本文实例讲述了php自定义排序uasort函数。...分享给大家供大家参考,具体如下: 项目需要风险排序 I(安全)<L(低风险)<M(中风险)<H(高风险) 的级别来排序 由于H排在I的前面,所以不能直接用sort来排序,要自定义。...用uasort()函数来自定义排序: /* * 二维数组指定键值排须 */ function arr_sort($array,$key,$order="asc"){//asc是升序 desc是降序...// I<L<M<H 排序 $arr_nums=$arr=array(); foreach($array as $k= $v){ $arr_nums[$k]=$v[$key]; }...='H') return 1; } PS:这里再为大家推荐一款关于排序的演示工具供大家参考: 在线动画演示插入/选择/冒泡/归并/希尔/快速排序算法过程工具: http://tools.zalou.cn

    1.5K30

    MySQL原理 - 字符集与排序规则

    字符集与比较规则配置有四个级别: MySQL实例级别 库级别 表级别 字段级别 指定的级别粒度越小,则以粒度越小的字符集还有比较规则优先。...例如指定MySQL实例级别字符集是utf8mb4,指定某个表字符集是latin1,那么这个表的所有字段如果不指定的话,编码就是latin1 由于字符集和比较规则是互相有联系的,如果我们只修改了字符集,比较规则也会跟着变化...表级别 可以在创建时指定字符集合排序规则,不指定的话,用数据库的字符集还有排序规则,也可以修改字符集和排序规则。...,对于已有字段,并没有改变编码和排序规则。...列级别 可以在创建表的时候,指定不同的列有不同的字符集和排序规则,也可以修改列的字符集和排序规则mysql> create table test (name varchar(32) character

    3.1K10

    技术分享 | MySQL--测试--排序规则 collation

    ---摘抄:https://dev.mysql.com/doc/refman/8.0/en/charset-general.htmlhttps://dev.mysql.com/doc/refman/8.0...字符集和排序规则的默认选择:如果你仅指定字符集,⽽不指定排序规则,则排序规则为字符集默认的排序规则;如果你仅指定排序规则,不指定字符集,则字符集为排序规则对应的字符集;例外项⻅: "设置对象的字符集和排序规则...,则使⽤数据库中声明的作为默认值;table建表时的CHARACTER SET ⼦句;建表时的COLLATE ⼦句;如果未在单个列上指定字符集和排序规则,则将表中声明的作为默认值;column建表时字段定义上的...如果未指定字符集但指定排序规则,则字符集使⽤ character_set_connection;如果未指定字符集和排序规则,则使⽤character_set_connection和collation_connection...作为默认值;说明:如果客户是查询表中的数据,那么寻找数据时是否忽略⼤⼩写,取决于对应字段上的COLLATE⼦句中定义的排序规则;如果客户是直接查询字符串,那么寻找数据时是否忽略⼤⼩写,取决于collation_connection

    1.2K30
    领券