LzyRecord。

实践

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值