Spring + JdbcTemplate + JdbcDaoSupport

点击打开链接

首先,数据库是这样的,很简单。


当然,要引入spring的包,这里我全部导入了,省事。


applicationContext.xml是这样的:

[html]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <beans xmlns="http://www.springframework.org/schema/beans"  
  3.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  4.     xsi:schemaLocation="  
  5.     http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd">  
  6.   
  7.     <bean id="test" class="jdbc.Test">  
  8.     <property name="dataSource" ref="dataSource"></property>  
  9.     </bean>  
  10.   
  11.     <bean id="dataSource"  
  12.         class="org.springframework.jdbc.datasource.DriverManagerDataSource">  
  13.         <property name="driverClassName" value="com.mysql.jdbc.Driver" />  
  14.         <property name="url" value="jdbc:mysql://localhost:3306/testspring" />  
  15.         <property name="username" value="root" />  
  16.         <property name="password" value="" />  
  17.     </bean>  
  18.   
  19. </beans>  

User.java是这样的:

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. package jdbc;  
  2.   
  3. public class User {  
  4.     private int id;  
  5.     private String name;  
  6.     private String password;  
  7.       
  8.     public int getId() {  
  9.         return id;  
  10.     }  
  11.     public void setId(int id) {  
  12.         this.id = id;  
  13.     }  
  14.     public String getName() {  
  15.         return name;  
  16.     }  
  17.     public void setName(String name) {  
  18.         this.name = name;  
  19.     }  
  20.     public String getPassword() {  
  21.         return password;  
  22.     }  
  23.     public void setPassword(String password) {  
  24.         this.password = password;  
  25.     }  
  26.       
  27. }  

下面来对比一下三种写法:

1、spring

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. package jdbc;  
  2.   
  3. import java.sql.Connection;  
  4. import java.sql.PreparedStatement;  
  5. import java.sql.SQLException;  
  6.   
  7. import javax.sql.DataSource;  
  8.   
  9. import org.springframework.context.ApplicationContext;  
  10. import org.springframework.context.support.ClassPathXmlApplicationContext;  
  11.   
  12. public class Test {  
  13.     private DataSource dataSource;  
  14.   
  15.     public void setDataSource(DataSource dataSource) {  
  16.         this.dataSource = dataSource;  
  17.     }  
  18.   
  19.     public void insert(User u) {  
  20.         String sql = "insert into _user " + "values(null, ?, ?)";//普通的sql语句  
  21.         Connection conn = null;  
  22.   
  23.         try {  
  24.             conn = dataSource.getConnection();  
  25.             PreparedStatement ps = conn.prepareStatement(sql);  
  26.             ps.setString(1, u.getName());  
  27.             ps.setString(2, u.getPassword());  
  28.             ps.executeUpdate();  
  29.             ps.close();  
  30.         } catch (SQLException e) {  
  31.             throw new RuntimeException(e);  
  32.         } finally {  
  33.             if (conn != null) {  
  34.                 try {  
  35.                     conn.close();  
  36.                 } catch (SQLException e) {  
  37.                 }  
  38.             }  
  39.         }  
  40.     }  
  41.   
  42.     public static void main(String[] args) {  
  43.         ApplicationContext ctx = new ClassPathXmlApplicationContext(  
  44.                 "applicationContext.xml");  
  45.         Test t = (Test) ctx.getBean("test");  
  46.           
  47.         User u = new User();  
  48.         u.setName("dd");  
  49.         u.setPassword("dd");  
  50.         t.insert(u);  
  51.     }  
  52. }  
运行结果是这样的:


2、JdbcTemplate 

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. package jdbc;  
  2.   
  3. import java.sql.Connection;  
  4. import java.sql.PreparedStatement;  
  5. import java.sql.SQLException;  
  6.   
  7. import javax.sql.DataSource;  
  8.   
  9. import org.springframework.context.ApplicationContext;  
  10. import org.springframework.context.support.ClassPathXmlApplicationContext;  
  11. import org.springframework.jdbc.core.JdbcTemplate;  
  12.   
  13. public class Test {  
  14.     private DataSource dataSource;  
  15.   
  16.     public void setDataSource(DataSource dataSource) {  
  17.         this.dataSource = dataSource;  
  18.     }  
  19.   
  20.     public void insert(User u) {  
  21.         String sql = "insert into _user " + "values(null, ?, ?)";//普通的sql语句  
  22.         JdbcTemplate template = new JdbcTemplate(dataSource);  
  23.         template.update(sql, new Object[]{u.getName(), u.getPassword()});  
  24.     }  
  25.   
  26.     public static void main(String[] args) {  
  27.         ApplicationContext ctx = new ClassPathXmlApplicationContext(  
  28.                 "applicationContext.xml");  
  29.         Test t = (Test) ctx.getBean("test");  
  30.           
  31.         User u = new User();  
  32.         u.setName("dd");  
  33.         u.setPassword("dd");  
  34.         t.insert(u);  
  35.     }  
  36. }  
