AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / dba / 问题

问题[sqlplus](dba)

Martin Hope
markfree
Asked: 2022-09-17 06:31:11 +0800 CST

Oracle ODBC 客户端配置缺少变量

  • 0

我正在尝试使用 unixODBC 驱动程序为 Oracle DB 配置 ODBC 连接。为此,我遵循了这个 Oracle 指南。

首先,我成功安装了 ODBC 客户端和驱动程序。

# dnf install unixODBC oracle-instantclient-sqlplus oracle-instantclient-odbc

Odbcinst 正确显示驱动程序默认值。

# odbcinst -j
unixODBC 2.3.7
DRIVERS............: /etc/odbcinst.ini
SYSTEM DATA SOURCES: /etc/odbc.ini
FILE DATA SOURCES..: /etc/ODBCDataSources
USER DATA SOURCES..: /root/.odbc.ini
SQLULEN Size.......: 8
SQLLEN Size........: 8
SQLSETPOSIROW Size.: 8

然后,指南建议使用odbc_update_ini.sh脚本配置 ODBC。

# find / -name "odbc_update_ini.sh"
/usr/lib/oracle/21/client64/bin/odbc_update_ini.sh

为此,我应该输入 <ODBCDM_Home> 作为第一个参数。

Usage: odbc_update_ini.sh <ODBCDM_Home> [<Install_Location> <Driver_Name> <DSN> <ODBCINI>]

碰巧这个脚本找不到INI文件。

# /usr/lib/oracle/21/client64/bin/odbc_update_ini.sh "/usr/local"
 *** INI file not found. Driver Manager not installed!

好像应该有一个$ODBCDM_Home环境变量集,但它并不存在,Oracle的指南也没有指导我们如何设置它。

# cat /usr/lib/oracle/21/client64/bin/odbc_update_ini.sh
(...)    
# Check whether Driver Manager is installed or not
if [ ! -f  $ODBCDM_HOME/etc/odbc.ini  -o  ! -f $ODBCDM_HOME/etc/odbcinst.ini ]
then
   echo " *** INI file not found. Driver Manager not installed!"
   exit
fi
(...)

我暂时找不到有关此问题的有意义的信息。

我现在很茫然。关于如何进行的任何想法?

oracle sqlplus
  • 1 个回答
  • 38 Views
Martin Hope
lakshman
Asked: 2022-07-27 03:21:06 +0800 CST

如何避免 SQLPlus 输出截断

  • 2

我在 oracle 数据库表中有以下列。

Column name : objectdata
Data type : LONG RAW

当我通过 sqlplus 查询此列时,输出如下所示。

SQL> select objectdata from tableA where login_id = 'xxxxxxxx';
O
-
A

这实际上应该是

Objectdata
----------------------
ACED0005737200136A617661... (very long value)

我已经尝试过 set long 10000 SET PAGESIZE 32766 SET LINESIZE 32766等。它仍然显示为截断。如何在不截断的情况下获得这个值?

oracle sqlplus
  • 1 个回答
  • 137 Views
Martin Hope
Timofey Pasichnik
Asked: 2022-06-21 23:05:24 +0800 CST

无法通过 IDE 连接到可插拔数据库

  • 0

我在computer1 上有一个Oracle XE 数据库。

当我尝试通过计算机 2 的 sqlplus 连接到它时,它对于 cdb 和 pdb 连接都可以正常工作;例如:

rlwrap sqlplus timon@//192.168.0.115:9121/xepdb1                                                                                  

SQL*Plus: Release 21.0.0.0.0 - Production on Tue Jun 21 09:40:00 2022
Version 21.6.0.0.0

Copyright (c) 1982, 2022, Oracle.  All rights reserved.

Enter password: 
Last Successful login time: Tue Jun 21 2022 09:39:11 +03:00

Connected to:
Oracle Database 18c Express Edition Release 18.0.0.0.0 - Production
Version 18.4.0.0.0

SQL> 

当我尝试通过 DataGrip IDE 连接到它时:

  • 我可以使用用户名“sys as sysdba”连接到容器数据库
  • 我无法连接到可插拔数据库 xepdb1。设置如下: 数据夹设置

错误如下:

在此处输入图像描述

我该如何解决?

oracle sqlplus
  • 1 个回答
  • 84 Views
Martin Hope
Franco
Asked: 2021-08-19 08:28:20 +0800 CST

