JDBC访问数据库的一些小技巧
一. 连接
1.使用try with resources关闭JDBC资源
示例代码如下:
public List<User> getUser(int userId) {
try (Connection con = DriverManager.getConnection(myConnectionURL);
PreparedStatement ps = createPreparedStatement(con, userId);
ResultSet rs = ps.executeQuery()) {
// process the resultset here, all resources will be cleaned up
} catch (SQLException e) {
e.printStackTrace();
}
}
private PreparedStatement createPreparedStatement(Connection con, int userId) throws SQLException {
String sql = "SELECT id, username FROM users WHERE id = ?";
PreparedStatement ps = con.prepareStatement(sql);
ps.setInt(1, userId);
return ps;
}
摘自:
传统的关闭JDBC资源的方法,如下:
public static void realeaseAll(ResultSet rs,Statement stmt,Connection conn){
if(rs!=null){
try {
rs.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if (stmt!=null){
try {
stmt.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if (conn != null) {
try{
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
或者利用jdk1.7 AutoCloseable,代码如下。
/**
* 如需同时关闭resultset,statement与connection,请依次按顺序关闭,即按照r->s->c的顺序将参数放入closeAll
* @param obj
*/
public static void closeAll(AutoCloseable... obj) {
for (AutoCloseable item : obj) {
try {
if(item!=null){
item.close();
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
在jdk1.7中因为所有的资源都要实现AutoCloseable接口,所以可以利用其进行关闭。当然,直接用try with resources语法是最好的。
2.使用C3P0连接数据库提示“Apparent Dead Lock”
一般都是因为用户名密码写错了(注意空格等)。不是这个原因的再查看其它地方。
3.使用C3P0连接数据的工具类JdbcPoolUtil
public class JdbcPoolUtil {
private static ComboPooledDataSource cpds;
static{
cpds = new ComboPooledDataSource();//默认读取classpath下的c3p0.properties文件
/*Properties prop = new Properties();//另外一种读取配置文件的方法
try {
InputStream in = JdbcPoolUtil.class.getClassLoader().getResourceAsStream("jdbc.properties");
prop.load(in);
cpds.setDriverClass(prop.getProperty("jdbc.driverClass"));
cpds.setJdbcUrl(prop.getProperty("jdbc.jdbcUrl"));
cpds.setUser(prop.getProperty("jdbc.user"));
cpds.setPassword(prop.getProperty("jdbc.password"));
cpds.setInitialPoolSize(Integer.parseInt(prop.getProperty("jdbc.initialPoolSize")));
cpds.setMaxPoolSize(Integer.parseInt(prop.getProperty("jdbc.maxPoolSize")));
} catch (Exception e) {
throw new ExceptionInInitializerError(e);
} */
}
public static DataSource getDataSource() {
return cpds;
}
public static Connection getConnection() throws SQLException{
Connection conn = cpds.getConnection();
return conn;
}
//其他代码
}
这里默认读取classpath下的c3p0.properties文件,也可使用注释中的方法对指定配置文件读取。
二. 处理日期
1. 将指定格式的日期字符串转化为LocalDateTime
String timeStamp = "20170818103605"
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyyMMddHHmmss");
LocalDateTime dateTime = LocalDateTime.parse(timeStamp, formatter);
三. 写入
1. 一种通用的插入方法
使用insert插入数据,一般格式如下:insert table1(col1, col2) values(?, ?)
。各种插入业务所不同的是每列的数据类型和到底有多少列。可以使用如下方法进行统一插入:
public static int insert(Connection conn, String sql, Object[] params){
PreparedStatement pstmt = null;
int result = 0;
try{
pstmt = conn.prepareStatement(sql);
for(int i =0; i<params.length; i++){
pstmt.setString(i+1, params[i]!=null?params[i].toString():null);
}
result = pstmt.executeUpdate();
}catch (Exception e) {
e.printStackTrace();
}finally{
//关闭数据库相关资源的代码
}
return result;
}
注意:params中存储的对象的toString
方法返回的值是否是你需要插入的值。
还可使用setObject(int parameterIndex, Object x)
方法,更简单。不过这两种方法在处理null值的时候有兼容性问题,可使用setNull
或 setObject(int parameterIndex, Object x, int sqlType)
。
四. 读取
1. 当数据库中某列值NULL是,ResultSet的getDouble(任何get数值类型的操作)结果返回0.0
public class ReadData {
public static void main(String[] args) {
String url = "jdbc:mysql://localhost:3306/test1";
String userName = "root";
String password = "123456";
String sql = "select id,stuno,age,birthdate,major from students";
try (Connection con = DriverManager.getConnection(url, userName, password);
PreparedStatement pStatement = con.prepareStatement(sql);
ResultSet rs = pStatement.executeQuery()) {
while (rs.next()) {
/*注意:getInt的返回值*/
System.out.printf("id=%s stuno=%s age=%s bd=%s major=%s%n", rs.getInt("id"), rs.getString("stuno"), rs.getInt("age"),
rs.getDate("birthdate"), rs.getString("major"));
/*可以全用getString返回数据*/
System.out.printf("id=%s stuno=%s age=%s bd=%s major=%s%n", rs.getString("id"), rs.getString("stuno"), rs.getString("age"),
rs.getString("birthdate"), rs.getString("major"));
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
对于记录:2 20150112 吴京 m null null null
返回结果如下:
id=2 stuno=20150112 age=0 bd=null major=null
id=2 stuno=20150112 age=null bd=null major=null
可以看到age虽然为Null但是返回0。那么如何返回null值呢?参考如下代码:
Integer age = rs.getInt("age");
Object oAge = rs.getObject("age");
System.out.printf("age=%s, oAge=%s%n",age, oAge);
打印结果为age=0, oAge=null
。还可使用如下方法:
Integer age = rs.getInt("age");
if (rs.wasNull())
age = null;
2. 使用getString可以以字符串形式返回任何类型的数据
数据同上,使用如下代码:
/*可以全用getString以字符串形式返回数据*/
System.out.printf("id=%s stuno=%s age=%s bd=%s major=%s%n", rs.getString("id"), rs.getString("stuno"), rs.getString("age"), rs.getString("birthdate"), rs.getString("major"));
返回结果为:id=2 stuno=20150112 age=null bd=null major=null
。注意:数据库中的null值被转化为null。
JDBC访问数据库的一些小技巧的更多相关文章
- 如何通过JDBC访问数据库
Java数据库连接(JDBC)用与在Java程序中实现数据库操作功能,它提供了执行SQL语句.访问各种数据库的方法,并为各种不同的数据库提供统一的操作接口,java.sql包中包含了JDBC操作数据库 ...
- java web中Jdbc访问数据库步骤通俗解释(吃饭),与MVC的通俗解释(做饭)
一.Jdbc访问数据库步骤通俗解释(吃饭) 1)加载驱动 Class.forName(“com.microsoft.jdbc.sqlserver.SQLServer”); 2) 与数据库建立连接 Co ...
- Jdbc访问数据库篇
一万年太久,只争朝夕 What JDBC 上部 JDBC(Java DataBase Connectivity)Java 数据库连接,主要提供编写 Java 数据库应用程序的 API 支持 java. ...
- 2017.10.3 JDBC访问数据库的建立过程
1·JDBC访问数据库,其访问流程: (1)注册驱动 (2)建立连接(Connection) (3)创建数据库操作对象用于执行SQL语句 (4)执行语句 (5)处理执行结果 (6)释放资源 2·注册驱 ...
- JDBC访问数据库的具体步骤(MySql + Oracle + SQLServer)
* 感谢DT课堂颜群老师的视频讲解(讲的十分仔细,文末有视频链接) import java.sql.Connection; import java.sql.DriverManager; import ...
- Spring实战6:利用Spring和JDBC访问数据库
主要内容 定义Spring的数据访问支持 配置数据库资源 使用Spring提供的JDBC模板 写在前面:经过上一篇文章的学习,我们掌握了如何写web应用的控制器层,不过由于只定义了SpitterRep ...
- 【jdbc访问数据库获取执行sql转换json】
Talk is cheap.Show me your code. import java.sql.*; import java.util.HashMap; import java.util.Map; ...
- javaweb三、JDBC访问数据库
JDBC是J2SE的内容,是由java提供的访问数据库的接口,但没有提供具体的实现方法,需要数据库厂商提供,就是对应的数据库驱动. 这样的好处是可以方便的更换数据库,提高了扩展性.这也是面向接口编程的 ...
- java之连接数据库之JDBC访问数据库的基本操作
1.将数据库的JDBC驱动加载到classpath中,在基于JavaEE的web应用实际开发过程中通常要把目标数据库产品的JDBC驱动复制到WEB—INF/lib下. 2.加载JDBC驱动并将其注册到 ...
随机推荐
- 通过java api统计hive库下的所有表的文件个数、文件大小
更新hadoop fs 命令实现: [ss@db csv]$ hadoop fs -count /my_rc/my_hive_db/* 18/01/14 15:40:19 INFO hdfs.Peer ...
- hadoop in hue的搭建(基于cdh版本)
首先官网下载tar包 http://archive.cloudera.com/cdh5/cdh/5/hue-3.9.0-cdh5.5.4.tar.gz 在安装hue之前,还需要安装各种依赖包,首先要检 ...
- python中关于文件的读取和写入
open()和close()方法:使用python的内置函数open()打开一个文件,创建一个file对象,相关的方法才可以调用它进行读写. file object = open(file_name ...
- drupal 8 之 captcha模块
captcha模块的作用: 添加验证码表单 一.模块下载 https://www.drupal.org/project/captcha 二.安装模块 [扩展]>[+安装新的模块] 在模块页面,复 ...
- [ Java学习基础 ] Java对象的创建和销毁
类实例化可生成对象,实例方法就是对象方法,实例变量就是对象属性.一个对象的生命周期包括三个阶段:创建.使用和销毁. 创建对象 创建对象包括两个步骤:声明和实例化. 声明 声明对象与声明普通变量没有区别 ...
- 1086: [SCOI2005]王室联邦
1086: [SCOI2005]王室联邦 Time Limit: 10 Sec Memory Limit: 162 MBSec Special JudgeSubmit: 1554 Solved: ...
- [HEOI 2014]大工程
Description 题库链接 给你一个 \(n\) 个节点的树, \(q\) 组询问,每次给出 \(k\) 个关键点,询问这 \(k\) 个关键点两两间路径长度和,长度最值. \(1\leq n\ ...
- hdu 5340 (manacher)
Sample Input 2 abc abaadada Sample Output Yes No 判断是否能成为3个非空回文子串 manacher算法求出个点回文长度,在找出第一个和最后一个保存下 ...
- Hdu 5595 GTW likes math
题意: 问题描述 某一天,GTW听了数学特级教师金龙鱼的课之后,开始做数学<从自主招生到竞赛>.然而书里的题目太多了,GTW还有很多事情要忙(比如把妹),于是他把那些题目交给了你.每一道题 ...
- String.IndexOf 方法笔记
记录以备使用 作用:报告指定 Unicode 字符或字符串在此实例中的第一个匹配项的从零开始的索引. 如果未在此实例中找到该字符或字符串,则此方法返回 -1. 重载列表 名称 说明 IndexOf ...