spring3 jdbctemplate 注解实例

简介: 本文章摘编、转载需要注明来源 http://blog.csdn.net/shadowsick/article/details/8888187 网上这spring jdbcte...

本文章摘编、转载需要注明来源 http://blog.csdn.net/shadowsick/article/details/8888187


网上这spring jdbctemplate的例子多如牛毛,我下面也继续再造一次轮子


第一步,先引入需要的包,这里不作详细说明


第二步,配置注解扫描,txManager是事务管理提供datasource就可以了

<aop:aspectj-autoproxy />

	<!-- transaction manager, use JtaTransactionManager for global tx -->
	<bean id="txManager"
		class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
		<property name="dataSource" ref="dynamicDataSource" />
	</bean>

	<!--
		enable component scanning (beware that this does not enable mapper
		scanning!)
	-->
	<context:component-scan base-package="com.shadow" />

	<!-- enable autowire -->
	<context:annotation-config />

	<!-- enable transaction demarcation with annotations -->
	<tx:annotation-driven transaction-manager="txManager" />

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

<!-- JDBC模板 -->
	<bean id="jdbcTemplate"
		class="org.springframework.jdbc.core.JdbcTemplate">
		<property name="dataSource" ref="dynamicDataSource" />
	</bean>

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

/**
 * 
 * @author shadow
 * @email 124010356@qq.com
 * @create 2012.04.28
 * 
 * @param <T>
 */
public abstract class AbstractBaseDao<T> implements DateFormatEntry {

	// SPRING JDBC模板接口
	private JdbcTemplate jdbcTemplate;

	public JdbcTemplate getJdbcTemplate() {
		return jdbcTemplate;
	}

	@Resource
	public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
		this.jdbcTemplate = jdbcTemplate;
	}

	/**
	 * 获取日期
	 * 
	 * @param timestamp
	 * @return Date
	 */
	public Date getDate(Timestamp timestamp) {
		return toDate(timestamp, null);
	}

	/**
	 * 获取日期
	 * 
	 * @param timestamp
	 * @param format
	 * @return Date
	 */
	public Date getDate(Timestamp timestamp, String format) {
		return toDate(timestamp, format);
	}

	/**
	 * Timestamp按格式转换成Date
	 * 
	 * @param timestamp
	 * @param format
	 * @return Date
	 */
	public Date toDate(Timestamp timestamp, String format) {
		Date date = null;
		if (null == format || "".equals(format))
			format = DEFAULT_FORMAT;
		SimpleDateFormat sdf = new SimpleDateFormat(format);
		try {
			date = sdf.parse(sdf.format(timestamp));
		} catch (ParseException e) {
			e.printStackTrace();
		}
		return date;
	}

}

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

public interface UserDao {

	public List<User> queryByUserName(String username);

	public int checkUser(String username);
	
	public List<User> queryForAll();
	
}

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

@Component("userDao")
public class UserDaoImpl extends AbstractBaseDao<User> implements UserDao {

	public int checkUser(String username) {
		// TODO Auto-generated method stub
		return 0;
	}

	@SuppressWarnings("unchecked")
	public List<User> queryByUserName(String username) {
		String sql = "select t1.* from t_user t1 where t1.username = ?";
		List<User> list = this.getJdbcTemplate().query(sql,
				new Object[] { username }, new UserMapper());
		return list;
	}

	public List<User> queryForAll() {
		SqlRowSet rowSet = getJdbcTemplate().queryForRowSet(null);
		while (rowSet.next()) {
		}
		return null;
	}

	@SuppressWarnings("unchecked")
	private class UserMapper implements RowMapper {
		public Object mapRow(ResultSet rs, int i) throws SQLException {
			User vo = new User();
			vo.setId(rs.getInt("id"));
			vo.setUsername(rs.getString("username"));
			vo.setPassword(rs.getString("password"));
			vo.setName(rs.getString("name"));
			return vo;
		}
	}

}

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

public interface UserService {

	/**
	 * 更新登录信息
	 * 
	 * @param user
	 */
	public void LoginForUpdate(User user);

	/**
	 * 安全退出功能
	 * 
	 * @return String
	 */
	public String logout();

	/**
	 * 检测用户是否存在
	 * 
	 * @param username
	 * @return Boolean
	 */
	public boolean checkUser(String username);

