by mybatis 自定义order_Mybatis自定义查询模板

mybatis查询使用是比较方便的,使用Mybatis generator可以直接从数据库逆向生成实体类。

但是有时,想自定义查询,就需要自己写相关类。

需要写的类有三个,以及一个xml文件:

ChatRoomMemberEX 实体类

ChatRoomMemberEXMapper .xml 书写sql语句

ChatRoomMemberEXExample 定义查询条件

ChatRoomMemberEXMapper 查询接口,定义查询方法

实体类

public class ChatRoomMemberEX implements Serializable {

private Integer clubId;

private String clubName;

private String clubMemberId;

private String clubMemberName;

private Boolean canSpeak;

public Integer getClubId() {

return clubId;

}

public void setClubId(Integer clubId) {

this.clubId = clubId;

}

public String getClubName() {

return clubName;

}

public void setClubName(String clubName) {

this.clubName = clubName;

}

public String getClubMemberId() {

return clubMemberId;

}

public void setClubMemberId(String clubMemberId) {

this.clubMemberId = clubMemberId;

}

public String getClubMemberName() {

return clubMemberName;

}

public void setClubMemberName(String clubMemberName) {

this.clubMemberName = clubMemberName;

}

public Boolean getCanSpeak() {

return canSpeak;

}

public void setCanSpeak(Boolean canSpeak) {

this.canSpeak = canSpeak;

}

}

查询xml,包含一个查询方法:

club_id, club_name,club_member_id,club_member_name,club_canSpeak

distinct

'true' as QUERYID,

from club_detail

order by ${orderByClause}

limit #{begin} , #{length}

and ${criterion.condition}

and ${criterion.condition} #{criterion.value}

and ${criterion.condition} #{criterion.value} and #{criterion.secondValue}

and ${criterion.condition}

#{listItem}

增加一个查询条件,在ChatRoomMemberEXExample 的内部类GeneratedCriteria中添加

public Criteria andCanSpeakEqualTo(Boolean value){

addCriterion("club_canSpeak not in", value, "canSpeak");

return (Criteria) this;

}

ChatRoomMemberEXExample 代码:

public class ChatRoomMemberEXExample {

protected String orderByClause;

protected boolean distinct;

protected ListoredCriteria;

protected Integer begin;

protected Integer length;

public ChatRoomMemberEXExample() {

oredCriteria = new ArrayList();

}

public static class Criteria extends GeneratedCriteria {

protected Criteria() {

super();

}

}

protected abstract static class GeneratedCriteria {

protected Listcriteria;

protected GeneratedCriteria() {

super();

criteria = new ArrayList();

}

protected void addCriterion(String condition) {

if (condition == null) {

throw new RuntimeException("Value for condition cannot be null");

}

criteria.add(new Criterion(condition));

}

protected void addCriterion(String condition, Object value, String property) {

if (value == null) {

throw new RuntimeException("Value for " + property + " cannot be null");

}

criteria.add(new Criterion(condition, value));

}

protected void addCriterion(String condition, Object value1, Object value2, String property) {

if (value1 == null || value2 == null) {

throw new RuntimeException("Between values for " + property + " cannot be null");

}

criteria.add(new Criterion(condition, value1, value2));

}

public Criteria andCanSpeakEqualTo(Boolean value){

addCriterion("club_canSpeak not in", value, "canSpeak");

return (Criteria) this;

}

}

public static class Criterion {

private String condition;

private Object value;

private Object secondValue;

private boolean noValue;

private boolean singleValue;

private boolean betweenValue;

private boolean listValue;

private String typeHandler;

public String getCondition() {

return condition;

}

public Object getValue() {

return value;

}

public Object getSecondValue() {

return secondValue;

}

public boolean isNoValue() {

return noValue;

}

public boolean isSingleValue() {

return singleValue;

}

public boolean isBetweenValue() {

return betweenValue;

}

public boolean isListValue() {

return listValue;

}

public String getTypeHandler() {

return typeHandler;

}

protected Criterion(String condition) {

super();

this.condition = condition;

this.typeHandler = null;

this.noValue = true;

}

protected Criterion(String condition, Object value, String typeHandler) {

super();

this.condition = condition;

this.value = value;

this.typeHandler = typeHandler;

if (value instanceof List>) {

this.listValue = true;

} else {

this.singleValue = true;

}

}

protected Criterion(String condition, Object value) {

this(condition, value, null);

}

protected Criterion(String condition, Object value, Object secondValue, String typeHandler) {

super();

this.condition = condition;

this.value = value;

this.secondValue = secondValue;

this.typeHandler = typeHandler;

this.betweenValue = true;

}

protected Criterion(String condition, Object value, Object secondValue) {

this(condition, value, secondValue, null);

}

}

}

查询接口

public interface ChatRoomMemberEXMapper {

ListgetAllChatRoomMembers(ChatRoomMemberEXExample chatRoomMemberEXExample);

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值