Java 数据库操作oracle增删改查,通用封装基于hashmap
pt1:首先安装oracle连接驱动
下载地址:https://pan.baidu.com/s/1jW_ofgU4eJmAn7Y2J5B46A 密码:epkz 1.将ojdbc6.jar导入项目中 先创建一个项目,然后在鼠标移到项目上右键-->new-->folder;folder name:lib;这样就在项目中创建了一个文件夹lib;然后将ojdbc6.jar包导入该文件夹中 2.Reference Library包右键-->build path-->add extend 导入jar包apply and save; package Db;
import java.sql.*;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.HashMap;
import java.util.Map; import org.openqa.selenium.remote.server.handler.DeleteCookie; import bsh.This;
import net.sf.json.JSONArray;
import net.sf.json.JSONObject; public class OrcTest {
String url;
String user;
String pwd;
String sql;
Connection connect;// 创建一个数据库连接
PreparedStatement pre ;// 创建预编译语句对象,一般都是用这个而不用Statement
ResultSet result; public OrcTest(String url,String user,String pwd){
this.url=url;
this.user=user;
this.pwd=pwd;
try {
Class.forName("oracle.jdbc.driver.OracleDriver");
this.connect=DriverManager.getConnection(this.url, this.user, this.pwd);
}catch (Exception e) {
System.out.println("连接数据驱动失败");
e.printStackTrace();
}
}
public void CloseDb(){
try {
if(this.pre !=null) {
this.pre.close();
System.out.println("关闭事物");
}
if(this.result !=null) {
this.result.close();
System.out.println("关闭结果对象");
}
if(this.connect !=null) {
this.connect.close();
System.out.println("关闭连接");
}
}catch (Exception e) {
e.printStackTrace();
}
}
// exe_select
public ArrayList<Object> exeselect(String sql) {
ArrayList<Object> list =new ArrayList<Object>();
try {
this.pre=this.connect.prepareStatement(sql);
this.result = this.pre.executeQuery();
ResultSetMetaData rsmd=null;
int count=0;
rsmd = this.result.getMetaData();
count=rsmd.getColumnCount();
while(this.result.next()) {
Map<String, Object> map = new HashMap<String, Object>();
for (int i = 1; i <= count; i++) {
map.put(rsmd.getColumnLabel(i),this.result.getObject(i));
}
JSONObject json = JSONObject.fromObject(map);
list.add(json.toString());
}
}catch(Exception e) {
e.printStackTrace();
}finally {
this.CloseDb();
}
return list;
}
//delete and update and insert
public boolean DeleteOrUpdateInsert(String sql) {
boolean bool;
try {
this.pre=this.connect.prepareStatement(sql);
this.pre.executeUpdate();
System.out.println("操作成功!!!!!!");
bool =true;
}catch (Exception e) {
bool=false;
e.printStackTrace();
}finally {
this.CloseDb();
}
return bool;
}
public static void main(String[] args){
String url="jdbc:oracle:thin:@localhost:1521/orcl";
String user="SCOTT";
String pwd="pipeline";
// String sql="select * from bonus";
OrcTest ob= new OrcTest(url, user, pwd);
// System.out.println(ob.exeselect(sql));
// System.out.println(ob.connect);
System.out.println(ob.DeleteOrUpdateInsert("insert into bonus(ENAME,JOB,SAL,COMM)VALUES('del','job_del',122,3)")); }
} ============================输出如下: 操作成功!!!!!!
关闭事物
关闭连接
true
============== 关闭事物
关闭结果对象
关闭连接
[{"ENAME":"cdp","COMM":1,"JOB":"jod_1234","SAL":1254}, {"ENAME":"cdp3","COMM":2,"JOB":"job003","SAL":1333}, {"ENAME":"cdp4","COMM":2,"JOB":"job004","SAL":1444}, {"ENAME":"cdp1","COMM":2,"JOB":"job222","SAL":1235}]
oracle.jdbc.driver.T4CConnection@533e64
json转换java 需要全jar包下载git地址 https://github.com/chen1932390299/pyscripts.git
Java 数据库操作oracle增删改查,通用封装基于hashmap的更多相关文章
- Linq 数据库操作(增删改查)
Linq数据库增删改查 Linq是一种查询语言,集成包含在formwork中,包含在C#语言中,它的作用是降低查询的门槛,提高开发效率,是我们必须掌握的技术之一,下面是我自己对linq数据库操作的方法 ...
- spring boot快速入门 4: jpa数据库操作 实现增删改查
spring boot jpa逆向生成表 简单实例: 第一步:pom文件: <?xml version="1.0" encoding="UTF-8"?&g ...
- 初次尝试PHP——一个简单的对数据库操作的增删改查例子
第一次学习PHP,很多人说PHP是最好的语言,学习了一点点,还不敢说这样的话,不过确实蛮好用的. 做了一个简单的对数据库的增删改查的操作,主要是将四种操作写成了独立的函数,之后直接调用函数.以下是代码 ...
- iOS sqlite 增删改查 简单封装(基于 FMDB)
/** * 对 sqlite 的使用进行简单封装,仅涉及简单的单表 增删改查 * * 基于 FMDB * * 操作基于 model ,数据库表字段与 model 属性一一对应,对 model 整 ...
- MySQL数据库操作:“增删改查”,忘记密码重置等。
[注] 数据库的“增删查改”,参考原作者Wid:http://www.cnblogs.com/mr-wid/archive/2013/05/09/3068229.html#d11.感谢大佬们的技术分享 ...
- flask 数据库操作(增删改查)
数据库操作 现在我们创建了模型,生成了数据库和表,下面来学习常用的数据库操作,数据库操作主要是CRUD,即Create(创建).Read(读取/查询).Update(更新)和Delete(删除). S ...
- ThinkPHP 数据库操作(二) : 增删改查
基本使用 可以直接使用数据库运行原生SQL操作了,支持 query (查询操作)和 execute (写入操作)方法,并且支持参数绑定. Db::query('select * from think_ ...
- php单例模式封装数据库操作类增删改查
<?php//三私一公 单例class Db{ //数据库连接对象 private static $instance; private static $table_name; private $ ...
- laravel中的数据库操作(增删改查)方法一
导入命名空间和DBnamespace App\Http\Controllers; use Illuminate\Support\Facades\DB; public function index(){ ...
随机推荐
- 【转】golang的channel的几种用法
关闭2次 ch := make(chan bool) close(ch) close(ch) // 这样会panic的,channel不能close两次 读取的时候channel提前关闭了 ch : ...
- uestc 1709 Binary Operations 位运算的灵活运用
Binary Operations Time Limit: 2000 ms Memory Limit: 65535 kB Solved: 56 Tried: 674 Description B ...
- POJ P2318 TOYS与POJ P1269 Intersecting Lines——计算几何入门题两道
rt,计算几何入门: TOYS Calculate the number of toys that land in each bin of a partitioned toy box. Mom and ...
- FineReport和泛微OA(Ecology)的单点登录集成方案
最近出现了很多关于帆软报表和泛微OA的集成问题,均出现在“单点登录”上.直接也有相关的文章介绍一些FineReport和泛微集成的背景.价值等,以及FineReport和OA的深度集成的方案,但是并没 ...
- 使用 npm 安装 Vue
使用 npm 安装 Vue 需要 node.js 就不多说了(从 nodejs.org 中下载 nodejs ) (1)安装 Vue,在 cmd 里直接输入: npm install -g cnpm ...
- postman具体讲解
postman 简单教程-实现简单的接口测试 最近开始做接口测试了,因为公司电脑刚好有postman,于是就用postman来做接口测试,哈哈哈哈,...postman 功能蛮强大的,还比较好用,下面 ...
- MooseFS安装部署
环境信息 Master服务器 dev04 chunkserver服务器 dev02.dev03.dev04 metalogger服务器 dev03 mount客户端 dev01.dev02 安装前下载 ...
- 2.java相对路径与绝对路径
1.基本概念的理解 绝对路径:绝对路径就是你的主页上的文件或目录在硬盘上真正的路径,(URL和物理路径)例如:C:xyz/test.txt 代表了test.txt文件的绝对路径.http://www. ...
- FileWriter与BufferedWriter的适用场景
IO这块,各种Writer,Reader,让人眼晕 而在网上基本找不到在什么时候用哪个类,并且网上的IO demo 很多用法都是错的 在这简单的分析一下FileWriter与BufferedWrite ...
- C#中Invoke的用法()-解决子线程访问主线程控件、线程安全等问题
引自https://www.cnblogs.com/lsgsanxiao/p/5523282.html invoke和begininvoke 区别 一直对invoke和begininvoke的使用和概 ...