第二步,配置注解扫描,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,当然也能使用回调接口映射成对象,我的例子里就是演示了如何把结果集映射成实体对象
相关推荐
在这个实例工程中,我们将深入探讨Spring JdbcTemplate的基本使用、优势以及常见操作。 一、Spring JdbcTemplate简介 Spring JdbcTemplate的出现是为了弥补原生JDBC在编码上的繁琐,它通过模板方法模式,将SQL执行...
在本实例中,我们将深入探讨Spring JdbcTemplate的查询功能及其在实际应用中的使用。 首先,Spring JdbcTemplate通过提供一系列的模板方法,如`queryForList`、`queryForObject`、`execute`等,使得执行SQL查询变得...
这通常在Spring配置文件中完成,通过`@Bean`注解创建一个JdbcTemplate实例,并将DataSource注入其中。 ```xml <!-- 配置数据库连接参数 --> <bean id="jdbcTemplate" class="org.springframework.jdbc.core....
在本示例中,我们探讨的是一个基于Spring MVC和JdbcTemplate的非注解式应用程序,该程序可能用于处理数据访问层的操作。Spring MVC是Spring框架的一部分,它专注于Web应用程序的模型-视图-控制器(MVC)架构。而...
Spring MVC通过`@Autowired`注解自动注入JdbcTemplate实例。例如: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.jdbc.core.JdbcTemplate; import org....
在配置方面,Spring的XML配置文件会定义Bean的实例化和依赖关系,包括Struts2的Action、Spring的Service和DAO等。同时,Spring还可以配置事务管理策略,确保数据库操作的一致性。例如,在登录失败(如密码错误)时,...
2. **创建 JdbcTemplate 实例**:通过 `new JdbcTemplate(dataSource)` 初始化。 3. **编写 SQL 语句**:可以是静态 SQL,也可以是动态 SQL(如:`NamedParameterJdbcTemplate`)。 4. **调用 JdbcTemplate 方法**:...
此外,可能还有对JdbcTemplate实例的配置,通过@Bean注解将其注入到Spring容器中。 "entity"目录下存放的是数据模型类,即数据库表对应的实体类。这些类通常使用JavaBeans模式,包含属性(字段)和getter/setter...
Spring MVC可以通过`@Autowired`注解注入DataSource和JdbcTemplate,或者使用Hibernate、MyBatis的Session工厂,来实现与数据库的交互。CRUD操作通常对应于这些框架的save、read、update、delete方法。 5. **SQL...
这是通过`@Resource`注解实现的,它告诉Spring容器将名称为`jdbcTemplate`的bean注入到这个字段中。 在`BaseDaoImpl` 类中,`find` 方法的实现使用了`JdbcTemplate`的`query`方法。这个方法可以接受SQL语句、参数...
使用Spring JdbcTemplate的第一步是创建一个JdbcTemplate实例。这通常通过Spring的IoC容器(依赖注入)完成,将DataSource配置到JdbcTemplate中。例如: ```java @Autowired private DataSource dataSource; @Bean...
3. `spring-jdbc-5.0.0.RELEASE.jar`:包含Spring对JDBC的支持,包括JDBCTemplate和DataSourceTransactionManager,它们是与数据库交互和管理事务的关键。 4. `spring-tx-5.0.0.RELEASE.jar`:提供了事务管理功能,...
5. 使用JdbcTemplate:在业务层,通过@Autowired注解注入对应的数据源的`JdbcTemplate`实例,然后进行数据库操作。例如: ```java @Service public class UserService { @Autowired @Qualifier(...
在获取到DataSource后,可以创建并初始化JdbcTemplate实例: ```java @Autowired private DataSource dataSource; @Bean public JdbcTemplate jdbcTemplate() { return new JdbcTemplate(dataSource); } ``` ###...
在上述代码中,`@Autowired`注解使得Spring自动将`ApplicationContext`注入到服务方法中,然后我们可以通过`getBean`获取到`JdbcTemplate`实例,执行数据库查询。 总结来说,Spring的`getBean`方法是DI机制的关键,...
在本项目"基于注解方式的spring_mvc_jdbcTemplate"中,我们将深入探讨如何利用注解驱动的Spring MVC和JdbcTemplate进行开发。 首先,让我们了解Spring MVC的核心组件: 1. **DispatcherServlet**:作为Spring MVC...
- **配置JdbcTemplate**:在Spring配置文件中声明一个JdbcTemplate实例,并注入数据源。 - **执行SQL查询**:使用`query(String sql, RowMapper<T> rowMapper)`方法执行SQL查询,`RowMapper`接口用于将结果集中的...
1.针对SpringMVC注解的配置...2.Spring+JdbcTemplate事物管理 3.Spring+Hibernate事物管理 4.Spring实现DWR注解方式的应用配置 5.Spring配置拦截器 6.Spring通过拦截器实现防止重复提交实例 对学习,会起到非常好的效果
- **使用**:通过@Autowired注解注入JdbcTemplate实例,然后调用其提供的方法进行CRUD操作,如`update()`, `query()`, `insert()`等。 - **事务管理**:JdbcTemplate支持声明式事务管理,可以通过@Transactional...
Spring可以方便地与JdbcTemplate集成,通过@Autowired注解,Spring可以自动注入JdbcTemplate实例,简化数据库访问代码。同时,Spring的事务管理同样适用于JdbcTemplate,确保了数据库操作的一致性。 在实际项目中,...