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的更多相关文章

  1. Linq 数据库操作(增删改查)

    Linq数据库增删改查 Linq是一种查询语言,集成包含在formwork中,包含在C#语言中,它的作用是降低查询的门槛,提高开发效率,是我们必须掌握的技术之一,下面是我自己对linq数据库操作的方法 ...

  2. spring boot快速入门 4: jpa数据库操作 实现增删改查

    spring boot jpa逆向生成表 简单实例: 第一步:pom文件: <?xml version="1.0" encoding="UTF-8"?&g ...

  3. 初次尝试PHP——一个简单的对数据库操作的增删改查例子

    第一次学习PHP,很多人说PHP是最好的语言,学习了一点点,还不敢说这样的话,不过确实蛮好用的. 做了一个简单的对数据库的增删改查的操作,主要是将四种操作写成了独立的函数,之后直接调用函数.以下是代码 ...

  4. iOS sqlite 增删改查 简单封装(基于 FMDB)

    /** *  对 sqlite 的使用进行简单封装,仅涉及简单的单表 增删改查 * *  基于 FMDB * *  操作基于 model ,数据库表字段与 model 属性一一对应,对 model 整 ...

  5. MySQL数据库操作:“增删改查”,忘记密码重置等。

    [注] 数据库的“增删查改”,参考原作者Wid:http://www.cnblogs.com/mr-wid/archive/2013/05/09/3068229.html#d11.感谢大佬们的技术分享 ...

  6. flask 数据库操作(增删改查)

    数据库操作 现在我们创建了模型,生成了数据库和表,下面来学习常用的数据库操作,数据库操作主要是CRUD,即Create(创建).Read(读取/查询).Update(更新)和Delete(删除). S ...

  7. ThinkPHP 数据库操作(二) : 增删改查

    基本使用 可以直接使用数据库运行原生SQL操作了,支持 query (查询操作)和 execute (写入操作)方法,并且支持参数绑定. Db::query('select * from think_ ...

  8. php单例模式封装数据库操作类增删改查

    <?php//三私一公 单例class Db{ //数据库连接对象 private static $instance; private static $table_name; private $ ...

  9. laravel中的数据库操作(增删改查)方法一

    导入命名空间和DBnamespace App\Http\Controllers; use Illuminate\Support\Facades\DB; public function index(){ ...

随机推荐

  1. java util 中set,List 和Map的使用

    https://www.cnblogs.com/Lxiaojiang/p/6231724.html 转载

  2. K:栈和队列的比较

    栈和队列的相同点: 都是线性结构,即数据元素之间具有"一对一"的逻辑关系 都可以在顺序存储结构和链式存储结构上进行实现 在时间代价上,插入和删除操作都需常数时间:在空间代价上,情况 ...

  3. 004bean作用域

    1.Singleton(单例) 2.Prototype(原型)---->每次注入.通过Spring应用上下文获取,都会重新创建    @Scope(ConfigurableBeanFactory ...

  4. maven配置以及在eclipse Mars2中的使用

    通过1.maven的作用 maven也是一种项目管理工具,主要能够将项目中的jar包移除,通过索引的方式调动本地或者远程仓库中的包,从而实现项目的构建.另一个作用能够应用于大型项目的分模块开发. 2. ...

  5. 用Appium让Android功能自动化测试飞起来

    前言 做Android端功能自动化已有2年多的时间了,使用过的功能自动化框架有Robotium.Uiautomator.Appium.最近研究自动化case复用的方案,调研了Appium的自动化框架, ...

  6. 个人总结-7- 实现图片在MySQL数据库中的存储,取出以及显示在jsp页面上

    昨天主要是进行对数据库的内容提取出来并进行动态显示,这个只需要设置一个servlet从数据库中获取数据即可,只是图片比较特殊,不能显示. 今天准备继续找方法来实现图片得录入和显示到jsp中,准备从网上 ...

  7. linux系统服务器可能被攻击的几种攻击方式

    linux系统随着Linux企业应用的扩展,有大量的网络服务器使用Linux操作系统.Linux服务器的安全性能受到越来越多的关注,这里根据Linux服务器受到攻击的深度以级别形式列出,并提出不同的解 ...

  8. Java Spring中@Query中使用JPQL LIKE 写法

    两种方式 // 一 public List<TestEntity> searchByJpql(){ String jpql = "select k from TestEntity ...

  9. Facebook POP 使用指南

    Facebook POP 使用指南 Pop是一个动画引擎,用以扩展iOS.OSX的动画类型.相较于iOS.OSX中的基本动画效果,Pop扩展后支持弹簧动画效果与衰减动画效果,你可以用Pop动画引擎来构 ...

  10. [翻译] ZFTokenField

    ZFTokenField 本人视频教程系类   iOS中CALayer的使用 效果图: iOS custom view that let you add token view inside like ...