Oracle 19c - 从挂载的备用数据库中查找主数据库信息

  • 0

我有一个(可能很简单)关于如何通过使用 sqlplus 查询已安装的备用数据库来查找 Oracle 19c 主数据库主机的查询。我可以获得如下主要名称:

select PRIMARY_DB_UNIQUE_NAME from v$database;

但是我怎样才能以类似的方式找到主节点的主机呢?

非常感谢。

正如下面与 sarat 的讨论中提到的,基于他的建议的以下 cmd 有效:

select distinct(machine) from v$session where username='PUBLIC' and osuser='oracle' and machine <> (select PRIMARY_DB_UNIQUE_NAME from v$database);

但我需要在输出中添加一个前导标题,以便之后从假脱机文件中获取结果。

select 'title'||distinct(machine) from v$session where username='PUBLIC' and osuser='oracle' and machine <> (select PRIMARY_DB_UNIQUE_NAME from v$database)

这失败了吗?有什么办法吗?谢谢。

sqlplus oracle-19c
  • 2 个回答
  • 357 Views
Martin Hope
Sankama
Asked: 2021-05-05 07:24:09 +0800 CST

在 SPFILE 中设置参数仍然输出相同的错误

  • 0

对于SAP IDM系统的安装,我需要知道如何alter system set "_ORACLE_SCRIPT"=true SCOPE=SPFILE;正确使用command命令。

安装会创建一个用户并给出错误ORA-65096: "invalid common user or role name"。在研究过程中,我发现了 command alter session set "_ORACLE_SCRIPT"=true。该命令允许临时创建用户。在下一个会话或在单独的终端中,这不再可能。

在$ORACLE_HOME/dbs/spfile.ora参数*_oracle_script=true中,但它再次给了我同样的错误。

先感谢您。

-Sruscht

sqlplus oracle-18c
  • 1 个回答
  • 143 Views
Martin Hope
Janmenjoy Roy
Asked: 2021-03-17 08:29:04 +0800 CST

当侦听器设置为主机 IP 地址时,与 Oracle DB 19c 的连接失败

  • 0

我是 Oracle DB 的新手,需要帮助解决以下问题。

我正在使用sqlplus (SQL*Plus: Version 21.1.0.0.0) 连接到Oracle DB 19c。

声明:当我将文件中的 IP 更改为“ ”时,我可以从192.168.0.109主机(如下:192.168.0.108192.168.0.1060.0.0.0localhostlistener.ora

LISTENER =
  (DESCRIPTION_LIST =
    (DESCRIPTION =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 0.0.0.0)(PORT = 1521))
      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
    )
  )

面临的问题:当我将文件中的 IP 更改为主机 IP ( )时,无法从 VM ( 192.168.0.108) 或 LAN ( ) 中的其他系统进行连接。请在下面找到修改:192.168.0.106192.168.0.109listener.oralistener.ora

LISTENER =
  (DESCRIPTION_LIST =
    (DESCRIPTION =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.0.109)(PORT = 1521))
      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
    )
  )

错误详情: sqlplus工具报错如下:

ORA-12514: TNS:listener does not currently know of service requested in connect descriptor

现在,让我也分享一下tnsnames.ora文件的内容(如果需要):

LISTENER_POLA =
(ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))


ORACLR_CONNECTION_DATA =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
    )
    (CONNECT_DATA =
      (SID = CLRExtProc)
      (PRESENTATION = RO)
    )
  )

POLA =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = pola)
    )
  )

更多细节:

  1. Oracle DB 所在的主机 (192.168.0.109) 可从包括 VM 在内的所有其他系统访问
  2. telnet 192.168.0.109 1521所有系统都显示它已连接。
  3. VM 在 Oracle Virtual Box 6.1 上运行并配置为桥接模式。
  4. Oracle DB 19c 和 VM 在 Windows Server 2016 之上运行。

查询: 当listener.ora文件配置了主机系统的IP地址(192.168.0.109)时,我需要做哪些配置才能使sqlplus可以从同一局域网内的任何系统连接到Oracle DB?

LSNRCTL 状态的输出:

LSNRCTL for 64-bit Windows: Version 19.0.0.0.0 - Production on 16-MAR-2021 23:18:31

