使用该工具类需要从spring开发包中导入spring.jar和commons-logging.jar,这个模板是线程安全的。

 

JdbcTemplate:

public class JdbcTemplateTest {

    static JdbcTemplate jdbc = new JdbcTemplate(JdbcUtils.getDataSource());

    /**
     * @param args
     */
    public static void main(String[] args) {
        User user = findUser("zhangsan");
        // System.out.println("user:" + user);

        // System.out.println("users:" + findUsers(3));

        // System.out.println("user count:" + getUserCount());

        // System.out.println("user name:" + getUserName(1));

        System.out.println("data:" + getData(1));
    }

    static int addUser(final User user) {
        jdbc.execute(new ConnectionCallback() {//想在插入的时候取主键,回调

            public Object doInConnection(Connection con) throws SQLException, DataAccessException {
                String sql = "insert into user(name,birthday, money) values (?,?,?) ";
                PreparedStatement ps = con.prepareStatement(sql,
                        Statement.RETURN_GENERATED_KEYS);
                ps.setString(1, user.getName());
                ps.setDate(2, new java.sql.Date(user.getBirthday().getTime()));
                ps.setFloat(3, user.getMoney());
                ps.executeUpdate();

                ResultSet rs = ps.getGeneratedKeys();
                if (rs.next())
                    user.setId(rs.getInt(1));
                return null;
            }
        });
        return 0;
    }

    static Map getData(int id) {
        String sql = "select id as userId, name, money, birthday  from user where id="
                + id;
        return jdbc.queryForMap(sql);
    }

    static String getUserName(int id) {
        String sql = "select name from user where id=" + id;
        Object name = jdbc.queryForObject(sql, String.class);
        return (String) name;
    }

    static int getUserCount() {
        String sql = "select count(*) from user";
        return jdbc.queryForInt(sql);//直接把结果返回成int型,也可以查询最大值平均值之类的
    }

    static List findUsers(int id) {
        String sql = "select id, name, money, birthday  from user where id<?";
        Object[] args = new Object[] { id };
        int[] argTypes = new int[] { Types.INTEGER };
        List users = jdbc.query(sql, args, argTypes, new BeanPropertyRowMapper(
                User.class));//查询结果是多条记录
        return users;
    }

    static User findUser(String name) {
        String sql = "select id, name, money, birthday  from user where name=?";
        Object[] args = new Object[] { name };
        Object user = jdbc.queryForObject(sql, args, new BeanPropertyRowMapper(
                User.class));//queryForObject查询如果查不到数据或者多于一条数据会报错
        return (User) user;
    }

    static User findUser1(String name) {
        String sql = "select id, name, money, birthday  from user where name=?";
        Object[] args = new Object[] { name };
        Object user = jdbc.queryForObject(sql, args, new RowMapper() {

            public Object mapRow(ResultSet rs, int rowNum) throws SQLException {
                User user = new User();
                user.setId(rs.getInt("id"));
                user.setName(rs.getString("name"));
                user.setMoney(rs.getFloat("money"));
                user.setBirthday(rs.getDate("birthday"));
                return user;
            }
        });
        return (User) user;
    }
}

 

 

 

NamedParameterJdbcTemplate :包含JdbcTemplate的功能,特点是可以解析sql语句中的非?参数,而且可以直接用sql去匹配bean中的属性。

public class NamedJdbcTemplate {
    static NamedParameterJdbcTemplate named = new NamedParameterJdbcTemplate(
            JdbcUtils.getDataSource());

    /**
     * @param args
     */
    public static void main(String[] args) {
        User user = new User();
        user.setMoney(10);
        user.setId(2);
        System.out.println(findUser1(user));
    }

