利用MyBatis Generator自动创建代码

阅读更多

如果你使用过hibernate的eclipse插件自动创建DAO文件,那么就容易理解下面介绍的内容;如果你还没有用过hibernate也无妨。下面介绍使用mybatis 3的eclipse插件自动生成相关文件以及如何使用这些文件。

 

eclipse插件安装地址:http://mybatis.googlecode.com/svn/sub-projects/generator/trunk/eclipse/UpdateSite/

 

附件有link安装包,link安装方式参考http://maimode.iteye.com/admin/blogs/1164524

 

MyBatis Generator详细介绍参见:http://code.google.com/p/mybatis/wiki/Generator

 

安装插件的过程就不说了,安装完后,eclipse中File-》new-》other中会发现多了mybatis选项说明插件安装成功。

 

利用MyBatis Generator自动创建代码_第1张图片

 

如何使用插件

 

在任意项目中利用上图中的向导创建generatorConfig.xml文件(名称可修改)然后修改文件内容,主要是设置连接数据的相关参数:

 

 




  
    
    
    
    
    

 

 

根据名称应该能才出来大致的意思。

 

配置好连接数据库及表的信息后就可以利用插件自动生成代码了。

 

利用MyBatis Generator自动创建代码_第2张图片

 

点击上图中的选项,如果配置正确,便自动创建相关文件了。

文件主要有三类:

client包,mapper 接口文件

model包,实体bean文件

mapper包,mapper xml文件

 

如何使用这些自动生成的文件

 

首先需要将mapper包下的xml文件添加到mybatis的sqlmapper文件中

 

利用MyBatis Generator自动创建代码_第3张图片

 

然后程序中这样使用:

 

 

public List selectTrackOnRoute(String routeName) {
		List rt = null;
		SqlSession session = null;
		try {
			session = sqlSessionFactory.openSession();
			AtfmTrackMapper mapper = session.getMapper(AtfmTrackMapper.class);
			// 构造查询条件
			AtfmTrackExample example = new AtfmTrackExample();
			example.createCriteria()
			.andRouteIs(routeName);
			// 查询
			List list = mapper.selectByExample(example);
			// 包装成TrackBean
			rt = this.toTrackBean(list);
		} catch (Exception e) {
			e.printStackTrace();
			logger.error(e.getMessage());
		} finally {
			if (session != null)
				session.close();
		}
		return rt;
	}

 

如果where条件比较复杂,还可以自定义查询条件,如上例中andRouteIs(routeName)就是自定义的查询条件。可以在

具体的Example的内部类Criteria中自定义查询条件:

利用MyBatis Generator自动创建代码_第4张图片

 

 

public Criteria andRouteIs(String routeName){
			StringBuffer sb = new StringBuffer("point_name in " +
					"(select p.point from route_point p where p.route = '" + routeName + "') " +
					"AND FLIGHT_NO IN " +
					"(select D.FLIGHT_NO from syn_aftn_dynamic_recent d " +
					"where d.route like '%" + routeName + "%')");
			
			addCriterion(sb.toString());
			return this;
		}

 

我们可能会担心一旦重新执行generate的时候,我们自己编写的代码会不会丢失,不会的,插件不会修改或丢弃我们自己编写的代码

 

一旦掌握了插件如何使用,重要的工作就是如何使用XXXExample类了。这种方式,完全不用编写繁琐的mapper xml文件。

  • 利用MyBatis Generator自动创建代码_第5张图片
  • 大小: 44.6 KB
  • 利用MyBatis Generator自动创建代码_第6张图片
  • 大小: 34.8 KB
  • 利用MyBatis Generator自动创建代码_第7张图片
  • 大小: 53.5 KB
  • 利用MyBatis Generator自动创建代码_第8张图片
  • 大小: 24.5 KB
  • MyBatis_Generator_1.3.1.zip (2.2 MB)
  • 下载次数: 4561
  • 查看图片附件

你可能感兴趣的:(mybatis,数据持久层)