最近研究了一下Spring + iBATIS。发现看别人的例子是一回事,自己写一个完整的应用又是另外一回事。自己受够了网上贴的一知半解的代码。
iBATIS是一个持久化框架,封面了sql过程,虽然sql语句需要自己写。另外,我觉得对于初学者来说,完整的示例真的很重要,不然不知道文件是如果放置的。
所有的第三包都需要加上,spring、ibatis.-2.3.3.720.jar、sqlijdbc.jar、oscache-2.4.jar、commons-pool-1.3.jar、commons-dbcp-1.4.jar,mysql-connector-5.0.5.jar。不然运行的时候都要报错。
xml文件的位置也很关键,因为访问配置文件需要确定他的路径。
有三个包:
1.bean。
bean包封装了POJO对象Ibatis,如下:
package com.tmall.bean;
public class Ibatis {
private String id;
private String name;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Ibatis(){
}
public Ibatis(String id, String name) {
super();
this.id = id;
this.name = name;
}
}
Dao里面有一个Dao和DaoImp。Dao是一个接口,DaoImp实现了Dao的接口。
Dao.java如下:
package com.tmall.dao;
import java.util.List;
import com.tmall.bean.Ibatis;;
public interface Dao {
public List getList();
public Ibatis getByName(String name);
public Ibatis getById(String id);
public void insert(Ibatis ibatis);
public void delete(String id);
public void update(Ibatis ibatis);
}
package com.tmall.dao;
import java.util.List;
import org.springframework.orm.ibatis.support.SqlMapClientDaoSupport;
import com.tmall.bean.Ibatis;
public class DaoImp extends SqlMapClientDaoSupport implements Dao {
public void delete(String id) {
getSqlMapClientTemplate().delete("deleteUsers", id);
}
public Ibatis getById(String id) {
return (Ibatis)getSqlMapClientTemplate().queryForObject("getUsersById",id);
}
public Ibatis getByName(String name) {
return (Ibatis)getSqlMapClientTemplate().queryForObject("getUsersByName",name);
}
@SuppressWarnings("unchecked")
public List getList() {
return getSqlMapClientTemplate().queryForList("getAllUsers",null);
}
public void insert(Ibatis ibatis) {
getSqlMapClientTemplate().insert("insertUsers",ibatis);
}
public void update(Ibatis ibatis) {
getSqlMapClientTemplate().update("updateUsers", ibatis);
}
}
applicationContext.xml文件是spring的配置文件,如下:
com.mysql.jdbc.Driver
root
123456
jdbc:mysql://localhost:3306/test
sqlMapConfig.xml
insert into ibatis (id,name) values (#id#,#name#)
delete from ibatis where id=#value#
update ibatis set name=#name# where id=#id#
package com.tmall.test;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import com.tmall.bean.Ibatis;
import com.tmall.dao.Dao;
public class Test {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
ApplicationContext context=new ClassPathXmlApplicationContext("applicationContext.xml");
Dao dao = (Dao)context.getBean("DaoImp");
dao.insert(new Ibatis("3","new3"));
Ibatis ibatis3 = dao.getById("2");
ibatis3.setName("new7");
dao.update(ibatis3);
// testDAOImpl.delete("3");
System.out.println("获得全查询列表");
List result=new ArrayList();
result = dao.getList();
for (Iterator iter = result.iterator(); iter.hasNext();) {
Ibatis element = (Ibatis) iter.next();
System.out.println(element.getName());
}
}
}