spring3 jdbctemplate 注解实例

简介:
[java]  view plain  copy
 
  1. <aop:aspectj-autoproxy />  
  2.   
  3.     <!-- transaction manager, use JtaTransactionManager for global tx -->  
  4.     <bean id="txManager"  
  5.         class="org.springframework.jdbc.datasource.DataSourceTransactionManager">  
  6.         <property name="dataSource" ref="dynamicDataSource" />  
  7.     </bean>  
  8.   
  9.     <!--  
  10.         enable component scanning (beware that this does not enable mapper  
  11.         scanning!)  
  12.     -->  
  13.     <context:component-scan base-package="com.shadow" />  
  14.   
  15.     <!-- enable autowire -->  
  16.     <context:annotation-config />  
  17.   
  18.     <!-- enable transaction demarcation with annotations -->  
  19.     <tx:annotation-driven transaction-manager="txManager" />  

第三步,配置jdbctemplate的实例,同样提供一个datasource就可以了

 

 

[java]  view plain  copy
 
  1. <!-- JDBC模板 -->  
  2.     <bean id="jdbcTemplate"  
  3.         class="org.springframework.jdbc.core.JdbcTemplate">  
  4.         <property name="dataSource" ref="dynamicDataSource" />  
  5.     </bean>  

第四步,写个BaseDao方便下面的dao层调用,由于时间转换经常用到,这里只写了个通用的时间转换

 

 

[java]  view plain  copy
 
  1. /** 
  2.  *  
  3.  * @author shadow 
  4.  * @email 124010356@qq.com 
  5.  * @create 2012.04.28 
  6.  *  
  7.  * @param <T> 
  8.  */  
  9. public abstract class AbstractBaseDao<T> implements DateFormatEntry {  
  10.   
  11.     // SPRING JDBC模板接口  
  12.     private JdbcTemplate jdbcTemplate;  
  13.   
  14.     public JdbcTemplate getJdbcTemplate() {  
  15.         return jdbcTemplate;  
  16.     }  
  17.   
  18.     @Resource  
  19.     public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {  
  20.         this.jdbcTemplate = jdbcTemplate;  
  21.     }  
  22.   
  23.     /** 
  24.      * 获取日期 
  25.      *  
  26.      * @param timestamp 
  27.      * @return Date 
  28.      */  
  29.     public Date getDate(Timestamp timestamp) {  
  30.         return toDate(timestamp, null);  
  31.     }  
  32.   
  33.     /** 
  34.      * 获取日期 
  35.      *  
  36.      * @param timestamp 
  37.      * @param format 
  38.      * @return Date 
  39.      */  
  40.     public Date getDate(Timestamp timestamp, String format) {  
  41.         return toDate(timestamp, format);  
  42.     }  
  43.   
  44.     /** 
  45.      * Timestamp按格式转换成Date 
  46.      *  
  47.      * @param timestamp 
  48.      * @param format 
  49.      * @return Date 
  50.      */  
  51.     public Date toDate(Timestamp timestamp, String format) {  
  52.         Date date = null;  
  53.         if (null == format || "".equals(format))  
  54.             format = DEFAULT_FORMAT;  
  55.         SimpleDateFormat sdf = new SimpleDateFormat(format);  
  56.         try {  
  57.             date = sdf.parse(sdf.format(timestamp));  
  58.         } catch (ParseException e) {  
  59.             e.printStackTrace();  
  60.         }  
  61.         return date;  
  62.     }  
  63.   
  64. }  

第五步,写个UserDao接口跟实现类

 

 

[java]  view plain  copy
 
  1. public interface UserDao {  
  2.   
  3.     public List<User> queryByUserName(String username);  
  4.   
  5.     public int checkUser(String username);  
  6.       
  7.     public List<User> queryForAll();  
  8.       
  9. }  

 

这里使用@Component("userDao"),相当于在xml配置里做一个<bean id="userDao" class="xxxxxx.UserDaoImpl"/>,然后我们在service调用就直接Resource("userDao")就能自动匹配这个实现类了

[java]  view plain  copy
 
  1. @Component("userDao")  
  2. public class UserDaoImpl extends AbstractBaseDao<User> implements UserDao {  
  3.   
  4.     public int checkUser(String username) {  
  5.         // TODO Auto-generated method stub  
  6.         return 0;  
  7.     }  
  8.   
  9.     @SuppressWarnings("unchecked")  
  10.     public List<User> queryByUserName(String username) {  
  11.         String sql = "select t1.* from t_user t1 where t1.username = ?";  
  12.         List<User> list = this.getJdbcTemplate().query(sql,  
  13.                 new Object[] { username }, new UserMapper());  
  14.         return list;  
  15.     }  
  16.   
  17.     public List<User> queryForAll() {  
  18.         SqlRowSet rowSet = getJdbcTemplate().queryForRowSet(null);  
  19.         while (rowSet.next()) {  
  20.         }  
  21.         return null;  
  22.     }  
  23.   
  24.     @SuppressWarnings("unchecked")  
  25.     private class UserMapper implements RowMapper {  
  26.         public Object mapRow(ResultSet rs, int i) throws SQLException {  
  27.             User vo = new User();  
  28.             vo.setId(rs.getInt("id"));  
  29.             vo.setUsername(rs.getString("username"));  
  30.             vo.setPassword(rs.getString("password"));  
  31.             vo.setName(rs.getString("name"));  
  32.             return vo;  
  33.         }  
  34.     }  
  35.   
  36. }  

第六步,写service层调用dao的方法

 

 

