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 ...
随机推荐
- vmware 传输(vmdb)错误-32:pipe:read failed 解决方法
摘自: http://www.myzhenai.com.cn/post/1088.html 传输(vmdb)错误-32:pipe:read failed 解决方法 原创内容,转载请注明出处:htt ...
- 查看网络IP连接
- MapReduce中的分布式缓存使用
MapReduce中的分布式缓存使用 @(Hadoop) 简介 DistributedCache是Hadoop为MapReduce框架提供的一种分布式缓存机制,它会将需要缓存的文件分发到各个执行任务的 ...
- Javaee项目经验须知
Java的主要应用领域就是企业级的项目开发!具体要点(09年,那一年我去面试,被拒了几次,想起来还不错!他锻炼了我的心理素质,让我体会到很多,笑一个吧!): 1.掌握项目开发的基本步骤 2.具备极强的 ...
- .NET-MVC站点发布注意事项
在进行MVC站点发布的过程中需要注意bin文件,使用vs2013自带的发布功能容易漏掉一些dll文件,所以在发布之后需要将程序的bin目录下的文件拷贝到发布好的iis站点下面
- 依据硬件设备配置高性能的Nginx
Nginx的高级配置会涉及硬件,假设配置不好,会直接让性能下降好多好多. 我这里总结一下,怎样依据server的硬件设备来配置Nginx. 见下图: 低訪问量的网络,能够这样配置. 标准的网络訪问量, ...
- HBase建立二级索引的一些解决方式
HBase的一级索引就是rowkey,我们仅仅能通过rowkey进行检索. 假设我们相对hbase里面列族的列列进行一些组合查询.就须要採用HBase的二级索引方案来进行多条件的查询. 常见的二级索引 ...
- 【Oracle】Oracle常用语句集合
表相关 1.快速统计大表记录数 select table_name, t.num_rows, t.last_analyzed from tabs t WHERE table_name='TABLE_ ...
- [Done]ibatis/mybatis: java.lang.NoSuchMethodException
异常描述: Caused by: org.apache.ibatis.reflection.ReflectionException: Error instantiating interface cn. ...
- linux cut 命令
cut:以某种方式按照文件的行进行分割 参数列表: -b 按字节选取 忽略多字节字符边界,除非也指定了 -n 标志 -c 按字符选取 -d 自定义分隔符,默认为制表符. -f 与-d一起使用,指定显示 ...