mysql、mybatis中SORT

SORT排序

根据数据表sys_series中HOT(int类型)进行升序排列:

  • 原来的数据库中存储:
    初始
  • 排序
# 结果是HOT字段为null的所有数据都排在最前面,不为null的数据按升序排列
SELECT * FROM sys_series ORDER BY HOT;

直接sort字段升序

# 结果是HOT字段为null的所有数据都排在最后面,不为null的数据按数据库中原本的先后顺序排列
SELECT * FROM sys_series ORDER BY isnull(HOT);

isnull

# 结果是HOT字段为null的所有数据都排在最后面,不为null的数据按升序排列
SELECT * FROM sys_series ORDER BY isnull(HOT), HOT;

null排在最后面升序

# 结果是HOT字段为null的所有数据都排在最前面,不为null的数据按升序排列
SELECT * FROM sys_series ORDER BY HOT, isnull(HOT);

先排字段
最后一种相当于第一种。因为对于ORDER BY排序的优先级是从前往后,先按第一个order by的字段进行排序,如果遇到了两个相同的,则按照第二个排列,eg:

# 先按NEED的值升序排列,若NEED值相等,则根据HOT的值升序
SELECT * FROM sys_series ORDER BY NEED, HOT;

两个字段排序

# 先按NEED的值升序排列,若NEED值相等,则根据HOT的降序
SELECT * FROM sys_series ORDER BY NEED, HOT DESC;

两字段排序

Mybatis

List<SysSeries> getLike();
<select id="getLike" resultType="java.util.List">
    SELECT *    
    FROM sys_series    
    ORDER BY ISNULL(HOT), HOT
</select>
报错

The error occurred while handling results### SQL: SELECT * FROM sys_series ORDER BY ISNULL(HOT), HOT### Cause: java.lang.UnsupportedOperationException

原因

resultType配置错误,返回的结果为List,所以resultType应该配置为实体类的路径:resultType=“com.harmony.supreme.modular.series.entity.SysSeries”,eg:

List<String> getAllIds();
<select id="getAllIds" resultType="java.lang.String"></select>
SysSeries selectById(String id);
<select id="selectById" resultType="com.harmony.supreme.modular.series.entity.SysSeries"></select>
List<Map<String, Object>> countByIdList(@Param("idList") List<String> idList);
<select id="countByIdList" resultType="java.util.Map"></select>

问答

根据 int 类型的字段 SORT 进行升序排列,如果SORT值为null空,则按创建时间升序排列:

select * from table_name ORDER BY ISNULL(SORT), SORT,CREATE_TIME
select * from table_name where (create_user = 'xxx') ORDER BY ISNULL(SORT), SORT,CREATE_TIME
List<TableName> get(String createUser);
<select id="get" parameterType="java.lang.String" resultType="com.harmony.supreme.modular.entity.tableName ">
    SELECT *    
    from table_name 
    WHERE CREATE_USER = #{createUser}    
    ORDER BY ISNULL(SORT), SORT, CREATE_TIME
</select>

把createUser等于eq的条件改为id属于in的条件:

List<tableName> getByLink(List<String> ids);
<select id="getByLink" parameterType="java.util.List" resultType="com.harmony.supreme.modular.entity.tableName ">
        SELECT *
        from table_table
        WHERE ID IN
        <foreach collection="list" item="id" separator="," open="(" close=")">
            #{id}
        </foreach>
        ORDER BY ISNULL(SORT), SORT, CREATE_TIME
</select>

相关推荐

  1. Pythonsort()与sorted()用法

    2024-02-12 15:12:02       16 阅读
  2. C++sort()排序函数使用方法

    2024-02-12 15:12:02       40 阅读
  3. Js的Array.prototype.sort()

    2024-02-12 15:12:02       32 阅读
  4. C++vector的sort用法

    2024-02-12 15:12:02       30 阅读
  5. 如何在vue使用sort对数组进行排序

    2024-02-12 15:12:02       20 阅读
  6. 【C++】STLsort算法使用了什么排序算法?

    2024-02-12 15:12:02       13 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-02-12 15:12:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-12 15:12:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-12 15:12:02       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-12 15:12:02       20 阅读

热门阅读

  1. 这条路那么远

    2024-02-12 15:12:02       32 阅读
  2. python udp端口范围映射转发

    2024-02-12 15:12:02       30 阅读
  3. 课时21:内置变量_脚本相关

    2024-02-12 15:12:02       27 阅读
  4. SQl 注入 - 利用报错函数updatexml及extracevalue

    2024-02-12 15:12:02       38 阅读
  5. Jwt生成token以及解析token

    2024-02-12 15:12:02       29 阅读
  6. 多重背包问题 Ⅰ&Ⅱ &Ⅲ

    2024-02-12 15:12:02       32 阅读
  7. AutoSAR(基础入门篇)8.2-IO相关驱动(一)

    2024-02-12 15:12:02       32 阅读