public class AttendDO { private String username; private Date attendTime; private int type; public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public Date getAttendTime() { return attendTime; } public void setAttendTime(Date attendTime) { this.attendTime = attendTime; } public int getType() { return type; } public void setType(int type) { this.type = type; } }
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd"> <context:component-scan base-package="com.HG.test"/> <!-- 扫描java文件,将所有注解标示的类注册为bean --> <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="locations"> <list> <value>classpath:jdbc.properties</value> </list> </property> </bean> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="${driver}"/> <property name="url" value="${url}"/> <property name="username" value="${username}"/> <property name="password" value="${password}"/> </bean> <bean id="sqlMapClient" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean"> <property name="configLocation" value="classpath:sqlMapConfig.xml"/> <property name="dataSource" ref="dataSource"/> </bean> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource"/> </bean> </beans>
driver = com.mysql.jdbc.Driver url = jdbc:mysql://localhost:3306/Attendance username = root password = 910718
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE sqlMapConfig PUBLIC "-//ibatis.apache.org//DTD SQL Map Config 2.0//EN" "http://ibatis.apache.org/dtd/sql-map-config-2.dtd"> <sqlMapConfig> <!-- 这里可以写多个实体的映射文件 --> <sqlMap resource="sqlmap-attend.xml"/> </sqlMapConfig> 其中,sqlMapConfig中写入相应的映射文件,这个映射就表示了一张数据表与相应的java对象的映射关系。 sqlmap-attend.xml如下: <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE sqlMap PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN" "http://ibatis.apache.org/dtd/sql-map-2.dtd"> <sqlMap> <!-- 为AttendDO设置一个别名 --> <typeAlias alias="AttendDO" type="com.HG.test.pojo.AttendDO"/> <!-- 配置对象和数据表之间的映射关系 --> <resultMap id="attendDO" class="AttendDO"> <result property="username" column="username" /> <result property="attendTime" column="attendTime" /> <result property="type" column="type" /> </resultMap> <insert id="insert_attend" parameterClass="AttendDO"> <![CDATA[ insert into attend(username, attendTime, type) values(#username#, #attendTime#, #type#) ]]> </insert> <select id="select_attend_time" parameterClass="java.util.Map" resultMap="attendDO"> <![CDATA[ select * from attend where attendTime BETWEEN #startTime# AND #endTime# ]]> </select> </sqlMap>
<import resource="classpath:applicationContext.xml"/>
@Component public class AttendDaoImpl extends SqlMapClientDaoSupport implements AttendDAO { @Resource(name = "sqlMapClient") private SqlMapClient sqlMapClient; @PostConstruct public void initSqlMapClient(){ super.setSqlMapClient(sqlMapClient); } @Override public boolean insert_attend(AttendDO attendDO) { Object result = getSqlMapClientTemplate().insert("insert_attend", attendDO); return result != null ? true:false; } @Override public List<AttendDO> select_byTime(Date startTime, Date endTime) { Map<String, Date> timeMap = new HashMap<String, Date>(); timeMap.put("startTime", startTime); timeMap.put("endTime", endTime); List<AttendDO> result = getSqlMapClientTemplate().queryForList("select_attend_time", timeMap); return result; } @Override public List<AttendDO> select_byUser(String username, Date startTime, Date endTime) { return null; } @Override public List<List<AttendDO>> select_ALLUser(Date startTime, Date endTime) { return null; } }
@RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(value="classpath:applicationContext.xml") public class AttendDAOTest { @Resource private AttendDaoImpl attendDaoImpl; @Test public void selectTest() throws ParseException { SimpleDateFormat sim=new SimpleDateFormat("yyyy-MM-dd"); Date startTime = sim.parse("2016-09-12"); Date endTime = sim.parse("2016-09-17"); List<AttendDO> list = attendDaoImpl.select_byTime(startTime, endTime); for(int i = 0; i<list.size();i++) { System.out.println(list.get(i).getUsername() + " " +list.get(i).getAttendTime() + " " +list.get(i).getType()); } } }
原文:http://www.cnblogs.com/kingatnuaa/p/6200522.html