一,場景:編寫一個用戶管理的服務層,包括增加用戶、刪除用戶和查詢用戶等等,而且用戶信息以關系型數據庫形式存儲。
分析:
這是一個典型的應用服務,涉及到業務層(business objects layer)、數據庫訪問層(db access)和存儲層(eis)。
采用典型的架構:bo+dao
dao采用spring提供的jdbctemplate來進行封裝。
二,具體實現
1)用戶類user
public class user{
private string username;
private string email;
private date birthday;
public user(){}
…
相應的setter/getter方法。
}
這是一個簡單的bean類,記錄用戶的信息。
2)數據庫訪問類:userdao
public interface userdao {
public void save(user user);
public void remove(string username);
public user searchbyname(string username);
}
這是數據庫訪問的接口類,定義了對用戶的數據庫操作,其實現類是userdaojdbc
userdaojdbc類
public class userdaojdbc extends jdbcdaosupport implements userdao {
public userdaojdbc() {
super();
}
public void save(user user) {
getjdbctemplate().update(
"insert into sample_user values (?,?,?)",
new object[] { user.getusername(), user.getemail(),
user.getbirthday() });
}
...
}
3)業務類usermanageservice
public interface usermanageservice {
public void saveuser(user user);
public void removeuser(string username);
public user getuserbyname(string username);
}
這是用戶的業務類接口,定義了和用戶相關的一些業務操作,其實現類usermanageserviceimpl
實現類usermanageserviceimpl
public class usermanageserviceimpl implements usermanageservice {
private userdao udao;
public usermanageserviceimpl() {
super();
}
public void saveuser(user user) {
udao.save(user);
}
public userdao getudao() {
return udao;
}
public void setudao(userdao udao) {
this.udao = udao;
}
}
4)spring bean描述文件配置
<beans>
<bean id="datasource" class="org.springframework.jdbc.datasource.drivermanagerdatasource">
<property name="driverclassname">
<value>oracle.jdbc.driver.oracledriver</value>
</property>
<property name="url">
<value>jdbc:oracle:thin:@172.16.4.219:1521:orcl</value>
</property>
<property name="username">
<value>zhangbo</value>
</property>
<property name="password">
<value>password</value>
</property>
</bean>
<bean id="transactionmanager" class="org.springframework.jdbc.datasource.datasourcetransactionmanager">
<property name="datasource">
<ref bean="datasource"/>
</property>
</bean>
<bean id="userdao" class="sample.spring.dao.userdaojdbc">
<property name="datasource">
<ref bean="datasource"/>
</property>
</bean>
<bean id="usermanageservice" class="sample.spring.service.usermanageserviceimpl">
<property name="udao">
<ref bean="userdao"/>
</property>
</bean>
</beans>
5)數據中存儲用戶的表sample_user
username varchar2(30) not null,
email varchar2(50) not null,
birthday date
6)通過單元測試來驗證usermanageservice中的操作:
public class usermanageservicetest extends testcase {
private usermanageservice service;
private static log logger = logfactory.getlog(usermanageservicetest.class);
protected void setup() throws exception {
super.setup();
service = (usermanageservice) springcontextutil
.getbean("usermanageservice");
}
public void testsaveandsearchandremoveuser() throws exception {
user user = new user();
user.setusername("zhangsan");
user.setemail("[email protected]");
user.setbirthday(new date());
service.saveuser(user);
logger.debug("存入一個新用戶:" + user);
user userfromdb = service.getuserbyname("zhangsan");
assertnotnull(userfromdb);
assertequals(userfromdb.getemail(), "[email protected]");
logger.debug("從數據庫中查到用戶:" + userfromdb);
service.removeuser("zhangsan");
logger.debug("從數據庫刪除用戶:" + userfromdb);
}
protected void teardown() throws exception {
super.teardown();
}
}
新聞熱點
疑難解答