JDBC连接Oracle数据库的问题

时间:2022-09-07 12:40:24

场景:最近做一个java web项目,使用jdbc连接Oracle数据库,遇到了两个问题。

问题1:jdbc连接不上Ubuntu Oracle服务器?

后来发现这个问题的原因是由于连接字符串写错了,修正以后如下所示:

    public static Connection getConn() {
        Connection conn = null;
 
        try {
 
            // oracle
            // 1.加载驱动
            Class.forName("oracle.jdbc.driver.OracleDriver"); // 需要下载oracle
                                                                // JDBC的驱动包
            // 2.得到链接
            String url = "jdbc:oracle:thin:user@//IP/orcl"; // user是用户名,IP是服务器地址,orcl是数据库的名称
            String user = "ji"; // 你ORACLE数据中一个用户名称
            String password = "ji"; // 对应上面用户名称的密码
            conn = DriverManager.getConnection(url, user, password); // 连接
 
            System.out.println(conn);
        } catch (Exception e) {
            e.printStackTrace();
        }
 
        return conn;
    }

.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }

问题2:服务器连接成功后,从服务器上取不出数据?

刚接触Oracle数据库的应用,小白一枚,若是大师,请忽略。

(1)操作自信

先描述一下本人的做法:

服务器数据库为空,本地用oracle sql developer连接,连接后创建了一张表TABLE_USER,接着用INSERT语句添加了一条测试数据,为了测试插入数据是否成功,又用SELECT语句查询了一番,如下图所示:

初始时,数据表为空:

JDBC连接Oracle数据库的问题

插入一条数据:INSERT INTO TABLE_USER(ID,USERNAME,PWD,STORE_ID) VALUES(1,'a','a',100)

再次查看数据表:(可以看到数据已经插入到数据表)

JDBC连接Oracle数据库的问题

为了保险起见,再用SELECT语句验证一番:SELECT * FROM TABLE_USER  如下图所示:

JDBC连接Oracle数据库的问题

经过上述步骤,确信数据已经准备好,可以进行Java代码读数据测试了。

(2)代码自信

java代码读取测试表数据,代码如下:

