Определение наличия установленной базы данных Oracle

Мне было интересно, есть ли способ узнать, установлена ​​ли база данных в экземпляре Oracle в системе или нет?

Это для сценария установки, и мне нужно убедиться, что существует действующая база данных, прежде чем продолжить загрузку моего собственного табличного пространства в эту базу данных. Кто-нибудь раньше занимался этой проблемой?

Ваше здоровье

Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
8
0
27 589
5
Перейти к ответу Данный вопрос помечен как решенный

Ответы 5

Вы можете использовать tnsping, чтобы проверить, активен ли слушатель базы данных, это будет хорошим показателем. Кроме того, почему бы просто не выполнить тестовое соединение? Если это часть процесса установки, вы можете предложить пользователю ввести соответствующие учетные данные для подключения, если вы не знаете, какими они будут заранее.

Ответ принят как подходящий

Проверьте наличие ORACLE_HOME. Также разумно ожидать, что эта среда должна быть настроена для установки, поэтому тестирование переменных среды и выход с разумной диагностикой (возможно, предполагающей, что они запускают oraenv) - хороший первый старт. Если у вас есть ORACLE_HOME, ORACLE_SID или другая соответствующая переменная среды, вы можете затем проверить наличие дома оракула и проверить возможность подключения к базе данных и разрешений.

Я только что проверил, у меня нет ORACLE_HOME или ORACLE_SID, и я могу без проблем подключаться к базам данных Oracle.

ninesided 03.12.2008 02:59

Если у вас есть мгновенный клиент, вам не нужен oracle home ... строка подключения может быть встроена прямо в приложение и не требует oracle home или tsnames.ora

jle 19.06.2009 06:35

Я думаю, что OP говорил о сервере - у вас может быть мгновенный клиент на ПК, но сервер все равно будет иметь дом оракула для экземпляра базы данных.

ConcernedOfTunbridgeWells 19.06.2009 12:36

Для Oracle 10g в Windows:

  • Проверить реестр:
    • Ключ HKLM\SOFTWARE\ORACLE должен существовать.
    • Должен существовать подключ, который:
      • Имеет имя, начинающееся с KEY_ (например, KEY_OraDb10g_home1, где конечная строка является домашним именем Oracle).
      • Имеет значение, имя которого начинается с ORA_ и заканчивается на _AUTOSTART. (например, ORA_XE_AUTOSTART, средняя строка - имя экземпляра).

Будьте осторожны, установка клиента Oracle (тогда без экземпляра базы данных) создает записи в реестре и может устанавливать переменные среды (например, ORACLE_HOME). Вот почему приведенный выше шаблон немного сложен.

Этот шаблон, скорее всего, также будет работать для Oracle 9i и, возможно, Oracle 8i.

+1 к дорожной карте. Клиентское программное обеспечение Win32 Oracle при установке создает огромное количество мусора в реестре.

ConcernedOfTunbridgeWells 08.12.2008 16:27

@Mac Я попытался проверить реестр, используя следующий оператор (C#): var swSubkeys = (Registry.LocalMachine.OpenSubKey («Программное обеспечение»)). GetSubKeyName‌ s ();, но в swSubKeys (массив строк) нет записи ORACLE. Поэтому я проверяю использование Regedit вручную, очевидно, что подраздел ORACLE существует в HKLM \ SOFTWARE ... Это очень запутано.

MagB 09.07.2014 10:59

Найдите файл / etc / oratab для домов oracle. В этих домах установлено программное обеспечение базы данных, а также имя базы данных из этого дома. Затем вы можете проверить, исправна ли база данных, запустив ее.

Я не уверен насчет Oracle, но для MySQL и PostgreSql я делаю следующее:

$yum grouplist | grep SQL

Это возвращает:

MySQL Database client
MySQL Database server
PostgreSQL Database client
PostgreSQL Database server

Я полагаю, вам стоит попробовать:

$yum grouplist | grep Orac

Другие вопросы по теме