Copyright (c) 1991, 2019, Oracle.  All rights reserved.

Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=192.168.0.109)(PORT=1521)))
STATUS of the LISTENER
------------------------
Alias                     LISTENER
Version                   TNSLSNR for 64-bit Windows: Version 19.0.0.0.0 - Production
Start Date                16-MAR-2021 23:16:07
Uptime                    0 days 0 hr. 2 min. 23 sec
Trace Level               off
Security                  ON: Local OS Authentication
SNMP                      OFF
Listener Parameter File   C:\Polarbear\WINDOWS.X64_193000_db_home\network\admin\listener.ora
Listener Log File         C:\Polarbear\diag\tnslsnr\WIN-4SO5O8T8UJ6\listener\alert\log.xml
Listening Endpoints Summary...
  (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=192.168.0.109)(PORT=1521)))
  (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(PIPENAME=\\.\pipe\EXTPROC1521ipc)))
Services Summary...
Service "CLRExtProc" has 1 instance(s).
  Instance "CLRExtProc", status UNKNOWN, has 1 handler(s) for this service...
The command completed successfully

命令 sqlplus / as sysdba 的输出:

SQL*Plus: Release 19.0.0.0.0 - Production on Wed Mar 17 00:00:29 2021
Version 19.3.0.0.0

Copyright (c) 1982, 2019, Oracle.  All rights reserved.


Connected to:
Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
Version 19.3.0.0.0

SQL> select count(*) from dba_tables;

  COUNT(*)
----------
      2182
sqlplus listener
  • 1 个回答
  • 1231 Views
Martin Hope
H P
Asked: 2021-01-12 10:56:15 +0800 CST

使用 sqlplus 删除的数据仍显示在 SQL Developer 中 [重复]

  • 0
这个问题在这里已经有了答案:
为什么 SQL Developer 中不显示行数据? (1 个回答)
去年关闭。

我编写了一个使用 SQLPlus 运行的脚本,它删除了我的 Oracle XE 数据库中前 7 天的数据。我使用 SQLPlus 登录数据库,运行脚本,它显示正确的行已被删除。我试图再次查询相同的日期范围以确保查询没有返回任何结果(即记录已被删除)。

但是,当我使用 Oracle SQL Manager 连接到数据库时,我可以转到同一个表,并且所有数据仍然存在!如果我在 SQL 管理器中运行查询,它会从 SQL 管理器的表中删除。

有谁知道为什么会这样?我用于登录的凭据在两个实例中都是相同的,并且我确保在运行 SQLPlus 时从 SQL 管理器中注销,反之亦然。我正在运行 XE 数据库的 18c 版本。

oracle sqlplus
  • 1 个回答
  • 364 Views
Martin Hope
radicaled
Asked: 2020-09-09 04:34:11 +0800 CST

SQLPlus 配置问题或防火墙问题

  • 0

我需要连接到远程 Oracle 数据库,所以我请求打开 1521 端口上的防火墙到数据库和副本。

[root@ansible-test ~]$ telnet <oracle_db_active> 1521
Trying <oracle_db_active>...
Connected to <oracle_db_active>.
Escape character is '^]'.

^CConnection closed by foreign host.

[root@ansible-test ~]$ telnet <oracle_db_replica> 1521
Trying <oracle_db_replica>...
Connected to <oracle_db_replica>.
Escape character is '^]'.

^CConnection closed by foreign host.

我可以远程登录到端口 1521 上的数据库。
但是当我尝试使用 SQLPlus 连接时,由于主机不存在,我得到一个错误。

[root@ansible-test ~]$ echo exit |sqlplus "<user>/<pass> @(DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = <oracle_db_active>)(PORT = 1521))(ADDRESS = (PROTOCOL = TCP)(HOST = <oracle_db_replica>)(PORT = 1521))(CONNECT_DATA = (SERVER = DEDICATED)(SERVICE_NAME = <service>)(FAILOVER_MODE = (TYPE = SELECT)(METHOD = BASIC)(RETRIES = 12)(DELAY = 5))))"

SQL*Plus: Release 19.0.0.0.0 - Production on Mon Sep 7 17:37:23 2020
Version 19.8.0.0.0

Copyright (c) 1982, 2020, Oracle.  All rights reserved.

ERROR:
ORA-12545: Connect failed because target host or object does not exist


Enter user-name: Enter password:
ERROR:
ORA-12162: TNS:net service name is incorrectly specified

我在与数据库相同的网络中有另一台服务器,并且可以使用相同的字符串进行连接。
我没有在任何服务器上配置 sql.ora 或 tnsname.ora。
两台服务器的唯一区别是一台是RedHat,另一台是centos。

