实践
topic [myProgram]
{ 流程范式>others }
JDBC [LzyJDBCUtils]
1.流程范式
注册驱动 >获取Driver对象 >获取Connection对象 >获取Statement对象(提交数据库操作语句) >获取ResultSet对象 >释放Connection,Statement,ResultSet资源。
JDBC(String JDBCurl){
Class.forName(String DriverName);//注册驱动。
/* DriverManager.getConnection([Param]...)会尝试当前注册的所有类型数据库驱动,部分场景会抛IllegalArgumentException(eg:HiveJDBC驱动和其她JDBC驱动并发同时使用)。
* 解决方案: a.先获取Driver对象,由Driver对象获取Connection对象。
* b.Hive最新版本已经完善了该不足。
*/
Driver driver = DriverManager.getDriver(JDBCUrl);//获取Driver对象。
Connection conn = driver.connect(JDBCUrl,info);//java.sql.Driver.connect(String url, Properties info);
XXXStatement xs = conn.xxxStatement();
ResultSet rs = xs.executeXXX(sql);
close(conn,xs,rs);
}
close(Connection conn,Statement xs,ResultSet rs){//释放资源。ResultSet>Statement>Connection。
rs.close();
xs.close();
conn.close();
}
2.Others
HiveJDBC
- 连接Hive。
在Hadoop客户端启动[HiveServer2]进程。
Hive2.0后的url:jdbc:hive2://hostIp:port/dbName。 - HivePreparedStatement未支持setObject(num,param)。
解决方案:工具类方法中对HivePreparedStatement类型的实例分支计算。 - HiveJDBC与其她JDBC共同使用时(eg:多线程),DriverManger.getConnection()会尝试所有类型的Connection,就会抛出异常。
解决方案:先获取Driver对象再通过Driver对象获取Connection对象,也就是上述给出的流程范式。最新版本的HiveJDBC完善了不足。
Statement
Java读写文件 [LzyTxtUtils,LzyExcelUtils]
1.流程范式
这里写代码片。
2.Others
- 三类五个读写文件方式比对。
- 传输对象的Stream对象。[ObjectOutpuStream & ObjectInpuStream]
ObjectXXXStream要求传输的对象实现Serializbale接口。