	/**
	 * 通过用户名获取账号
	 * 
	 * @param username
	 * @return List<User>
	 */
	public List<User> findByUserName(String username);

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

具体请看帮助文档

@Transactional
@Component("userService")
public class UserServiceImpl implements UserService {

	@Resource
	private UserDao userDao;

	public void LoginForUpdate(User user) {
		// TODO Auto-generated method stub
	}

	public boolean checkUser(String username) {
		// TODO Auto-generated method stub
		return false;
	}

	public List<User> findByUserName(String username) {
		return this.userDao.queryByUserName(username);
	}

	public String logout() {
		// TODO Auto-generated method stub
		return null;
	}

}

第七步,写junit测试

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:application.xml")
public class Junit {

	@Resource
	private UserService userService;

	@Test
	public void test() {
		for (int i = 0; i < 10; i++) {
			List<User> users = userService.findByUserName("3213231");
			System.out.println("当前用户数:" + users.size());
		}
	}

}

最后右键run as junit就ok了


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



目录
相关文章
|
26天前
|
监控 Java Spring
SpringBoot:SpringBoot通过注解监测Controller接口
本文详细介绍了如何通过Spring Boot注解监测Controller接口,包括自定义注解、AOP切面的创建和使用以及具体的示例代码。通过这种方式,可以方便地在Controller方法执行前后添加日志记录、性能监控和异常处理逻辑,而无需修改方法本身的代码。这种方法不仅提高了代码的可维护性,还增强了系统的监控能力。希望本文能帮助您更好地理解和应用Spring Boot中的注解监测技术。
62 16
|
1月前
|
XML Java 测试技术
Spring IOC—基于注解配置和管理Bean 万字详解(通俗易懂)
Spring 第三节 IOC——基于注解配置和管理Bean 万字详解!
129 26
|
2月前
|
缓存 Java 数据库
SpringBoot缓存注解使用
Spring Boot 提供了一套方便的缓存注解,用于简化缓存管理。通过 `@Cacheable`、`@CachePut`、`@CacheEvict` 和 `@Caching` 等注解,开发者可以轻松地实现方法级别的缓存操作,从而提升应用的性能和响应速度。合理使用这些注解可以大大减少数据库的访问频率,优化系统性能。
202 89
|
3月前
|
Java Spring 容器
【SpringFramework】Spring IoC-基于注解的实现
本文主要记录基于Spring注解实现IoC容器和DI相关知识。
69 21
|
3月前
|
Java Spring
【Spring】方法注解@Bean,配置类扫描路径
@Bean方法注解,如何在同一个类下面定义多个Bean对象,配置扫描路径
187 73
|
3月前
|
存储 Java Spring
【Spring】获取Bean对象需要哪些注解
@Conntroller,@Service,@Repository,@Component,@Configuration,关于Bean对象的五个常用注解
|
3月前
|
Java Spring
【Spring配置】idea编码格式导致注解汉字无法保存
问题一:对于同一个项目,我们在使用idea的过程中,使用汉字注解完后,再打开该项目,汉字变成乱码问题二:本来a项目中,汉字注解调试好了,没有乱码了,但是创建出来的新的项目,写的注解又成乱码了。
|
4月前
|
前端开发 Java 开发者
Spring MVC中的请求映射:@RequestMapping注解深度解析
在Spring MVC框架中,`@RequestMapping`注解是实现请求映射的关键,它将HTTP请求映射到相应的处理器方法上。本文将深入探讨`@RequestMapping`注解的工作原理、使用方法以及最佳实践,为开发者提供一份详尽的技术干货。
287 2
|
4月前
|
前端开发 Java Spring
探索Spring MVC:@Controller注解的全面解析
在Spring MVC框架中,`@Controller`注解是构建Web应用程序的基石之一。它不仅简化了控制器的定义,还提供了一种优雅的方式来处理HTTP请求。本文将全面解析`@Controller`注解,包括其定义、用法、以及在Spring MVC中的作用。
97 2
|
4月前
|
前端开发 Java 开发者
Spring MVC中的控制器:@Controller注解全解析
在Spring MVC框架中,`@Controller`注解是构建Web应用程序控制层的核心。它不仅简化了控制器的定义,还提供了灵活的请求映射和处理机制。本文将深入探讨`@Controller`注解的用法、特点以及在实际开发中的应用。
191 0

热门文章

最新文章