[java]  view plain  copy
 
  1. public interface UserService {  
  2.   
  3.     /** 
  4.      * 更新登录信息 
  5.      *  
  6.      * @param user 
  7.      */  
  8.     public void LoginForUpdate(User user);  
  9.   
  10.     /** 
  11.      * 安全退出功能 
  12.      *  
  13.      * @return String 
  14.      */  
  15.     public String logout();  
  16.   
  17.     /** 
  18.      * 检测用户是否存在 
  19.      *  
  20.      * @param username 
  21.      * @return Boolean 
  22.      */  
  23.     public boolean checkUser(String username);  
  24.   
  25.     /** 
  26.      * 通过用户名获取账号 
  27.      *  
  28.      * @param username 
  29.      * @return List<User> 
  30.      */  
  31.     public List<User> findByUserName(String username);  

 

这里使用了的@Resource没有带参数就是默认使用接口类名首字母小写(例如接口是UserDao,默认匹配是userDao),@Transactional是事务的注解,可加各种参数设置,

具体请看帮助文档

[java]  view plain  copy
 
  1. @Transactional  
  2. @Component("userService")  
  3. public class UserServiceImpl implements UserService {  
  4.   
  5.     @Resource  
  6.     private UserDao userDao;  
  7.   
  8.     public void LoginForUpdate(User user) {  
  9.         // TODO Auto-generated method stub  
  10.     }  
  11.   
  12.     public boolean checkUser(String username) {  
  13.         // TODO Auto-generated method stub  
  14.         return false;  
  15.     }  
  16.   
  17.     public List<User> findByUserName(String username) {  
  18.         return this.userDao.queryByUserName(username);  
  19.     }  
  20.   
  21.     public String logout() {  
  22.         // TODO Auto-generated method stub  
  23.         return null;  
  24.     }  
  25.   
  26. }  

第七步,写junit测试

 

 

[java]  view plain  copy
 
  1. @RunWith(SpringJUnit4ClassRunner.class)  
  2. @ContextConfiguration("classpath:application.xml")  
  3. public class Junit {  
  4.   
  5.     @Resource  
  6.     private UserService userService;  
  7.   
  8.     @Test  
  9.     public void test() {  
  10.         for (int i = 0; i < 10; i++) {  
  11.             List<User> users = userService.findByUserName("3213231");  
  12.             System.out.println("当前用户数:" + users.size());  
  13.         }  
  14.     }  
  15.   
  16. }  

最后右键run as junit就ok了

 

 

附言,其实spring jdbctemplate是很灵活的,性能也很不错,你能使用queryForXX一类的方法返回map,也能返回原始ResultSet,当然也能使用回调接口映射成对象,我的例子里就是演示了如何把结果集映射成实体对象

 

相关文章
|
12天前
|
XML Java 数据格式
SpringBoot入门(8) - 开发中还有哪些常用注解
SpringBoot入门(8) - 开发中还有哪些常用注解
30 0
|
30天前
|
Java Spring
在使用Spring的`@Value`注解注入属性值时,有一些特殊字符需要注意
【10月更文挑战第9天】在使用Spring的`@Value`注解注入属性值时,需注意一些特殊字符的正确处理方法,包括空格、引号、反斜杠、新行、制表符、逗号、大括号、$、百分号及其他特殊字符。通过适当包裹或转义,确保这些字符能被正确解析和注入。
|
19天前
|
XML JSON Java
SpringBoot必须掌握的常用注解!
SpringBoot必须掌握的常用注解!
42 4
SpringBoot必须掌握的常用注解!
|
21天前
|
存储 缓存 Java
Spring缓存注解【@Cacheable、@CachePut、@CacheEvict、@Caching、@CacheConfig】使用及注意事项
Spring缓存注解【@Cacheable、@CachePut、@CacheEvict、@Caching、@CacheConfig】使用及注意事项
68 2
|
21天前
|
JSON Java 数据库
SpringBoot项目使用AOP及自定义注解保存操作日志
SpringBoot项目使用AOP及自定义注解保存操作日志
34 1
|
1月前
|
架构师 Java 开发者
得物面试:Springboot自动装配机制是什么?如何控制一个bean 是否加载,使用什么注解?
在40岁老架构师尼恩的读者交流群中,近期多位读者成功获得了知名互联网企业的面试机会,如得物、阿里、滴滴等。然而,面对“Spring Boot自动装配机制”等核心面试题,部分读者因准备不足而未能顺利通过。为此,尼恩团队将系统化梳理和总结这一主题,帮助大家全面提升技术水平,让面试官“爱到不能自已”。
得物面试:Springboot自动装配机制是什么?如何控制一个bean 是否加载,使用什么注解?
|
15天前
|
存储 安全 Java
springboot当中ConfigurationProperties注解作用跟数据库存入有啥区别
`@ConfigurationProperties`注解和数据库存储配置信息各有优劣,适用于不同的应用场景。`@ConfigurationProperties`提供了类型安全和模块化的配置管理方式,适合静态和简单配置。而数据库存储配置信息提供了动态更新和集中管理的能力,适合需要频繁变化和集中管理的配置需求。在实际项目中,可以根据具体需求选择合适的配置管理方式,或者结合使用这两种方式,实现灵活高效的配置管理。
12 0
|
1月前
|
XML Java 数据库
Spring boot的最全注解
Spring boot的最全注解
|
28天前
|
存储 Java 数据管理
强大!用 @Audited 注解增强 Spring Boot 应用,打造健壮的数据审计功能
本文深入介绍了如何在Spring Boot应用中使用`@Audited`注解和`spring-data-envers`实现数据审计功能,涵盖从添加依赖、配置实体类到查询审计数据的具体步骤,助力开发人员构建更加透明、合规的应用系统。
|
1月前
|
XML Java 数据格式
手动开发-简单的Spring基于注解配置的程序--源码解析
手动开发-简单的Spring基于注解配置的程序--源码解析
47 0
下一篇
无影云桌面