【Oracle连接】java.sql.SQLException: Listener refused the connection with the following error: ORA-12505

article/2025/9/24 9:10:01

连接数据库时,提示错误描述:

java.sql.SQLException: Listener refused the connection with the following error: ORA-12505, TNS:listener does not currently know of SID given in connect descriptor

问题描述:情况使用帆软报表连接数据库时,提示数据库连接失败,但是用Navicat工具连接同一个数据库时,却没有问题,不会提示报错。

后面看到有人说,错误重点是:listener does not currently know of SID given in connect descriptor

以及强调:SID != SERVICE_NAME

查询数据库的SID,发现数据库的SID确实变了,不一样,导致连接错误,更换连接的SID,就可以解决。

查询数据库的SID:

select instance_name from V$instance

 问题原因:关于JDBC连接ORACLE的三种格式方法:

格式一: Oracle JDBC Thin using an SID

标准:jdbc:oracle:thin:@<host>:<port>:<SID>

举例:jdbc:oracle:thin:@localhost:1521:orcl

查询数据库的SID的方法语句:
--查SID
select value from v$parameter where name='instance_name';

格式二: Oracle JDBC Thin using a ServiceName

标准:jdbc:oracle:thin:@//<host>:<port>/<service_name>

举例:jdbc:oracle:thin:@//localhost:1521/orcl.huizxxxx.com 

查询数据库的ServiceName的方法语句:
--查ServiceName

select value from v$parameter where name='service_names';

格式三:Oracle JDBC Thin using a TNSName

标准:jdbc:oracle:thin:@<TNSName>

举例:jdbc:oracle:thin:@TNS_ALIAS_NAME

配置如下:jdbc:oracle:thin:@(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=localhost)(PORT=1521)))(CONNECT_DATA=(SERVICE_NAME=or12c2)))

注意:使用第三中的数据库连接时,好像是不能用超级管理员的用户名和密码,需要用管理员,用超级管理员的账号密码使用链接时,会报错。

后来创建个新用户和账号,来访问数据库,数据库连接,可以正常使用

 

实例与数据库之间的关系:

实例是操作系统中访问数据库所需要的一系列的进程和内存的集合。即使没有任何数据文件,实例也可以启动。但是要想访问数据库,必须把数据库文件加载进实例中。实例和数据库的区别可以简单概括为:实例是临时的,它只在相关的进程和内存集合存在时存在,而数据库是永久的,只要文件存在它就存在。一个实例只能对应一个数据库,但是一个数据库可以有多个实例。

 SID即INSTANCE_NAME是用来唯一标示实例的。

参考文献链接:https://blog.csdn.net/zhangzl1012/article/details/50752572

 

 

 


http://chatgpt.dhexx.cn/article/1JQVf7od.shtml

相关文章

ORA-12505:TNS:listener does not currently know of SID given in connect descriptor

Oracle安装好之后&#xff0c;默认的listener是localhost&#xff0c;现在为了在局域网内能够访问&#xff0c;其他电脑访问的时候&#xff0c;提示如下错误&#xff1a; ORA-12505&#xff1a;TNS:listener does not currently know of SID given in connect descriptor。 修…

ORA-12505:TNS: 监听程序当前无法识别连接描述符中所给出的 SID

问题描述&#xff1a; 小学期修Oracle课程&#xff0c;为了小团队的便利性&#xff0c;在腾讯云中使用Docker创建了Oracle容器进行共享&#xff0c;在这段时间使用是正常的。在一两个星期后使用nacicat连接oracle时&#xff0c;报了ORA-12505&#xff1a;TNS: 监听程序当前无法…

ORA-12505, TNS:listener does not currently know of SID given in connect descriptor解决方式

启动项目连接oracle数据报&#xff1a;ORA-12505, TNS:listener does not currently know of SID given in connect descriptor ORA-12505: TNS: 监听程序当前无法识别连接描述符中所给出的SID 报错原因&#xff1a;通过报错内容 “TNS:listener does not currently know of …

ORA-12505

oracle 数据库&#xff0c;用sqldeveloper 打开报了 ORA-12505: TNS:listener does not currently know of SID given in connect descriptor&#xff1b; 先通过sqlplus\命令行, 查看当前正在使用的数据库实例及主机名 SQL>conn/as sysdba SQL>select instance_name fr…

关于oracle连接ORA-12505错误的直观解决方法

oracle连接一直好好的&#xff0c;突然间连接的时候报错了&#xff0c;报错为ORA-12505, TNS:listener does not currently know of SID given in connect descriptor 。网上找了好长时间也没解决。现在将个人的解决方法分享出来&#xff0c;大家有什么不同意见的&#xff0c;…

ORA-12505: TNS: 监听程序当前无法识别连接描述符中所给出的SID等错误解决方法【连接本机】

遇到这个问题首先考虑检查配置文件listener.ora和tnsnames.ora。 1 listener.ora文件 获取电脑主机名称&#xff1a;可通过dba登录sqlplus利用 select HOST_NAME from v$instance; 语句查询主机名 模板如下&#xff1a; SID_LIST_LISTENER (SID_LIST (SID_DESC (SID_NAM…

【Navicat】连接Oracle报错 ORA-12505

