JDBC方式操作数据库
1.读取配置文件,我将配置信息写入配置文件(.properties)中,方便后期数据库变更后或者其他项目使用,扩展性好些,尽量避免硬编码.
driver=oracle.jdbc.driver.OracleDriver
url=jdbc:oracle:thin:@127.0.0.1:1521:orcl
username=test
password=test
根据key获取配置文件方法之前的blog中有写.
2.获取数据库连接
/**
* 实例化数据库连接
* @return
*/
private Connection getConnection() {
String fileName = "thirdconfig.properties";
Connection conn = null;
try {
String driver = PropertiesUtil.readPropertiesInfo(fileName, "driver");
Class.forName(driver);
String url = PropertiesUtil.readPropertiesInfo(fileName, "url");
String username = PropertiesUtil.readPropertiesInfo(fileName, "username");
String password = PropertiesUtil.readPropertiesInfo(fileName, "password");
conn = DriverManager.getConnection(url, username, password);
} catch (Exception e) {
logger.error("数据库连接失败", e);
}
return conn;
}
3查询数据总量
private int getTotalCount(Connection conn, PreparedStatement prep) {
ResultSet rs = null;
int rowNum = 0;
String querySql = "select count(1) from BACKUP_ALARM_INFO";
try {
prep = conn.prepareStatement(querySql);
rs = prep.executeQuery();
if (rs.next()) {
rowNum = rs.getInt(1);
}
} catch (SQLException e) {
logger.error("执行查询出错", e);
} finally {
if (rs != null) {
try {
rs.close();
} catch (SQLException e) {
}
rs = null;
}
}
return rowNum;
}
4JDBC读取PG数据库
driver=org.postgresql.Driver
url=jdbc:postgresql://localhost:5432/postgres
username=postgres
password=postgres
querysql=select count(*) from test where id='#'
private boolean validatePgExist(String hashValue) { String driver = IncrementSysConfigHandler.readSystemConfig("driver");
String url = IncrementSysConfigHandler.readSystemConfig("url");
String username = IncrementSysConfigHandler.readSystemConfig("username");
String password = IncrementSysConfigHandler.readSystemConfig("password");
String sqlStr = IncrementSysConfigHandler.readSystemConfig("querysql");
sqlStr = sqlStr.replace("#", hashValue); Connection c = null;
Statement stmt = null;
ResultSet rs = null;
try {
Class.forName(driver);
c = DriverManager.getConnection(url, username, password);
c.setAutoCommit(false);
logger.info("Opened database successfully");
stmt = c.createStatement();
rs = stmt.executeQuery(sqlStr);
while (rs.next()) {
String result = rs.getString(1);
int count = Integer.valueOf(result);
if (count > 0) {
return true;
}
} } catch (Exception e) {
logger.error(e.getClass().getName() + ": " + e.getMessage());
} finally {
try {
rs.close();
} catch (SQLException e) {
e.printStackTrace();
}
try {
stmt.close();
} catch (SQLException e) {
e.printStackTrace();
}
try {
c.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
return false;
}
JDBC方式操作数据库的更多相关文章
- 重学 Java 设计模式:实战中介者模式「按照Mybaits原理手写ORM框架,给JDBC方式操作数据库增加中介者场景」
作者:小傅哥 博客:https://bugstack.cn - 原创系列专题文章 沉淀.分享.成长,让自己和他人都能有所收获! 一.前言 同龄人的差距是从什么时候拉开的 同样的幼儿园.同样的小学.一样 ...
- 使用原生JDBC方式对数据库进行操作
使用原生JDBC方式对数据库进行操作,包括六个步骤: 1.加载JDBC驱动程序 在连接数据库之前,首先要加载想要连接的数据库的驱动到JVM.可以通过java.lang.Class类的静态方法forNa ...
- jdbc原生操作数据库
jdbc原生操作数据库流程: 第一步:Class.forName()加载数据库连接驱动: 第二步:DriverManager.getConnection()获取数据连接对象; 第三步:根据 SQL 获 ...
- 理解class.forName() ---使用jdbc方式链接数据库时会经常看到这句代码
目录(?)[-] 官方文档 类装载 两种装载方法的区别 不同的类装载器 是否实例化类 在jdbc链接数据库中的应用 资源 原文地址:http://yanwushu.sinaapp.com/clas ...
- Win10 64位系统ADO方式操作数据库失败解决方法
VC操作Access数据库一般通过ODBC.ADO.DAO等方式,但在我的Win10 64位操作系统中,通过ADO方式操作数据库会失败,无法读取数据.解决方法:1.首先确保Win10操作系统ado目录 ...
- JAVA采用JDBC连接操作数据库详解
JDBC连接数据库概述 一.JDBC基础知识 JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供 ...
- python_协程方式操作数据库
# !/usr/bin/python3 # -*- coding: utf-8 -*- import requests import gevent import pymysql from gevent ...
- 2017.11.12 web中JDBC 方式访问数据库的技术
JavaWeb------ 第四章 JDBC数据库访问技术 在JavaWeb应用程序中数据库访问是通过Java数据库连接(JavaDateBase Connectivity简称JDBC)数据库的链接一 ...
- 使用JDBC连接操作数据库
JDBC简介 Java数据库连接(Java Database Connectivity,JDBC),是一种用于执行SQL语句的Java API,它由一组用Java编程语言编写的类和接口组成. JDBC ...
随机推荐
- 如何理解docker镜像build中的上下文
参考:https://yeasy.gitbooks.io/docker_practice/content/image/build.html 理解上线文概念非常重要,不然可能碰到一些奇怪的问题. 构建镜 ...
- ORACLE日期时间函数
ORACLE日期时间函数大全 TO_DATE格式(以时间:2007-11-02 13:45:25为例) Year: yy two digits 两位年 ...
- F-02 创建财务凭证BAPI
**.获取抬头参数, documentheader **.项目参数 accountgl = lt_acgl"G/L account item accountreceivable = lt_a ...
- 003 F-47创建预付定金请求检查增强-20150819.docx
Enhancement SE38:LEINRF26 操作F-47,预付定金请求回车时,检查输入的采购订单项目发票视图,预付定金% 栏位,若为空,则报错,不为空可继续. 检查逻辑:检查采购凭证项 ...
- docker helloworld
阿里云镜像: docker官网 docker官方安装文档 配置阿里云镜像后,重启服务,以及检测服务是否正确启动 docker version.info.--help linux帮助命令man ls 镜 ...
- ajax json 异步请求
function ajaxTest(){ if (true) { $.ajaxSettings.async = false; var dataJson; $.getJSON("/univer ...
- commonAncestor
commonAncestor 光标或选区所在区域最外层的祖先节点
- 使用Axure生成网站结构图
使用Axure设计的各网站(产品)页面,生成网站(产品)结构图.这个对于了解网站整体结构很有帮助. 需要把它生成对应结构的网站结构图. 第一步:在“主页”上面新建一个和“主页”平级的页面,命名为“网站 ...
- Linux基本命令 压缩命令
1.压缩命令 ================================================================================== 命令名称:gzip ...
- 建议50:Python中的高级数据结构
# -*- coding:utf-8 -*- ''' Collection.Array.Heapq.Bisect.Weakref.Copy以及Pprint collections模块包含了内建类型之外 ...