运行期建立HikariDataSource和JdbcTemplate

HikariDataSource是效率较高的数据源,JdbcTemplate又比JDBC省代码,两者结合一下高效而简洁。

以下是一个运行期建立HikariDataSource和JdbcTemplate的例子, 留着以备参考:

复制代码
package com.hy.lab.hikari;

import com.zaxxer.hikari.HikariDataSource;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;

class Emp{
    long id;
    String name;

    public String toString(){
        return "Emp id:"+id+" name="+name;
    }
}
public class Test {
    public static void main(String[] args){
        HikariDataSource ds=new HikariDataSource();
        ds.setDriverClassName("oracle.jdbc.OracleDriver");
        ds.setJdbcUrl("jdbc:oracle:thin:@127.0.0.1:1521:orcl");
        ds.setUsername("luna");
        ds.setPassword("1234");
        ds.setMinimumIdle(10);
        ds.setMaximumPoolSize(10);

        JdbcTemplate jdbcTplt = new JdbcTemplate(ds);

        StringBuilder sb=new StringBuilder();
        sb.append("create table emp0426(");
        sb.append("    id number(12),");
        sb.append("    name nvarchar2(20)");
        sb.append(")");
        String createTbSql=sb.toString();
        jdbcTplt.execute(createTbSql);

        jdbcTplt.execute("insert into emp0426(id,name) values(1,'Andy')");
        jdbcTplt.execute("insert into emp0426(id,name) values(2,'Bill')");
        jdbcTplt.execute("insert into emp0426(id,name) values(3,'Cindy')");
        jdbcTplt.execute("insert into emp0426(id,name) values(4,'Douglas')");

        List<Emp> emps = jdbcTplt.query("select id,name from emp0426", new RowMapper<Emp>() {
            @Override
            public Emp mapRow(ResultSet rs, int rowNum) throws SQLException {
                Emp emp=new Emp();
                emp.id=rs.getInt("id");
                emp.name=rs.getString("name");
                return emp;
            }});

        for(Emp emp:emps){
            System.out.println(emp);
        }
    }
}
复制代码

输出:

2022-04-26 20:51:13.846 - HikariPool-1 - Starting...
2022-04-26 20:51:14.586 - HikariPool-1 - Start completed.
Emp id:1 name=Andy
Emp id:2 name=Bill
Emp id:3 name=Cindy
Emp id:4 name=Douglas

Process finished with exit code 0

END

posted @   逆火狂飙  阅读(651)  评论(1编辑  收藏  举报
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
历史上的今天:
2018-04-26 【js】用正则表达式对文字进行局部替换
2018-04-26 【python】用正则表达式进行文字局部替换
2018-04-26 [Python] 错误“IndentationError: unindent does not match any outer indentation level”是什么意思?
2018-04-26 【Tip】如何在chrome浏览器中查看网页的Header
生当作人杰 死亦为鬼雄 至今思项羽 不肯过江东
点击右上角即可分享
微信分享提示