文章目录 一、错误描述1.1、Navicat连接Oracle错误码&#xff1a; ORA-125051.2、Oralce数据库版本1.3、Navicat版本 二、分析2.1、排查 ORA-12505 错误码含义2.2 排查windowns 服务 三、解决方案3.1、下载 Oracle 的instant-client服务3.2、 解压到合适的位置3.3、配置Navicat…

ora 12505

报错为ORA-12505, TNS:listener does not currently know of SID given in connect descriptor 。具体步骤如下; 1、首先先检查检查自己的数据库配置部分时候有错&#xff0c;正确配置如下图 错误配置&#xff1a; 可能是后面的参数导致的。 2、Oracle的 listener.ora 文件配…

俄罗斯方块源码(彩色版)

此程序使用C语言简单实现了俄罗瑟方块主要的游戏功能&#xff08;包含统计得分、速度等级设置、下一方块提示&#xff09;&#xff0c;还有简单的消除特效。 使用的编译器为&#xff1a;Visual Studio 2022 效果图&#xff1a; 主要缺点&#xff1a; 1&#xff1a;代码较长 …

html 小游戏 俄罗斯方块

样式如下&#xff1a; html代码如下&#xff1a; <!DOCTYPE html> <html><head><meta http-equiv"Content-Type" content"text/html; charsetutf-8"/><title>俄罗斯方块</title><style>body, div, dl, dt, dd…

Javascript 俄罗斯方块 游戏代码

本俄罗斯方块代码采用 JavaScript 脚本代码写成&#xff0c;简单易懂&#xff1b; 全代码采用静态类及静态变量成员组成&#xff1b; 全脚本通过实现代码全局配置 OLSFK.Options {...} 定义方块起始坐标及定义各自的旋转点&#xff1b; 从初始化俄罗斯方块界面开始&#x…

C语言实现俄罗斯方块代码

这里为大家敲写一段怎样用C语言实现俄罗斯方块&#xff1a; 首先推荐大家使用CodeBlocks这个软件&#xff0c;方便添加不同的工程。 代码中有很多注释便于理解&#xff01; 下面是效果图和全部的代码以及注释&#xff0c;大家可以观看并自己新增内容&#xff01; 1&#xff1a;…

android俄罗斯方块完整代码

这段时间一直没有更新自己的博客,很多东西不经常看看会生疏了许多。在这里我就把自己前段时间编写的android俄罗斯方块代码贴出来。 转载请注明出处~~~~~~~~~~~~~~~~谢谢! http://blog.csdn.net/wu10045125/article/details/8248356 再贴出几张图片: 整个游戏我分为10个jav…

俄罗斯方块-C语言-完整代码

效果图如下 #ifndef _DAY7_H #define _DAY7_H #include<windows.h> #include<time.h> #include<stdbool.h> #include<conio.h>//控制台输入输出函数getch通过键盘进行的操作 //游戏区域位置设计 #define COL_BEGIN 2 #define COL_END 14 #define ROW_…

C语言俄罗斯方块(新版本完整代码)

2020博客之星年度总评选进行中&#xff1a;请为74号的狗子投上宝贵的一票&#xff01; 我的投票地址&#xff1a;点击为我投票 写在前面&#xff1a; 大家好&#xff0c;我是 花狗Fdog &#xff0c;来自内蒙古的一个小城市&#xff0c;目前在泰州读书。 很感谢能有这样一个平台…

HTML5俄罗斯方块网页游戏代码

HTML5俄罗斯方块网页游戏代码 非常好用 代码如下 注意 把所有文件放在一个文件夹里! 把所有css文件夹里,命名css 把所有js文件夹里,命名js 先看index.html <!DOCTYPE html> <html> <head><meta charset"utf-8"><title>俄罗斯方块…

俄罗斯方块C++语言代码

大家都知道俄罗斯方块&#xff0c;就是控制不同的方块旋转&#xff0c;通过摆满一行方块消除得分&#xff0c;今天就让我们用C制作一个俄罗斯方块小游戏。 首先定义方块&#xff1a; int block00[4][4] { { 10,0,0,0 },{ 1,1,1,1 },{ 0,0,0,0 },{ 0,0,0,0 } }; int block01[…

c++俄罗斯方块 完整源代码

文章目录 1. 功能描述2. 源代码3. 运行截图4. 结尾 1. 功能描述 2. 源代码 #include<iostream> #include<string> #include<cstdlib> #include<windows.h> #include<ctime> #include<conio.h> #include<cstdio> using namespace st…

俄罗斯方块游戏代码

♥️作者&#xff1a;小刘在C站 ♥️个人主页&#xff1a;小刘主页 ♥️每天分享云计算网络运维课堂笔记&#xff0c;努力不一定有回报&#xff0c;但一定会有收获加油&#xff01;一起努力&#xff0c;共赴美好人生&#xff01; ♥️夕阳下&#xff0c;是最美的&#xff0c;绽…

C语言实现俄罗斯方块

目录 一、游戏效果展示 二、完整代码&#xff0c;可以直接拷贝运行 三、所需开发环境 四、具体项目实现 ①游戏欢迎界面 welcome( ) ②游戏背景 initGameScreen( ) ③方块表示 int block[ ][ ][ ] ④新方块表示nextBlock( ) ⑤设计游戏循环main( ) ⑥搭建用户操作框…