一个简单的测试用例中ibatis2.3.4 + h2 1.3.146。只有一个map类,
H2是用的Embedded模式运行的
package org.jamsa
case class User(var userName:String,var id:Int){
def this()=this("abc",-1)
}
import com.ibatis.sqlmap.client.SqlMapClientBuilder
import com.ibatis.common.resources.Resources
object Client {
val sqlMapClient = initSqlMapClient();
private def initSqlMapClient()={
SqlMapClientBuilder.buildSqlMapClient(Resources.getResourceAsReader("sql-map-config.xml"))
}
}
import com.ibatis.common.resources.Resources
import Client.sqlMapClient
object UserDao {
def getUser(id:Int)={
sqlMapClient.queryForObject("getUser",id).asInstanceOf[User]
}
def addUser(user:User)={
sqlMapClient.insert("addUser",user)
}
def deleteUser(id:Int)={
sqlMapClient.delete("deleteUser",id)
}
def main(args:Array[String]){
var user = User("abc5",5)
addUser(user)
Thread.sleep(2000)
}
}
如果不加Thread.sleep这行,数据就不会被保存到数据库里去。
从控制台可以看到语句都执行了,但是数据没有被保存进去。
如果H2以Server模式运行,没有出现这个问题。
暂时没找到具体原因
本文探讨了一个使用Ibatis 2.3.4和H2 1.3.146进行数据操作的问题案例。在测试环境中,采用H2数据库的Embedded模式时,发现即使执行了插入语句并且没有报错,数据也不会被保存到数据库中,除非增加Thread.sleep延迟。
176

被折叠的 条评论
为什么被折叠?



