运行期建立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
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需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