欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

mybatis查询数据赋值到model里面为空的解决

程序员文章站 2022-03-08 18:41:57
目录查询数据赋值到model里为空查询无数据的时候问题查询数据赋值到model里为空因为数据多所以在查询中使用分页,但是发现直接执行sql语句是可以获取到数据,而list里面却是空的

查询数据赋值到model里为空

因为数据多所以在查询中使用分页,但是发现直接执行sql语句是可以获取到数据,而list里面却是空的

<select id="list" resulttype="daliydo">
        select a1.* from (
            select
                id ,rownum
            from dual 
            <where>
                <if test="id != null and id != ''"> and id = #{id} </if>
            </where>
            <choose>
                <otherwise>
                    order by id desc
                </otherwise>
            </choose>
            ) a1
        <if test="offset != null and limit != null">
            where rownum between #{offset} and #{offset}+#{limit}
        </if>
    </select>

原因是 resulttype属性与model不对应。

我们使用分页会在查询值加入一个rownum的值,这个值在我们建立model的时候是没有的,所以只要在model里面加上rownum这个属性就可以。

当然你也可以使用别的分页方法

查询无数据的时候问题

1.如果返回值是list、map这种集合类,会先执行new语句,再赋值。所以判断是否有数据时,只能用size==0来判断。

2.如果是普通的对象,不会new,所以可以使用是否为null来判断是否有数据。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。