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驱动并将其注册到 ...
随机推荐
- The first week CorelDRAW 课总结:
1.这节课学到了什么知识? 答:(1)认识了CorelDRAW X4的工作界面(由标题栏 菜单栏 工具栏 属性栏 工具箱 页面控制栏 状态栏 绘图区和调色板组成): (2)CorelDRAW X4的基 ...
- Spring-cloud (一):Eureka注册中心搭建
前提 系统安装jdk1.8及以上,配置好maven的ide(这里用idea进行演示,maven版本3.5,配置阿里云源) 项目搭建 新建一个maven项目,创建最简单的那种就好,项目名这里为Eurek ...
- 031718-js变量、数据类型、运算符
1.关键字.标识符.变量(是一个名称,最好用字母开头,对大小写敏感).常量 (是有数据类型的一个值) 变量: ①定义并赋值 ②使用 2.数据类型:数字 字符串 布尔 null undefi ...
- ubuntu12.04更新到14.04,win7误删BCD引导项,导致两个系统都无法进入
解决办法: 制作老毛桃U盘启动盘,使用BCD编辑软件,对C/boot下的BCD文件进行编辑,添加win7引导向. 开机进入win7后,使用easyBCD添加ubuntu14.04启动项,选择grub2 ...
- PostgreSQL的insert注入
写这篇文是在昨夜的ctf中遇到的. ctf地址:bloody-feedback.quals.2017.volgactf.ru email存在注入,在ctf中发现注入就很好办了,只要找到能绕过的方法就行 ...
- [HNOI 2018]游戏
Description 题库链接 有 \(n\) 个房间排成一列,编号为 \(1,2,...,n\) ,相邻的房间之间都有一道门.其中 \(m\) 个门上锁,其余的门都能直接打开.现在已知每把锁的钥匙 ...
- [USACO 09FEB]Fair Shuttle
Description 逛逛集市,兑兑奖品,看看节目对农夫约翰来说不算什么,可是他的奶牛们非常缺乏锻炼——如果要逛完一整天的集市,他们一定会筋疲力尽的.所以为了让 奶牛们也能愉快地逛集市,约翰准备让奶 ...
- [HNOI2010]MATRIX 矩阵
Description Input 第一行包含三个正整数N M P表示矩阵的行数列数以及每个数的范围,接下来N行每行包含M个非负整数,其中第i行第j个数表示以格子(i,j)为右下角的2*2子矩阵中的数 ...
- [Ioi2011]ricehub
Description 乡间有一条笔直而长的路称为“米道”.沿着这条米道上 R 块稻田,每块稻田的坐标均 为一个 1 到 L 之间(含 1 和 L)的整数.这些稻田按照坐标以不减的顺序给出,即对于 0 ...
- [bzoj4866] [Ynoi2017]由乃的商场之旅
来自FallDream的博客,未经允许,请勿转载,谢谢, 由乃有一天去参加一个商场举办的游戏.商场派了一些球王排成一行.每个人面前有几堆球.说来也巧,由乃和你一样,觉得这游戏很无聊,于是决定换一个商场 ...