mapper mysql 分页_Mybatis+mysql动态分页查询数据案例——配置映射文件(HouseDaoMapper.xml)...

本文通过具体的案例展示了如何使用Mybatis配合MySQL进行动态分页查询。详细介绍了配置映射文件HouseDaoMapper.xml中的SQL语句,包括增删改查操作,并提供了根据多个条件进行筛选和分页的查询方法。
摘要由CSDN通过智能技术生成

select * form district where id=#{district_id}

select * from users where id=#{user_id}

select * from street where id=#{street_id}

select * from types where id=#{type_id}

ID, USER_ID, TYPE_ID, TITLE, DESCRIPTION, PRICE, PUBDATE, FLOORAGE, CONTACT, STREET_ID

select

from house

where ID = #{id,jdbcType=INTEGER}

delete from house

where ID = #{id,jdbcType=INTEGER}

insert into house

(

USER_ID, TYPE_ID, TITLE,

DESCRIPTION, PRICE, PUBDATE,

FLOORAGE, CONTACT, STREET_ID

)

values

(

#{users.id,jdbcType=INTEGER},

#{types.id,jdbcType=INTEGER}, #{title,jdbcType=VARCHAR},

#{description,jdbcType=VARCHAR}, #{price,jdbcType=REAL},

#{pubdate,jdbcType=DATE}, #{floorage,jdbcType=INTEGER},

#{contact,jdbcType=VARCHAR}, #{street.id,jdbcType=INTEGER}

)

update house set

USER_ID = #{users.id,jdbcType=INTEGER},

TYPE_ID = #{types.id,jdbcType=INTEGER},

TITLE = #{title,jdbcType=VARCHAR},

DESCRIPTION = #{description,jdbcType=VARCHAR},

PRICE= #{price,jdbcType=REAL},

PUBDATE = #{pubdate,jdbcType=DATE},

FLOORAGE = #{floorage,jdbcType=INTEGER},

CONTACT= #{contact,jdbcType=VARCHAR},

STREET_ID = #{street.id,jdbcType=INTEGER}

where ID = #{id,jdbcType=INTEGER}

select count(0) from house h

and h.price > #{priceBegin}

and h.price #{priceEnd}

and h.street_id = #{street.id}

and h.type_id = #{types.id}

and h.floorage > #{floorageBegin}

and h.floorage #{floorageEnd}

select * from house h

and h.price > #{priceBegin}

and h.price #{priceEnd}

and h.street_id = #{street.id}

and h.type_id = #{types.id}

and h.floorage > #{floorageBegin}

and h.floorage #{floorageEnd}

limit #{stratRow},#{endRow}

select * from house

select * from house limit #{startRow},#{endRow}

分享到:

18e900b8666ce6f233d25ec02f95ee59.png

72dd548719f0ace4d5f9bca64e1d7715.png

2017-03-18 22:52

浏览 138

评论

MyBatis-Plus提供了非常方便的分页查询功能,可以直接使用Page类来进行分页查询。 使用MyBatis-Plus的分页查询,需要进行以下步骤: 1. 引入MyBatis-Plus的依赖:在pom.xml添加以下依赖: ``` <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.4.0</version> </dependency> ``` 2. 定义实体类:定义需要进行分页查询的实体类,并使用注解@TableField进行字段映射。 3. 定义Mapper接口:定义Mapper接口,并继承BaseMapper类,继承BaseMapper类后,MyBatis-Plus会自动提供一些基本的CRUD操作。 ``` public interface UserMapper extends BaseMapper<User> {} ``` 4. 分页查询:在Service层调用分页查询方法,使用Page对象设置分页参数,然后调用selectPage方法进行分页查询。 ``` @Service public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; @Override public Page<User> getUserList(int pageNum, int pageSize) { Page<User> page = new Page<>(pageNum, pageSize); return userMapper.selectPage(page, null); } } ``` 如果需要自定义sql分页,可以在xml使用MyBatis分页插件进行分页查询。 1. 引入分页插件:在pom.xml添加以下依赖: ``` <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper</artifactId> <version>5.1.10</version> </dependency> ``` 2. 配置分页插件:在MyBatis配置文件配置分页插件。 ``` <plugins> <plugin interceptor="com.github.pagehelper.PageInterceptor"> <property name="dialect" value="mysql"/> </plugin> </plugins> ``` 3. 自定义sql分页查询:在xml使用分页插件的PageHelper.startPage方法进行分页查询。 ``` <select id="getUserList" resultMap="userMap"> select * from user <where> <if test="name != null"> and name like concat('%',#{name},'%') </if> </where> order by id desc </select> ``` ``` @Service public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; @Override public PageInfo<User> getUserList(int pageNum, int pageSize, String name) { PageHelper.startPage(pageNum, pageSize); List<User> userList = userMapper.getUserList(name); return new PageInfo<>(userList); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值