public static ResultSet getRs(Connection con, String sql, Object[] param) {
        Connection conn = con;
        PreparedStatement pstmt = null;
        ResultSet rs = null;
 
        try {
            pstmt = conn.prepareStatement(sql);
            if (param != null) {
                for (int i = 0; i < param.length; i++) {
                    pstmt.setObject(i + 1, param[i]);
                }
            }
            rs = pstmt.executeQuery();
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return rs;
    }
 
public static List<Account> findAccount(String sql, Object[] param) {
        Connection con = BaseDao.getConn();
        ResultSet rs;
        rs = BaseDao.getRss(con, sql, param);
        List<Account> list = new ArrayList<Account>();
 
        try {
            while (rs.next()) {
                Account ac = new Account();
                String accountEmail = rs.getString("USERNAME");
                ac.setAccountEmail(accountEmail);
                list.add(ac);
            }
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            try {
                con.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        
        return list;
    }

.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }

代码执行时,在rs.next()处一直出错,原因是rs中没有数据。

于是乎不停的检查代码是否出错,一路调试,改变代码写法,重新在sql developer上再插入数据……无数次的修改,无济于事!!!

(3)挥泪如雨

搜索引擎搜了一遍又一遍,帖子看了一篇又一篇,方法试了一个又一个,却依然没有解决这个问题……

折腾了两天,暂时放弃了……

(4)柳暗花明

偶然一次服务器关机了,然后重启了,我再次去SELECT数据时,突然发现我的数据表是空的,瞬间明白了,什么叫COMMIT。

我竟不知道sql developer插入数据是在本地,若不提交服务器上是没有的。

下面就看一下这个千呼万唤始出来COMMIT:

just insert

JDBC连接Oracle数据库的问题

insert & commit

JDBC连接Oracle数据库的问题

就是这个commit按钮才能将数据提交到服务器。

(5)重要的事情说三遍

insert、update、delete语句一定要commit

insert、update、delete语句一定要commit

insert、update、delete语句一定要commit

JDBC连接Oracle数据库的问题的更多相关文章

  1. jdbc连接oracle数据库

    /*** 通过改变配置文件来连接不同数据库*/package com.xykj.jdbc; import static org.junit.Assert.*; import java.io.Input ...

  2. jdbc连接oracle数据库问题

    下面是JDBC连接oracle数据库流程: String dbURL = "jdbc:oracle:thin:@url:1521:service_name"; String use ...

  3. JDBC 连接Oracle 数据库,JDBC 连接Mysql 数据库

    首先是JDBC 连接Oracle  数据库 package com.util; import com.pojo.UserInfo; import java.sql.*; public class DB ...

  4. JAVA通过JDBC连接Oracle数据库详解【转载】

    JAVA通过JDBC连接Oracle数据库详解 (2011-03-15 00:10:03) 转载▼http://blog.sina.com.cn/s/blog_61da86dd0100q27w.htm ...

  5. jdbc连接oracle数据库字符串

    jdbc连接oracle数据库有两种方式: 连接数据库SID 连接数据库service_name 当连接SID时,字符串如下: url::orcl1" password="xxxx ...

  6. JDBC连接Oracle数据库时出现的ORA-12505错误及解决办法

    转载至http://www.blogjava.net/itspy/archive/2007/12/20/169072.html Oracle 问题描述:今天使用jdbc连接oracle 10.2.0. ...

  7. 简单的JDBC连接oracle数据库例子

    java连接Oracle数据库 JDBC(Java Data Base Connectivity,java数据库连接),那么我们该如何用java进行数据库的连接呢. import java.sql.C ...

  8. JDBC 连接Oracle数据库 各个对象的理解

    JDBC: 1. **代码实现:(连接oracle数据库) ​    1.导入驱动jar包 ​    2.注册驱动 ​     Class.forName("oracle.jdbc.driv ...

  9. Eclipse通过jdbc连接oracle数据库

    首先要有包 然后,在项目中加载进去- 最后就是代码了 import java.sql.*;public class GetConn {public Connection getConnection() ...

随机推荐

  1. IOS轮播图

    轮播图播放的主要技术在于: cell的封装.这里采用UICollectionViewCell实现. #import <UIKit/UIKit.h> @interface CircleVie ...

  2. NSThread 子线程 Cocoa NSOperation GCD(Grand Central Dispatch) 多线程

    单词:thread 英 θred:n 线.思路.vt 穿过.vi 穿透过 一.    进程.线程 进程:正在进行中的程序被称为进程,负责程序运行的内存分配,每一个进程都有自己独立的虚拟内存空间 线程: ...

  3. 【转载】ASP&period;NET MVC Web API 的路由选择

    此文章描述了ASP.NET Web API如何将Http请求路由到controller. 路由表 在ASP.NET Web API中,controller是用来处理HTTP请求的一个类.这个类中用于处 ...

  4. &lbrack;Storm&rsqb; java&period;io&period;FileNotFoundException&colon; File &&num;39&semi;&period;&period;&sol;stormconf&period;ser&&num;39&semi; does not exist

    This bug will kill supervisors Affects Version/s: 0.9.2-incubating, 0.9.3, 0.9.4 Fix Version/s: 0.10 ...

  5. javaBean与Map&lt&semi;String&comma;Object&gt&semi;互转

    背景:有时候想不通阿帕奇的BeanUtils是怎么进行map和Bean互相转化的. 工作闲暇之余,自己写个一小段代码,一探究竟,试试才发现,原来一切并非我们想的那么什么和复杂. 注:这里只是简单实例, ...

  6. win8系统使用Administrator用户 命令行

    windows键+X,再按A键进入管理员模式的命令提示符 输入命令:net user administrator /active:yes 然后注销,即可使用管理员账户登录

  7. c&num; 修改appConfig文件节点

    配置文件对于程序的帮助是不可小视的,尤其是java工程师们,当然了,我这里说的是c#的配置文件.废话不多说了,直接上代码了,想必大家一看就会明白了 private string UpdateConfi ...

  8. Redis 安装与简单示例 &lt&semi;第一篇&gt&semi;

    一.Redis的安装 Redis下载地址如下:https://github.com/dmajkic/redis/downloads 解压后根据自己机器的实际情况选择32位或者64位.下载解压后图片如下 ...

  9. java演示适配器&lpar;adapter&rpar;模式

    为什么要使用模式: 模式是一种做事的一种方法,也即实现某个目标的途径,或者技术. adapter模式的宗旨就是,保留现有类所提供的服务,向客户提供接口,以满足客户的需求. 类适配器:客户端定义了接口并 ...

  10. 【VxWorks系列】任务间同步与通信之信号量

    信号量是VxWorks提供的最常用,最快速的一种任务间通信机制.VxWorks中信号量有三种:二值信号量,互斥信号量,计数信号量.下面一一介绍这三种信号量的作用与区别. 信号量通常的作用就是是控制任务 ...