日期:2014-05-16  浏览次数:20517 次

总结:ibatis对derby数据库操作,以及与spring的集成(ibatis's hello world)

转载请注明出处: http://renjie120.iteye.com/

?

用过ibatis之后,感觉hibernate太复杂.

使用过derby数据库之后,感觉mysql也很大.

helloWorld工程很重要,学习新东西完成helloWorld就心里有底了.


闲来无聊,看了一下这些东西,发现derby好好玩.花了几天时间学习了一下基本的ibatis,derby的知识,然后集合了spring框架.

?

遇到了几个小小的问题,都一一解决了,这里好好总结一下以后再次遇到就不用浪费时间百度了.

?

1.使用jdbc连接derby数据库的基本语句如下,注意有用户名,密码 的情况,要使用properties文件包含用户名和密码,然后通过properties读值:

private static Properties properties = null;
	static {
		// getResourceAsStream的参数"/application.properties"表示以当前类的包的根路径为基准路径   
		InputStream inputStream = DerbyUtil.class
				.getResourceAsStream("/derby.properties");
		properties = new Properties();
		try {
			properties.load(inputStream);
			inputStream.close();
		} catch (IOException e) {
			System.out.println("获取系统属性文件异常:");
		}
	}

	/**
	 * 取得数据库连接
	 * @return
	 */
	public static Connection getCon() {
		Connection con = null;
		String driver = "org.apache.derby.jdbc.EmbeddedDriver";
		String connectionURL = "jdbc:derby:testIbatis;create=true;";
		// 装载数据库驱动.
		try {
			Class.forName(driver);
			System.out.println(driver + " loaded. ");
		} catch (java.lang.ClassNotFoundException e) {
			System.err.print("ClassNotFoundException: ");
			System.out.println("缺少derby相关jar包!");
		}
		try {
			con = DriverManager.getConnection(connectionURL, properties);
		} catch (SQLException e) {
			System.out.println("出现异常.");
			errorPrint(e);
		}
		return con;
	}

?经常遇到的一个错误是:

--- Cause: java.sql.SQLException: Schema '.......' does not exist

原因就是因为数据库连接的用户名,密码有误!

上面的/derby.properties内容如下:注意用户名,密码的key!开始我写成了use,password(因为直接连接derby的话,配置用户名密码就是用user=;password=),结果找了半天!!

JDBC.Username=admin
JDBC.Password=admin

?

2.使用ibatis 的 sqlMapClient连接数据库的基本方式如下:不论什么数据库都是一样,derby,mysql,oracle都这样写.

public List getDises(Dis argVo) {
		String resource = "ibatis/SqlMapConfig.xml";
		SqlMapClient sqlMap = null;
		List ans = null;
		try {
			Reader reader = Resources.getResourceAsReader(resource);
			sqlMap = SqlMapClientBuilder.buildSqlMapClient(reader);
		} catch (Exception e) {
			e.printStackTrace();
		}
		// sqlMap系统初始化完毕,开始执行getAllUser操作
		try {
			sqlMap.startTransaction();
			ans =  sqlMap.queryForList("getDises", argVo);
			sqlMap.commitTransaction();
		} catch (SQLException e) {
			System.out.println(e.getMessage());
		} finally {
			try {
				sqlMap.endTransaction();
			} catch (SQLException e) {
				e.printStackTrace();
			}
		}
		return ans;
	}

?

3.上面的写法很多都是重复的部分,所以可以使用模板类进行简化书写,要继承SqlMapDaoTemplate这个类,然后还要在ibatis基础配置文件上,再多添加一个配置文件DaoConfig.xml,一般还会要多添加一个类叫做DaoConfig.java.

DaoConfig.xml配置文件一般如下所示:

?

<daoConfig>
	<context>
		<transactionManager type="SQLMAP">
			<property name="SqlMapConfigResource"
				value="ibatis/SqlMapConfig.xml" />
		</transactionManager>

		<dao interface="ibatis.newTest.IDistrict"
			implementation="ibatis.dao.NewTestDistrict" />
	</context>
</daoConfig>

?

实现的方式网上很多,但是我遇到了一个很郁闷的问题,找了很久,错误如下:

Exception in thread "main" java.lang.ClassCastException: $Proxy1
??? at ibatis.dao.NewTestDistrict.main(NewTestDistrict.java:24)


找了半天,原来在写测试类的时候,

DaoManager daoManager = DaoConfig.getDaoManager();

NewTestDistrict test= (