springJDBC实现查询
其实在Spring这个框架中,提供了一些对JDBC访问数据库的封装,其中JdbcTemplate就是一个很好用的类,下面来
演示一下这个类的一些用法。首先需要导入commons-logging.jar,和spring.jar这两个包。然后使用他的功能就可以了,
可以说,Spring框架对JDBC的封装是非常强大的,只需要一个数据源,建立完成连接后,对于连接的处理,连接池的
创建和维护,语句的发送和大数据的访问和返回,都提供了最好的支持,程序员不需要去关注这些,使用极为方便
- package com.bird.jdbc.spring;
- import java.sql.ResultSet;
- import java.sql.SQLException;
- import java.util.List;
- import org.springframework.jdbc.core.BeanPropertyRowMapper;
- import org.springframework.jdbc.core.JdbcTemplate;
- import org.springframework.jdbc.core.RowMapper;
- import com.bird.jdbc.Temple;
- import com.bird.jdbc.domain.User;
- public class JdbcTemple {
- /**
- * @param args
- */
- public static void main(String[] args) {
- System.out.println(test2(227));
- }
- public static User test(String name){
- JdbcTemplate jdbc = new JdbcTemplate(Temple.getDataSource());
- String sql = "select id,name,money,birthday from user where id=?";
- Object[] args = new Object[] {name};
- Object use = jdbc.queryForObject(sql, args,new RowMapper(){
- @Override
- public Object mapRow(ResultSet rs, int arg1) throws SQLException {
- User use = new User();
- use.setId(rs.getInt("id"));
- use.setBirthday(rs.getDate("birthday"));
- use.setMoney(rs.getFloat("money"));
- use.setName(rs.getString("name"));
- return use;
- }
- });
- return (User)use;
- }
- /**
- * 使用反射的基本行映射器
- * @param name
- * @return
- */
- public static User test1(String name){
- JdbcTemplate jdbc = new JdbcTemplate(Temple.getDataSource());
- String sql = "select id,name,money,birthday from user where id=?";
- Object[] args = new Object[] {name};
- Object use = jdbc.queryForObject(sql, args,new BeanPropertyRowMapper(User.class));
- return (User)use;
- }
- /**
- * 查询返回多个结果
- * @param id
- * @return
- */
- public static List<User> test2(int id){
- JdbcTemplate jdbc = new JdbcTemplate(Temple.getDataSource());
- String sql = "select id,name,money,birthday from user where id<?";
- Object[] args = new Object[] {id};
- @SuppressWarnings("unchecked")
- List<User> use = jdbc.query(sql, args,new BeanPropertyRowMapper(User.class));
- return use;
- }
- }
- 首先提供一个数据源,用来提供数据库的信息来进行连接,然后就是行映射器,来对返回的数据进行不同方式的封装
第一个是使用匿名内部类实现的,对于数据的访问,spring可以返回一个数据一组数据或者是一个容器,都是可以的
灵活实现,而且只要参数的顺序和问号的顺序要是一致,其他的就无所谓了,如果不想实现行映射器,也可以使用反
射机制,直接给他一个class文件就行了
springJDBC实现查询的更多相关文章
- springJdbc in 查询,Spring namedParameterJdbcTemplate in查询
springJdbc in 查询,Spring namedParameterJdbcTemplate in查询, SpringJdbc命名参数in查询,namedParameterJdbcTempla ...
- springJDBC实现查询方法二
无废话,看代码: @Override public List<Sites> queryAllSites(Pager pager) { String sql = "select * ...
- springJdbc like模糊查询,Spring namedParameterJdbcTemplate like查询
springJdbc like模糊查询,Spring namedParameterJdbcTemplate like查询, SpringJdbc命名参数like模糊查询,namedParameterJ ...
- SpringJDBC的JdbcTemplate在MySQL5.7下不支持子查询的问题
org.springframework.jdbc.BadSqlGrammarException: PreparedStatementCallback; bad SQL grammar [ SELECT ...
- SpringJDBC解析1-使用示例
JDBC(Java Data Base Connectivity,Java数据库连接)是一种用于执行SQL语句的JavaAPI,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组 ...
- springJDBC学习笔记和实例
前言:相对于Mybatis(ibatis),个人感觉springJDBC更灵活,主要实现类JdbcTemplate:它替我们完成了资源的创建以及释放工作,从而简化了我们对JDBC的使用.它还可以帮助我 ...
- springJDBC实现mysql简单分页
效果图:
- springJDBC一对多关系,以及Java递归,jsp递归的实现
maven编译,springMVC+spring+springJDBC框架. 要实现的功能是一个文件夹下,可能显示n个文件夹,每个文件夹下又可能显示n个文件夹.... 前台效果:
- SpringJDBC的简单应用
此处写上应用JdbcTemplate的dao操作数据库的一些代码(含基本的增删改查,注:重点是查询出多条语句的写法): package org.sakaiproject.zhaorui.dao.imp ...
随机推荐
- 根据不同浏览器使用不同的css文件
代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3. ...
- vb.net中将DataGridView与数据源绑定
在< .net中将DataGridView内的数据导出为Excel表格>中说了如何导出数据到Excel,今天这篇文章将讲述如何绑定数据源,在控件中显示我们需要的信息. 在敲机房收费系统的时 ...
- STL - C++ 11的Lambda表达式(上)
Lambda始自C++ 11,是一种在表达式或语句内指定函数行为的定义式. 你可以定义函数行为作为对象,以inline实参的形式传给算法作为predicate(判断式). eg: std:transf ...
- vue 表单 验证 async-validator
1.使用插件async-validator async-validator 地址:https://github.com/yiminghe/async-validator 2.示例(vue+elemen ...
- 谁占用了我的Buffer Pool?--【转】
转自:http://blogs.msdn.com/b/apgcdsd/archive/2011/01/11/buffer-pool.aspx 我在做SQL Server 7.0技术支持的时候有客户问我 ...
- PHP-静态方法(static)继承等分析
<?php class A { const CONST_NAME = 'A'; public static $static_name = 'A'; public static $static_n ...
- 【LeetCode】114. Flatten Binary Tree to Linked List
Flatten Binary Tree to Linked List Given a binary tree, flatten it to a linked list in-place. For ex ...
- Zookeeper研究和应用
http://www.searchtb.com/2011/01/zookeeper-research.html zookeeper简介 zookeeper是一个开源分布式的服务,它提供了分布式协作,分 ...
- JavaScript 中的所有数据都是以 64 位浮点型数据(float) 来存储。浮点型数据使用注意事项。全局变量特殊之处
JavaScript 中的所有数据都是以 64 位浮点型数据(float) 来存储. 所有的编程语言,包括 JavaScript,对浮点型数据的精确度都很难确定: <!DOCTYPE html& ...
- Postman+Postman interceptor的安装和使用-解决把chrome浏览器登录状态同步到postman进行有依赖的接口测试 Postman 使用方法详解
Postman+Postman interceptor的安装和使用-解决把chrome浏览器登录状态同步到postman进行有依赖的接口测试 问题引入:做接口测试时,有依赖关系的接口往往不好测试( ...