可以看得出简单了很多,不用Connection了。

3、JdbcDaoSupport

这个更简单,不用new JdbcTemplate了。

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. package jdbc;  
  2.   
  3. import org.springframework.context.ApplicationContext;  
  4. import org.springframework.context.support.ClassPathXmlApplicationContext;  
  5. import org.springframework.jdbc.core.support.JdbcDaoSupport;  
  6.   
  7. public class Test extends JdbcDaoSupport {  
  8.     //JdbcDaoSupport类已经有了public final void setDataSource(DataSource dataSource)了  
  9.     //不用重写也不能重写  
  10.       
  11.     public void insert(User u) {  
  12.         String sql = "insert into _user " + "values(null, ?, ?)";//普通的sql语句  
  13.         this.getJdbcTemplate().update(sql, new Object[]{u.getName(), u.getPassword()});  
  14.     }  
  15.   
  16.     public static void main(String[] args) {  
  17.         ApplicationContext ctx = new ClassPathXmlApplicationContext(  
  18.                 "applicationContext.xml");  
  19.         Test t = (Test) ctx.getBean("test");  
  20.           
  21.         User u = new User();  
  22.         u.setName("dd");  
  23.         u.setPassword("dd");  
  24.         t.insert(u);  
  25.     }  
  26. }  
三种方法哪一种更简单一目了然。

我参考的文章:Spring + JdbcTemplate + JdbcDaoSupport Examples


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好!对于SpringMVC和JdbcTemplate的整合,可以通过以下步骤进行查询和删除操作: 1. 配置数据源和JdbcTemplate 首先,在Spring的配置文件中配置数据源和JdbcTemplate。您可以使用Spring的内置数据源,如`BasicDataSource`或`HikariDataSource`,并为其提供数据库连接信息。然后,将数据源注入到JdbcTemplate中。 2. 创建DAO层接口和实现类 在DAO(数据访问对象)层中,创建一个接口来定义查询和删除操作的方法。您可以使用JdbcTemplate提供的方法来执行SQL查询和删除语句。然后,在实现类中实现这些方法。 例如,创建一个名为`UserDAO`的接口,定义查询和删除方法: ```java public interface UserDAO { List<User> getAllUsers(); void deleteUser(int userId); } ``` 然后,创建一个名为`UserDAOImpl`的实现类: ```java public class UserDAOImpl implements UserDAO { private JdbcTemplate jdbcTemplate; public UserDAOImpl(JdbcTemplate jdbcTemplate) { this.jdbcTemplate = jdbcTemplate; } public List<User> getAllUsers() { String sql = "SELECT * FROM users"; List<User> users = jdbcTemplate.query(sql, new BeanPropertyRowMapper<>(User.class)); return users; } public void deleteUser(int userId) { String sql = "DELETE FROM users WHERE id = ?"; jdbcTemplate.update(sql, userId); } } ``` 3. 创建Service层 接下来,在Service层中使用DAO层的实现类来提供业务逻辑。创建一个名为`UserService`的接口,并在实现类中注入`UserDAO`。 ```java public interface UserService { List<User> getAllUsers(); void deleteUser(int userId); } ``` ```java public class UserServiceImpl implements UserService { private UserDAO userDAO; public UserServiceImpl(UserDAO userDAO) { this.userDAO = userDAO; } public List<User> getAllUsers() { return userDAO.getAllUsers(); } public void deleteUser(int userId) { userDAO.deleteUser(userId); } } ``` 4. 创建Controller层 最后,在Controller层中使用Service层的实现类来处理HTTP请求。创建一个名为`UserController`的类,并在其中注入`UserService`。 ```java @Controller @RequestMapping("/users") public class UserController { private UserService userService; public UserController(UserService userService) { this.userService = userService; } @GetMapping public String getAllUsers(Model model) { List<User> users = userService.getAllUsers(); model.addAttribute("users", users); return "users"; } @PostMapping("/{id}/delete") public String deleteUser(@PathVariable("id") int userId) { userService.deleteUser(userId); return "redirect:/users"; } } ``` 在上述示例中,`getAllUsers`方法用于获取所有用户,并将其添加到Model中以供视图渲染。`deleteUser`方法用于删除指定ID的用户,并通过重定向返回到用户列页面。 这样,您就可以使用SpringMVC和JdbcTemplate进行查询和删除操作了。当然,您还可以根据具体需求进行扩展和优化。希望对您有所帮助!如有任何问题,请随提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值