    static void addUser(User user) {
        String sql = "insert into user(name,birthday, money) values (:name,:birthday,:money) ";
        SqlParameterSource ps = new BeanPropertySqlParameterSource(user); //使用bean来设置sql中的参数
        KeyHolder keyHolder = new GeneratedKeyHolder(); 
        named.update(sql, ps, keyHolder); //获取主键
        int id = keyHolder.getKey().intValue();
        user.setId(id);
       
        Map map = keyHolder.getKeys(); //如果主键是多个,可以用该方法获取成Map映射
    }

    static User findUser(User user) {
        String sql = "select id, name, money, birthday  from user "
                + "where money > :m and id < :id";
        Map params = new HashMap();
        // params.put("n", user.getName());
        params.put("m", user.getMoney());
        params.put("id", user.getId()); //使用Map来设置sql的参数
        Object u = named.queryForObject(sql, params, new BeanPropertyRowMapper(
                User.class)); //第三个参数是一个映射器,将获取的数据映射给Bean
        return (User) u;
    }

    static User findUser1(User user) {
        String sql = "select id, name, money, birthday  from user "
                + "where money > :money and id < :id";
        SqlParameterSource ps = new BeanPropertySqlParameterSource(user);
        Object u = named.queryForObject(sql, ps, new BeanPropertyRowMapper(
                User.class));
        return (User) u;
    }

}

 

 

 

 

SimpleJdbcTemplate:在前两者基础上支持了可变参数和泛型

public class SimpleJdbcTemplateTest {
    static SimpleJdbcTemplate simple = new SimpleJdbcTemplate(JdbcUtils
            .getDataSource());

    static User find(String name) {
        String sql = "select id, name, money, birthday  from user where name=? and money > ?";
        User user = simple.queryForObject(sql,
                ParameterizedBeanPropertyRowMapper.newInstance(User.class),
                name, 100f);
        return user;
       
        //simple.getNamedParameterJdbcOperations().update(sql,paramSource,keyHolder);先获取NamedJdbcTemplate模板,再获取主键
        //simple.getJdbcOperations()获取JdbcTemplate
    }

}

 

 

 

上面代码引用的自定义工具类的代码:

public final class JdbcUtils {
    private static String url = "jdbc:mysql://localhost:3306/jdbc";
    private static String user = "root";
    private static String password = "";
    private static DataSource myDataSource = null;

    private JdbcUtils() {
    }

    static {
        try {
            Class.forName("com.mysql.jdbc.Driver");
            // myDataSource = new MyDataSource2();
            Properties prop = new Properties();
            // prop.setProperty("driverClassName", "com.mysql.jdbc.Driver");
            // prop.setProperty("user", "user");

            InputStream is = JdbcUtils.class.getClassLoader()
                    .getResourceAsStream("dbcpconfig.properties");
            prop.load(is);
            myDataSource = BasicDataSourceFactory.createDataSource(prop);
        } catch (Exception e) {
            throw new ExceptionInInitializerError(e);
        }
    }

    public static DataSource getDataSource() {
        return myDataSource;
    }

    public static Connection getConnection() throws SQLException {
        // return DriverManager.getConnection(url, user, password);
        return myDataSource.getConnection();
    }

    public static void free(ResultSet rs, Statement st, Connection conn) {
        try {
            if (rs != null)
                rs.close();
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            try {
                if (st != null)
                    st.close();
            } catch (SQLException e) {
                e.printStackTrace();
            } finally {
                if (conn != null)
                    try {
                        conn.close();
                        // myDataSource.free(conn);
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
            }
        }
    }
}

JDBC JdbTemplate&NamedParameterJdbcTemplate(Spring工具类)的更多相关文章

  1. 一、JDBC的概述 二、通过JDBC实现对数据的CRUD操作 三、封装JDBC访问数据的工具类 四、通过JDBC实现登陆和注册 五、防止SQL注入

    一.JDBC的概述###<1>概念 JDBC:java database connection ,java数据库连接技术 是java内部提供的一套操作数据库的接口(面向接口编程),实现对数 ...

  2. spring 工具类大集合

    接以前的文章 apache-commons 常用工具类 和文章 apache-commons 工具类扩展 小家 Spring 对 spring 的工具类做了详细的介绍(一) 这里我抽出一些好用的类,不 ...

