设为首页 收藏本站
查看: 840|回复: 0

[经验分享] 一个简单的mybatis封装(二)

[复制链接]

尚未签到

发表于 2016-11-27 09:28:42 | 显示全部楼层 |阅读模式
基于上一篇的封装,实现一个UserDAO
接口:IUserDAO,也是在mybatis配置中对应的一个mapper接口

package example.dao;
import java.util.List;
import java.util.Map;
import org.apache.ibatis.annotations.Param;
import example.model.User;
public interface IUserDAO {
public User findById(int id);
public User findByName(String name);
public void addUser(User user);
public List<User> findUsers(@Param("start")int start, @Param("size")int size);
public Map<Integer, User> findUserByIds(List<Integer> list);
}


具体实现,继承了AbstractBatisDAO,供业务逻辑层调用。

package example.dao.impl;
import java.util.List;
import java.util.Map;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.session.SqlSession;
import example.dao.AbstractBatisDAO;
import example.dao.IUserDAO;
import example.model.User;
public class UserDAO extends AbstractBatisDAO implements IUserDAO {
@Override
public User findById(final int id) {
User user = (User) super.process(new AbstractBatisDAO.SqlCaller() {
public Object doWith(SqlSession session) {
IUserDAO mapper = session.getMapper(IUserDAO.class);
return mapper.findById(id);
}
});
return user;
}
@Override
public User findByName(final String name) {
User user = (User) super.process(new AbstractBatisDAO.SqlCaller() {
public Object doWith(SqlSession session) {
IUserDAO mapper = session.getMapper(IUserDAO.class);
return mapper.findByName(name);
}
});
return user;
}
@Override
public void addUser(final User user) {
// TODO Auto-generated method stub
super.process(new AbstractBatisDAO.SqlCaller() {
public Object doWith(SqlSession session) {
IUserDAO mapper = session.getMapper(IUserDAO.class);
mapper.addUser(user);
return null;
}
});
}
@Override
public List<User> findUsers(@Param("start")final int start,
@Param("size")final int size) {
List<User> users = (List<User>)super.process(new AbstractBatisDAO.SqlCaller() {
public Object doWith(SqlSession session) {
IUserDAO mapper = session.getMapper(IUserDAO.class);
return mapper.findUsers(start, size);
}
});
return users;
}
@Override
public Map<Integer, User> findUserByIds(final List<Integer> list) {
Map<Integer, User> users = (Map<Integer, User>)super.process(new AbstractBatisDAO.SqlCaller() {
public Object doWith(SqlSession session) {
IUserDAO mapper = session.getMapper(IUserDAO.class);
return mapper.findUserByIds(list);
}
});
return users;
}
}


最后是一个调用的例子:

package example;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import example.dao.impl.UserDAO;
import example.model.User;
public class SimpleBatis {
public static void main(String[] args) throws Exception {
MybatisSessionMgr sessionMgr = new MybatisSessionMgr();
sessionMgr.init();
UserDAO userDao = new UserDAO();
userDao.setSessionMgr(sessionMgr);
User user = null;
user = new User();
user.setName("terry");
user.setSex((byte)1);
user.setAge(30);
userDao.addUser(user);
System.out.println("sleeping 2 seconds...");
user = userDao.findByName("terry");
if(user != null) {
System.out.println("find user:"+user.getName()+", id="+user.getId());
} else {
System.out.println("user not found");
}
List<Integer> ids = new ArrayList<Integer>(2);
ids.add(1);
ids.add(2);
Map<Integer, User> map = userDao.findUserByIds(ids);
if(map != null) {
for(Integer i : map.keySet()) {
System.out.println("key from map:"+i);
User u = map.get(i);
System.out.println(u.getId()+"-"+u.getName()+", sex:"+u.getSex()+", age:"+u.getAge());
}
}
}
}


SessionMgr,DAO的实现类都是线程安全,可以通过spring IOC将其单例化管理。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-306035-1-1.html 上篇帖子: Mybatis深入剖析 下篇帖子: 解决mybatis使用枚举的转换
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表