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

MySQL根据输入查询条件排序

问题      现在一个需求是查询某一列,用逗号分开,返回结果要根据输入顺序返回结果      比如:姓名输入框输入是(zhangsan,lisi),那么返回结果也要是按照(zhangsan,...lisi)这样顺序展示 测试 有如下表classroom,内容如下 如果根据字段名称去查,那么它会根据字典顺序排序,如下所示 select * from classroom where classname...in ("class2","class3") order by classname 如果想根据我in里面的顺序去排序,那么只能是如下所示 select * from classroom where classname...in ("class2","class3") order by field(classname,"class3","class2") 如果我想在原来基础上,在根据时间排序 select * from...条件必须比 in 里面的查询条件多,如果少一个,那么这个排序就不会成功 //成功 select * from classroom where classname in ("class2","class3

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

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

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

    4.6K30

    Elasticsearch中将Doc根据A字段排序获得第一个DocB字段方法

    注:本文基于Elasticsearch 6.1.2编写 最近遇到这样一个需求,要通过Elasticsearch将Doc根据A字段降序,然后获得B字段值,最终根据B字段值再去做Pipeline Aggregation...先尝试了Max Aggregation,但是Max Aggregation只能获得A字段最大值。...下面举例说明 比如现在我们有一堆股票价格数据,我们现在需要获得股票每天收盘价比前一天差值(Delta)。...下面先倒入一段股票数据,date字段代表时间戳,price字段代表当时价格: POST /_bulk {"index":{"_index":"stock-price","_type":"data"}...,这个会用到Scripted Metric Aggregation 最后根据算每个bucket差值,这个会用到Serial Differencing Aggregation 下面是查询代码: GET

    1.1K20

    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根据某个字段将多条记录某个字段拼接成一个字段

    问题 GROUP_CONCAT函数用于将多个字符串连接成一个字符串,在拼接成字符串时就会存在拼接长度问题,MySQL 默认拼接最大长度为1024 个字节,由于1024个字节会出现不够用情况,所以有时需要去根据情况进行修改..., 使用SHOW VARIABLES LIKE "%group_concat_max_len%"查看 mysql> SHOW VARIABLES LIKE "%group_concat_max_len%...> 1 临时修改(命令行) 1.1 修改group_concat_max_len长度为:10240 mysql> SET GLOBAL group_concat_max_len = 10240; mysql...[mysqld] ...... group_concat_max_len = 10240  #添加 2.2 重启mysql服务 如果mysql服务不重启的话,可以配合临时修改一起使用 $ service...> 3 附加 有时我们并不知需要多大字节才能满足需求,此种情况可以考虑不设置最大字节(即采用最大字节数)即在配置文件设置group_concat_max_len=-1 此种情况下group_concat_max_len

    1.9K20

    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

    根据数字二进制下 1 数目排序

    请你将数组中元素按照其二进制表示中数字 1 数目升序排序。 如果存在多个数字二进制中 1 数目相同,则必须将它们按照数值大小升序排列。 请你返回排序数组。...示例 1: 输入:arr = [0,1,2,3,4,5,6,7,8] 输出:[0,1,2,4,8,3,5,6,7] 解释:[0] 是唯一一个有 0 个 1 数。...按照 1 个数排序得到结果数组为 [0,1,2,4,8,3,5,6,7] 示例 2: 输入:arr = [1024,512,256,128,64,32,16,8,4,2,1] 输出:[1,2,4,8,16,32,64,128,256,512,1024...] 解释:数组中所有整数二进制下都只有 1 个 1 ,所以你需要按照数值大小将它们排序。...tupleList = [(x,(dict(Counter(bin(x)))).get("1",0)) for x in arr] # 根据先【1数量】再【值】排序

    20100

    根据数字二进制下 1 数目排序

    请你将数组中元素按照其二进制表示中数字 1 数目升序排序。 如果存在多个数字二进制中 1 数目相同,则必须将它们按照数值大小升序排列。 请你返回排序数组。...示例 1: 输入:arr = [0,1,2,3,4,5,6,7,8] 输出:[0,1,2,4,8,3,5,6,7] 解释:[0] 是唯一一个有 0 个 1 数。...按照 1 个数排序得到结果数组为 [0,1,2,4,8,3,5,6,7] 示例 2: 输入:arr = [1024,512,256,128,64,32,16,8,4,2,1] 输出:[1,2,4,8,16,32,64,128,256,512,1024...] 解释:数组中所有整数二进制下都只有 1 个 1 ,所以你需要按照数值大小将它们排序。...tupleList = [(x,(dict(Counter(bin(x)))).get("1",0)) for x in arr] # 根据先【1数量】再【值】排序

    18610

    MySQL字段类型_mysql数据库字段类型

    大家好,又见面了,我是你们朋友全栈君。 前言: 要了解一个数据库,我们必须了解其支持数据类型。MySQL 支持大量字段类型,其中常用也有很多。...例如字段 salary DECIMAL(5,2),能够存储具有五位数字和两位小数任何值,因此可以存储在salary列中范围是从-999.99到999.99。...2.字符串类型 字符串类型也经常用到,常用几个类型如下表: 其中 char 和 varchar 是最常用到。char 类型是定长MySQL 总是根据定义字符串长度分配足够空间。...3.日期时间类型 MySQL支持日期和时间类型有 YEAR 、TIME 、DATE 、DATETIME 、TIMESTAMP,几种类型比较如下: 涉及到日期和时间字段类型选择时,根据存储需求选择合适类型即可...总结: 本篇文章主要介绍了 MySQL 中常用字段类型,平时用到字段类型基本都在这里了,以一张思维导图总结如下: 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。

    19.4K10

    WordPress自定义字段字符串类型转数字排序

    ,就像子凡给我们网站开发了一个标签页访问统计功能,但是在后台访问量却无法准确安装访问量排序,所以这就是子凡要解决问题。...经过一番排除发现给 WordPress 标签自定义字段参数在数据库中默认都是字符串类型,而对于访问量这种数字排序就需要将字符串转换一下类型,才能够正常排序。...当然 WordPress 在 wp_query 查询中需要对自定义类型做数据类型排序可以直接把 meta_value 换成 meta_value_num 就行了。...$pieces['orderby'] = ' ORDER BY CAST(tm.meta_value AS UNSIGNED) ';//转换类型排序(这才是本文要分享重点) break;...} return $pieces; } 注意查看代码中注释信息,其实就是使用了 SQL 中 CAST 方式,本来想要转换成数字类型发现居然报错了,后来换成 UNSIGNED 就成功了,我自己也比较懵

    64940
    领券