  3. Spring工具类 非spring管理环境中获取bean及环境配置

    SpringUtils.java import org.springframework.beans.BeansException; import org.springframework.beans.f ...

  4. Spring工具类:WebApplicationContextUtils

    当 Web 应用集成 Spring 容器后,代表 Spring 容器的WebApplicationContext对象将以 WebApplicationContext.ROOT_WEB_APPLICAT ...

  5. spring工具类获取bean

    import org.springframework.web.context.ContextLoader; import org.springframework.web.context.WebAppl ...

  6. 借助Spring工具类如何实现支持数据嵌套的赋值操作

    假设有两个Bean A和B,想将B中的属性赋值到A实体中,可以使用get set来实现,当属性过多时,就会显得很冗余,可以使用spring提供的BeanUtils.copyProperties()来实 ...

  7. 你可能用到的Spring工具类?

    现在绝大部分项目都已经拥抱Spring生态,掌握Spring常用的工具类,是非常重要,零成本增加编码效率. 一.常用工具类 ObjectUtils org.springframework.util.O ...

  8. MySQL JDBC常用知识,封装工具类,时区问题配置,SQL注入问题

    JDBC JDBC介绍 Sun公司为了简化开发人员的(对数据库的统一)操作,提供了(Java操作数据库的)规范,俗称JDBC,这些规范的由具体由具体的厂商去做 对于开发人员来说,我们只需要掌握JDBC ...

  9. Spring工具类ToStringBuilder用法简介

    比如说我们需要打印某个方法的User参数对象 package test; /** * * @author zhengtian * @time 2012-6-28 */ public class Use ...

随机推荐

  1. mpdf与fpdf的使用比较

    php扩展 ---mpdf/fpdf 最近用到pdf扩展,需求是生成合同与简历的pdf,可供下载打印 mpdf 首先接触的是mpdf,从源码可以看出mpdf是基于fpdf与html2fpdf的成果. ...

  2. servlet中请求转发(forword)和重定向(redirect)的区别

    servlet请求转发与重定向的区别: request.setAttribute("test","hello"); request.getRequestDisp ...

  3. CDOJ 1314 Hash Perfectly FFT

    Hash Perfectly 题目连接: http://acm.uestc.edu.cn/#/problem/show/1314 Description In computing, a hash ta ...

  4. linux基础命令学习 (七)压缩解压

    一.tar tar主要用来压缩和解压文件 语法: tar [主选项+辅选项] 文件或者目录 主选项: c 创建新的档案文件.如果用户想备份一个目录或是一些文件,就要选择这个选项.相当于打包. x 从档 ...

  5. minor gc和full gc

    Minor GC ,Full GC 触发条件 Minor GC触发条件:当Eden区满时,触发Minor GC. Full GC触发条件: (1)调用System.gc时,系统建议执行Full GC, ...

  6. Maven +Tomcat+m2eclipse的热部署(hot deploy)

    原文地址: http://www.cnblogs.com/cbf4life/archive/2010/01/29/1659502.html 软件版本:maven 2.2 tomcat 6.0,Ecli ...

  7. Openshift 3.11和LDAP的集成

    1. OpenLDAP的安装 只记录主要步骤,详细可参考 https://access.redhat.com/solutions/2484371 # yum install -y openldap o ...

  8. python的__slots__节约内存的魔法;检查python每一行代码内存占用情况的工具

    在Python中,每个类都有实例属性.默认情况下Python用一个字典来保存一个对象的实例属性.这非常有用,因为它允许我们在运行时去设置任意的新属性. 然而,对于有着已知属性的小类来说,它可能是个瓶颈 ...

  9. 双sonar的cache问题

  10. go语言基础之for循环

    1.for 的用法 示例: package main //必须有一个main包 import "fmt" func main() { //for 初始化条件 ; 判断条件 ; 条件 ...