最近接触oracle有点多,同时也在配置数据库连接池,坑也就踩多了,记录下。

  事情还没有结束,没时间记录问题,很多事情都忘了,过了国庆再写的话可能就真的全忘了吧……而且不单单是数据库问题,还有一些数据库连接池等等的问题。

  先写有关数据库的吧。

一、Navicat连接远端oracle需要配置合适的驱动

  我用Navicat的时候还用的是plsql,连plsql并没有踩什么坑(或者是我自己忘了),所以连接oracle的时候并没有做特殊的配置,然后每次一连接就闪退,我只当是自己填错账号密码没有深究。然后后面查了查教程,需要配置oci。

  先确认你想要连接的oracle的版本,再下载版本对应的驱动

  然后进入Navicat中,选择工具-选项-环境,然后设置oci环境如下,选择自己下载的驱动下面的oci.dll,然后重启Navicat就可以生效了

  

  同时,如果没有配置好oci环境也会报“navicat is not able to create OCI handles”的错误。

二、java.sql.SQLException: 未调用 ResultSet.next

  这种情况,即使你使用java程序查询oracle程序时返回的只有一条数据,也必须使用result.next(),譬如:

if(result.next()){
int count = result.getInt(1);
}

三、查询某个表格是否存在

  我需要使用的是java确定远端oracle中是否有我需要的那张表格存在,有就继续后续的查询操作。根据https://blog.csdn.net/lmb55/article/details/54837719所给的方案得到了解决。

  主要有两个思考方向,一是s可用的sql语句。我在网上查到了很多说法,知道数据库中是有一张表格保存了数据库中所有表的信息,比如表名、拥有者等信息的,但是他们所给的表在我所连接的数据库中都是空表,可能不同的数据库设置问题导致表格也不同,而且也需要确定你的账号有没有访问这张表格的权限。

  我最终找到了结果(注意表名和拥有者作为查询的字符串条件时是区分大小写的,我一开始就因为这个原因屡次出问题):

  

select * from all_tables WHERE upper(OWNER) LIKE '表的拥有者的大写' AND upper(TABLE_NAME) LIKE '表名的大写';

  第二个方法是别人提供的java方法,但是我这里返回结果是不对的,一直是不存在:

ResultSet rs = con.getMetaData().getTables(null, null, tableName, null);
if (rs.next()) {
return true;
}else {
return false;
}

java连数据库和数据库连接池踩坑日记(一)-------oracle连接的一些问题的更多相关文章

  1. java连数据库和数据库连接池踩坑日记(二)-------数据库连接池c3p0

    关于数据库连接池,我觉得有些沮丧,因为最后被毙掉了说不用考虑多线程的问题…… 数据库连接池的推荐:https://www.cnblogs.com/nuccch/p/8120349.html 我最终选择 ...

  2. JAVA和C#中数据库连接池原理与应用

    JAVA和C#中数据库连接池原理 在现在的互联网发展中,高并发成为了主流,而最关键的部分就是对数据库操作和访问,在现在的互联网发展中,ORM框架曾出不穷, 比如:.Net-Core的EFCore.Sq ...

  3. AI相关 TensorFlow -卷积神经网络 踩坑日记之一

    上次写完粗浅的BP算法 介绍 本来应该继续把 卷积神经网络算法写一下的 但是最近一直在踩 TensorFlow的坑.所以就先跳过算法介绍直接来应用场景,原谅我吧. TensorFlow 介绍 TF是g ...

  4. 人工智能(AI)库TensorFlow 踩坑日记之一

    上次写完粗浅的BP算法 介绍 本来应该继续把 卷积神经网络算法写一下的 但是最近一直在踩 TensorFlow的坑.所以就先跳过算法介绍直接来应用场景,原谅我吧. TensorFlow 介绍 TF是g ...

  5. hexo博客谷歌百度收录踩坑日记

    title: hexo博客谷歌百度收录踩坑日记 toc: false date: 2018-04-17 00:09:38 百度收录文件验证 无论怎么把渲染关掉或者render_skip都说我的格式错误 ...

  6. Hexo搭建静态博客踩坑日记(二)

    前言 Hexo搭建静态博客踩坑日记(一), 我们说到利用Hexo快速搭建静态博客. 这节我们就来说一下主题的问题与主题的基本修改操作. 起步 chrome github hexo git node.j ...

  7. Hexo搭建静态博客踩坑日记(一)

    前言 博客折腾一次就好, 找一个适合自己的博客平台, 专注于内容进行提升. 方式一: 自己买服务器, 域名, 写前端, 后端(前后分离最折腾, 不分离还好一点)... 方式二: 利用Hexo, Hug ...

  8. 【Java进阶】——初识数据库连接池

    [简介] 数据库连接池:程序启动时建立足够的数据库连接,并将这些连接组成一个连接池,由程序动态地对池中的链接进行申请,使用,释放. 相比之前的程序连接,减少了数据库的打开关闭次数,从而减少了程序响应的 ...

  9. java 利用c3p0管理数据库连接池

    数据库连接池类,用于获取数据库连接.利用单例模式保证所有的连接都只通过一个连接池管理. package com.mousewheel.dbcon; import java.io.InputStream ...

随机推荐

  1. 使用jQuery开发dialog对话框插件

    1.插件使用 首先引入 jquery 库,然后引入 dialog.js.dialog.css,如下: <script type="text/javascript" src=& ...

  2. PHP导出XML格式的EXCEL

    <?php function Export(){ set_time_limit(0); ob_start(); $biz = new ZaikuBiz(); $biz->setSearch ...

  3. 【OO学习】OO第三单元作业总结

    [OO学习]OO第三单元作业总结 第三单元,我们学习了JML语言,用来进行形式化设计.本单元包括三次作业,通过给定的JML来实行了一个对路径的管理系统,最后完成了一个地铁系统,来管理不同的线路,求得关 ...

  4. 【转载】C#中Add方法将往List集合末尾添加相应元素对象

    在C#的List集合操作中,有时候需要将符合条件的对象添加到已有List集合中的末尾,此时就需要使用到List集合的Add方法,Add方法的作用为将对应的元素添加到List集合末尾,Add方法签名为v ...

  5. element-ui日期筛选:选择日期即触发查询

    需求:日期范围选择器,当选择好一个日期范围时,立即触发查询功能 <el-date-picker v-model="dateVal" type="daterange& ...

  6. React Native 开发豆瓣评分(六)添加字体图标

    添加依赖 yarn add react-native-vector-icons Link 依赖 react-native link react-native-vector-icons 使用默认字体图标 ...

  7. DBA面对新mysql环境

    来源:http://blog.csdn.net/wyzxg/article/details/8491152 author:skatetime:2013/01/10 DBA面对新MySQL环境感悟 1. ...

  8. php数组,常量,遍历等

    php常量,常量是不能被改变的,由英文字母,下划线,和数字组成,但是数字不能作为首字母出现. bool define ( string $name , mixed $value [, bool $ca ...

  9. System V共享内存

    目录 1. 概述 2. System V共享内存API shmget shmat shmdt shmctl 3. 简单的程序 代码实现 common.h shmcreate.c shmrmid.c s ...

  10. java请求url可以带参数

    /** * * @param urlStr * url * @param content * 提交的参数 * @param encoding * 编码格式 * @return */ public st ...