你的位置:首页 > 软件开发 > Java > Spring框架针对dao层的jdbcTemplate操作crud之query查询数据操作

Spring框架针对dao层的jdbcTemplate操作crud之query查询数据操作

发布时间:2017-11-28 03:00:04
查询目标是完成3个功能:(1)查询表,返回某一个值。例如查询表中记录的条数,返回一个int类型数据(2)查询表,返回结果为某一个对象。(3)查询表,返回结果为某一个泛型的list集合。一、查询表中记录的条数,返回一个int类型数据的操作方法使用jdbcTemplate原理是把加载 ...

查询目标是完成3个功能:

(1)查询表,返回某一个值。例如查询表中记录的条数,返回一个int类型数据

(2)查询表,返回结果为某一个对象。

(3)查询表,返回结果为某一个泛型的list集合。

一、查询表中记录的条数,返回一个int类型数据的操作方法

使用jdbcTemplate

原理是把加载驱动Class.forName("com.mysql.jdbc.Driver");

和连接数据库Connection conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/sw_database?user=root&password=root");

用一个对象完成DriverManagerDataSource dataSource=new DriverManagerDataSource();

package com.swift;import org.springframework.jdbc.core.JdbcTemplate;import org.springframework.jdbc.datasource.DriverManagerDataSource;import org.springframework.stereotype.Component;@Component(value="jdbcTemplateDemo")public class JdbcTemplateDemo { public int queryCount() {  DriverManagerDataSource dataSource=new DriverManagerDataSource();  dataSource.setDriverClassName("com.mysql.jdbc.Driver");  dataSource.setUrl("jdbc:mysql://localhost:3306/sw_database");  dataSource.setUsername("root");  dataSource.setPassword("root");    JdbcTemplate jdbcTemplate=new JdbcTemplate(dataSource);  String sql="select count(*) from sw_user";  int count=jdbcTemplate.qureyForObject(sql, Integer.class);  return count;  }  public boolean update() {  DriverManagerDataSource dataSource=new DriverManagerDataSource();  dataSource.setDriverClassName("com.mysql.jdbc.Driver");  dataSource.setUrl("jdbc:mysql://localhost:3306/sw_database");  dataSource.setUsername("root");  dataSource.setPassword("root");    JdbcTemplate jdbcTemplate=new JdbcTemplate(dataSource);  String sql="update sw_user set password=? where username=?";  int count=jdbcTemplate.update(sql,"lunchtime","doomsday");  if(count!=0) {   return true;  }  return false;  } }

查询数据库操作使用JdbcTemplate对象根据数据源直接使用qureyForObject方法完成,第二个参数Integer.class为返回值类型的class。

之前完成需按下边方法:

PreparedStatement ps=conn.prepareStatement("select count(*) from sw_user");

???ResultSet rs=ps.executeQuery();???有待验证

上边代码使用Spring框架注解生成对象方法

<?

使用Servlet类进行测试:

package com.swift;import java.io.IOException;import javax.servlet.ServletException;import javax.servlet.annotation.WebServlet;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import org.springframework.context.ApplicationContext;import org.springframework.context.support.ClassPath)public class ServletTest extends HttpServlet { private static final long serialVersionUID = 1L; public ServletTest() {  super(); } protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {  response.setCharacterEncoding("utf-8");  response.setContentType("text/html;charset=utf-8");  response.getWriter().append("Served at: ").append(request.getContextPath());  ApplicationContext context=new ClassPath);  JdbcTemplateDemo jdbcTemplateDemo=(JdbcTemplateDemo) context.getBean("jdbcTemplateDemo");  response.getWriter().append(jdbcTemplateDemo.queryCount());   } protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {  doGet(request, response); }}

运行结果图

 Spring框架针对dao层的jdbcTemplate操作crud之query查询数据操作

 

原标题:Spring框架针对dao层的jdbcTemplate操作crud之query查询数据操作

关键词:Spring

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。

可能感兴趣文章

我的浏览记录