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 ...
随机推荐
- qt study 泛型和容器
所谓泛型(generic) 能够像操作基本类型一样轻松操作对象的类和函数. qt容器类就是泛型类,基于模板的泛型类. 重载运算符overloaed operator, 托管容器 managed con ...
- RS查询报错之递归公用表表达式不包含顶级 UNION ALL运算符
在FM里面涉及模型的时候,修改了物理层的查询SQL如下 select * from TARGET_VISIT_GH where ghksdm in(select dept_id from DIM_BI ...
- [Functional Programming] Monad
Before we introduce what is Monad, first let's recap what is a pointed functor: A pointed functor is ...
- 淘宝网前端开发面试题(二)--JS 面试题
所有答案仅供参考,不负责答案对错(^_^) 1.js 是什么,js 和 html 的开发如何结合? js是javascript的缩写,是一种基于对象的.事件驱动的脚本语言.它一共由三个部分组成:分别是 ...
- Linux Samba安装与使用
一 安装环境: 虚拟机:RedHat 5.4 192.168.75.128 主机环境:WIN7 32bit 192.168.75.1 网络连接方式:NAT 二 安装步骤: 说明: Ø samb ...
- 微信小程序 - 为何setData到页面上有的加分号
Page({ /** * 页面的初始数据 */ data: { }, /** * 生命周期函数--监听页面加载 */ onLoad: function(options) { let _page = t ...
- 在Ubuntu 12 服务器上源码安装 OpenERP 8.0
原文:http://vivianyw.blog.163.com/blog/static/134547422201421112349489/ 1. 安装SSH: sudo apt-get install ...
- Eclipse/Myeclipse中查看和调试JDK源代码的方法
看过这篇文章后,实践写的 http://blog.csdn.net/qq_27857857/article/details/71250401 一共做了以下几部: 第一步: 第二步: 一直next,到第 ...
- 用记事本编写一个Servlet项目
第一步:建立目录 新建一个文件夹FirstServlet,然后在FirstServlet目录下面再建两个文件夹,分别为:WEB-INF和src.最后在WEB-INF下面建一个classes文件夹 第二 ...
- Android自定义控件-折线图
好长时间没有更新博客了,终于可以抽出时间写点东西了,写点什么呢?最近在qq群里边有人问,下边的这个控件怎么画?如下图所示:图可以左右拖动,直到显示完全为止.刚开始看到这个效果图,我也想了一下总共分为以 ...