我是否需要向数据库打开任何其他端口,这是配置问题吗?

谢谢(对不起所有的编辑)

oracle sqlplus
  • 2 个回答
  • 281 Views
Martin Hope
Khang Mai
Asked: 2019-11-12 06:07:58 +0800 CST

无法使用 sqlplus 将数据库作为 sys 连接为 sysdba

  • 3

我是 oracle server 18c 的新手(目前正在学习在线课程)。我的问题是 sql*plus 我尝试使用 sqlplus 然后 sys 作为 sysdba (它不起作用)并且错误出现在下面。 在此处输入图像描述

但是,如果我使用 sqlplus / as sysdba (它工作,我不知道为什么) 在此处输入图像描述

我试过这个命令:lsnrctl start,但还是不行。另外,我检查了我的 listener.ora 和 tnsnames.oraca 在此处输入图像描述 在此处输入图像描述

我已在 .bash_profile 中附加了我的环境设置 在此处输入图像描述

请帮帮我。谢谢

oracle sqlplus
  • 1 个回答
  • 21451 Views
Martin Hope
Max
Asked: 2019-10-10 00:20:03 +0800 CST

如何从运行脚本访问传递给 SQL*Plus 的 TNS 连接标识符以进行重新连接?

  • 1

我想知道如何在 SQL 脚本中使用 TNS 标识符。在这个例子中

$ sqlplus MY_USER/pswd@TNSID @script.sql par1 par2

我想获取 TNSID 作为字符串以便从中使用它,script.sql但我不知道在哪里可以找到它。

目标是作为同一实例上的不同用户重新连接。

oracle sqlplus
  • 2 个回答
  • 179 Views

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    连接到 PostgreSQL 服务器:致命:主机没有 pg_hba.conf 条目

    • 12 个回答
  • Marko Smith

    如何让sqlplus的输出出现在一行中?

    • 3 个回答
  • Marko Smith

    选择具有最大日期或最晚日期的日期

    • 3 个回答
  • Marko Smith

    如何列出 PostgreSQL 中的所有模式?

    • 4 个回答
  • Marko Smith

    列出指定表的所有列

    • 5 个回答
  • Marko Smith

    如何在不修改我自己的 tnsnames.ora 的情况下使用 sqlplus 连接到位于另一台主机上的 Oracle 数据库

    • 4 个回答
  • Marko Smith

    你如何mysqldump特定的表?

    • 4 个回答
  • Marko Smith

    使用 psql 列出数据库权限

    • 10 个回答
  • Marko Smith

    如何从 PostgreSQL 中的选择查询中将值插入表中?

    • 4 个回答
  • Marko Smith

    如何使用 psql 列出所有数据库和表?

    • 7 个回答
  • Martin Hope
    Jin 连接到 PostgreSQL 服务器:致命:主机没有 pg_hba.conf 条目 2014-12-02 02:54:58 +0800 CST
  • Martin Hope
    Stéphane 如何列出 PostgreSQL 中的所有模式? 2013-04-16 11:19:16 +0800 CST
  • Martin Hope
    Mike Walsh 为什么事务日志不断增长或空间不足? 2012-12-05 18:11:22 +0800 CST
  • Martin Hope
    Stephane Rolland 列出指定表的所有列 2012-08-14 04:44:44 +0800 CST
  • Martin Hope
    haxney MySQL 能否合理地对数十亿行执行查询? 2012-07-03 11:36:13 +0800 CST
  • Martin Hope
    qazwsx 如何监控大型 .sql 文件的导入进度? 2012-05-03 08:54:41 +0800 CST
  • Martin Hope
    markdorison 你如何mysqldump特定的表? 2011-12-17 12:39:37 +0800 CST
  • Martin Hope
    Jonas 如何使用 psql 对 SQL 查询进行计时? 2011-06-04 02:22:54 +0800 CST
  • Martin Hope
    Jonas 如何从 PostgreSQL 中的选择查询中将值插入表中? 2011-05-28 00:33:05 +0800 CST
  • Martin Hope
    Jonas 如何使用 psql 列出所有数据库和表? 2011-02-18 00:45:49 +0800 CST

热门标签

sql-server mysql postgresql sql-server-2014 sql-server-2016 oracle sql-server-2008 database-design query-performance sql-server-2017

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve