Instance состоит из:
SGA (System Global Area), которая обеспечивает коммуникацию между процессами;
до пяти (в последних версиях больше) бэкграундовых процессов.
От себя добавлю – database включает в себя tablespace, tablespace включает в себя segments (в одном файле данных может быть один или несколько сегментов, сегменты не могут быть разделены на несколько файлов). segments включают в себя extents.
Как заставить Oracle анализировать все таблицы базы данных?
Nomadicотвечает:
Конечно, можно использовать DBMS_SQL, DBMS_JOB…
А можно и так:
#!/bin/sh
#
# Analyze all tables
#
SQLFILE=/tmp/analyze.sql LOGFILE=/tmp/analyze.log
echo @connect dbo/passwd@> $SQLFILE
$ORACLE_HOME/bin/svrmgrl <> $SQLFILE
connect dbo/passwd
SELECT 'TABLE', TABLE_NAME FROM all_tables WHERE owner = 'DBO';
EOF
echo exit>> $SQLFILE
cat $SQLFILE> $LOGFILE
cat $SQLFILE | $ORACLE_HOME/bin/svrmgrl>> $LOGFILE
cat $LOGFILE | /usr/bin/mailx –s 'Analyze tables' tlk@nbd.kis.ru
rm $SQLFILE rm $LOGFILE
В режиме отладки приложения не разрешается доступ (открытие) базы данных. Как лечить?
Nomadicотвечает:
Необходимо отключить (деинсталлировать через Oracle Installer) Trace Service на клиенте – совет от ORACLE.
Глюк имеет место быть только под Windows NT 4.xx.
Подскажите, как на Oracle 7.3.2.3 (Solaris x86) поменять compatible на 7.3.2.3 (c 7.1.0.0)?
Nomadicотвечает:
Ставить в initmybase.ora
compatible = "7.3.2.3"
и после старта с новым параметром сделать
ALTER DATABASE RESET COMPABILITY;
И рестартовать базу.
Как настроить Personal Oracle с русским языком на корректную работу с числами и BDE?
Nomadicотвечает:
прописать в \HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE параметр:
NLS_NUMERIC_CHARACTERS = '.,'
или
после соединения с ORACLE выполнить
ALTER SESSION SET NLS_NUMERIC_CHARACTERS = '.,'
Как в Oracle создать sequence с некоторого номера?
Nomadicотвечает:
create sequence minvalue 10;
Как решать некоторые вопросы при подключении к Oracle?
Nomadicотвечает:
DD> 1. Все поля (TField), определенные в формах, имеющие типы TDateField,
DD> TSmallIntField – при открытии таблицы ругаются: Field «…» is not of
DD> expected type. Посмотрел – при переопределении их под Oracle'ом они
Чтобы «увидеть» integer-поля нужно в настройке Alias'а Oracle в BDE установить Enable Integers→True (и напрочь будет потерян Locate по этим якобы int/smallint полям). С датами, возможно, тоже надо разбираться через настройки Win & Oracle. У меня в Win дата формата «дд.мм.гггг», в Oracle NLS_LANG→AMERICAN_AMERICA.CL8MSWIN1251 и с датами все гут.
DD> 2. Используя в SQL
DD> строки типа 'SELECT XX FROM YY WHERE XX="QQQ"' мы поступали
DD> неправильно,
DD> т.к. двойные кавычки в Oracle обрабатываются не так, как в Btrieve.
Oracle в данном случае не при чем. Это глюк BDE. Лечилось просто – вместо обрамления двойными кавычками строкового значения, нужно обрамлять его с помощью #39, примерно так
MySQLString := 'SELECT XX FROM YY WHERE XX='+#39+'QQQ'+#39;
Belsky Roman
(2:450/94.75)
SS> У кого-нибудь есть опыт по настройке BDE? Откликнитесь плиз! При
SS> попытке соединиться с базой вылезает ошибка: Vendor failed init!
SS> Delphi запускаю под 95. Hа всякий случай пути к \BDE и ORAWIN\BIN я
SS> проставил! orant71.dll (родной или переименнованый ora72win.dll)
SS> закидывал куда угодно, но… все равно вылетает ошибка BDE Error
SS> 15879 Vendor failed init :-(
Клиент у тебя NT, как я понял?
• ora7x.dll – 32bit клиент для win95
• orant7x.dll – 32bit клиент для NT
• ora7xwin.dll – 16bit клиент для win
т.е. ora7xwin в Delphi3 вообще ставить бесполезно (16bit для 32bit appl). ora*71.dll у меня изначально к ORACLE 7.2 не коннектился – они там как-то резко сменили OCI. Правда потом ora72win.dll с Personal Oracle 7.3 работал, но все равно лучше, наверное, чтобы номер версии dll был не ниже версии сервера.
А вообще я 32bit дельфях в Vendor Init давно прописываю OCIW32.dll – он всегда для последней версии сервера с которым ты работаешь.
Это IMHO. Hо у меня Delphi3 и Delphi1 коннектятся как с Oracle 7.1 на Unix'е, так и с Personal Oracle 7.3
WindowsNT 4.0 + Delphi 2.01 C/S + Oracle Client 7.3 + Oracle Server 7.3. После логина в базу данных возникает `EExternalError 0xC0000008`. Что делать?
Nomadicкоротко отвечает:
A: (IA, SK): Снести Oracle Trace Collection Services.
Получение пути псевдонима и таблицы I
Есть три способа сделать это… №1 годится только для постоянных псевдонимов BDE. №2 работает с BDE и локальными псевдонимами, и No3 работает с BDE и локальными псевдонимами, используя "тяжелый" путь, через вызовы DBI.
functionGetDBPath1(AliasName: string): TFileName;
varParamList: TStringList;
begin
ParamList := TStringList.Create;
withSession do try
Читать дальше