Oracle 質問総合スレ ..
[2ch|▼Menu]
446:NAME IS NULL
07/04/30 00:12:47
>>443,>>444
ありがとうございます
ぐぐったんですが、DL出来るURL教えてもらえますか?
ORACLEのサイト苦手orz

447:NAME IS NULL
07/04/30 01:05:10
>>446

( ´∀`)σ)∀`) URLリンク(www.oracle.com)

448:NAME IS NULL
07/04/30 01:13:00
日本のサイトならこれ
URLリンク(otn.oracle.co.jp)
プラットフォームはUSより少ないみたいだけど。


449:NAME IS NULL
07/04/30 02:13:10
>>447,>>448
度々すみません。助かりました。
まだDLしてませんが、>>447さんが教えてくださった方は期間は無期限なのでしょうか?



450:NAME IS NULL
07/04/30 06:11:50
開発用だから無期限
日本サイトにある体験版も中身は全く一緒。
そもそもいまのOracleには日本語版というものがないしね。


451:NAME IS NULL
07/04/30 08:25:43
>>449

ボラクルの体験版、もくしは開発者用ライセンスは紳士協定という
ことになっております。
まあ、端的に言うならテクニカルには無期限という事です。

452:NAME IS NULL
07/04/30 12:00:53
>>450,>>451
わかりました。ありがとうございます。
日本語版のをインスコしてみようと思います。
わかり易く説明してくださって本当にありがとうございました。

DB板は本当に紳士な方ばかりで癒されます。


453:NAME IS NULL
07/04/30 13:46:52
>>452

日本語版はないと >>450 で教えてもらったのに、その態度はなんだ。


454:NAME IS NULL
07/04/30 13:55:41
>>453
日本語サイトの・・・ね。行間察して♪

455:NAME IS NULL
07/04/30 17:55:20
行間? どの行とどの行?

アホが沸いてくるのは春だからか。


456:NAME IS NULL
07/04/30 20:35:34
ここからも製品何でも落とせるよ。
URLリンク(edelivery.oracle.com)


457:NAME IS NULL
07/04/30 23:16:41
>>431
レス遅くなってすみません。
元のサーバーの起動終了から次のサーバーの起動開始まで大体3日ぐらいあります。
サーバーはウインドウズサーバーかなんかです。

パソコン詳しくなくてすみません。

458:NAME IS NULL
07/05/01 00:06:50
>>457

鯖がウィンドウズか・・・。
まあ、移行手順としてはこんな感じ?

1. DBをシャットダウンしてコントロールファイル、データファイル、リドログファイル、
init.ora、tnsnames.ora、listener.oraのバックアップをテープやネットワークバック
アップなどの外部メディアに保存

2. 新規鯖の準備が完了後、ボラクルのソフトウェアのインスコ

3. oradim使ってインスタンス(サービス)の作成

4. 外部メディアからバックアップを戻す

459:NAME IS NULL
07/05/01 00:49:55
>>458
おしい。80点。PWD***.oraとか忘れてる。


460:NAME IS NULL
07/05/01 01:41:12
その手順は、ファイルのパスとかが変わらなければという条件付きだな。


461:NAME IS NULL
07/05/01 02:30:04
鯖そのもののウプグレードだし、窓鯖だし、そんなにファイルパスとか
変わらんでないの?
まあ、例え変わったとしてもalter database rename file文打てばいい
だけだし。

462:NAME IS NULL
07/05/01 14:29:27
モノホンDB(HP-UXのOracle 10G オプションは謎)でexpしたdumpファイルを
テスト用DB(WindowsNTのOracle 10G ただのXE)でimpしてます

大半のテーブルはなぜか問題なくimpできましたが
10G XEはパーティション表は対応してませんのでパーティション表だけはimpできません

仕方なくバイナリエディタでパーティション定義の部分を半角空白で潰してからimpしてますが
もっとましなインポート方法はOracle 10Gとパーティション表のオプションを買う以外ないのでしょうか

ちなみにエクスポート側は人様のブツなのでいぢれません


463:462
07/05/01 14:49:52
失礼
WindowsNT→WindowsXP


464:NAME IS NULL
07/05/01 14:53:09
>>462
Personal Edition買え。
XEじゃオプション使えないけど、
PersonalならEnterprise Editionで使えるオプションは
スタンドアロンで使う分においては
ライセンス上すべて使うことが可能。


465:NAME IS NULL
07/05/01 22:35:38
>>458-459
とりあえずテストはうまくいきました。
ありがとうございます。

あとは本番が来るのを待つのみです。


466:NAME IS NULL
07/05/04 21:42:41
10gでデータベースのdropをするとselect * from tabをするとゴミみたいな物ができるのだが、どうやって消せばいいのでしょうか?

467:NAME IS NULL
07/05/04 22:18:08
>>466

purge recyclebin;

468:NAME IS NULL
07/05/05 00:56:48
>>467
サンクス
試してみるよ

469:NAME IS NULL
07/05/07 07:05:40 V4L2+2IZ
初期ぱらに
10.1 なら _recyclebin=FALSE
10.2 なら recyclebin=OFF

470:NAME IS NULL
07/05/10 14:29:13
Pro*Cで質問です。
NUMBER(10)を受け取れるホスト変数は何型で定義すればよいでしょうか?
intでは足りないようです。

471:NAME IS NULL
07/05/10 16:29:03
>>470
int に (多分 long でも同じだろうが) 入りきれないような値はどう頑張っても無理。
数桁ずつ2つに分割して受け取るか、諦めて char [] で受け取るしかない。

472:NAME IS NULL
07/05/11 01:32:29
>>470
プリコンパイルで エラーとか警告とかが出てるとか ?

473:428
07/05/11 04:45:58 EOvcBfqi
oracle10g でNVL関数で不具合らしきものは
聞いた事ありますか?

sqlplusで
aaa:number型
NVL(aaa,999)
aaaがNULLの場合、""の場合、0の場合で
取得結果が一致してしまうことはありますか?


474:NAME IS NULL
07/05/11 06:28:25
Oracleにおいては、空文字列はNULLとして保存される(文字型であっても!)。


475:NAME IS NULL
07/05/11 07:12:48
>>473
Number型に""(空文字列)は入れられないだろwww

aaa=0とaaa=NULLの場合は
明らかにNVLの戻り値は異なると思うが。


476:NAME IS NULL
07/05/11 15:48:27
>>475
入るよNULLとしてw
>空文字列はNULLとして保存される


477:NAME IS NULL
07/05/11 22:14:56
練習目的で
oracle database10g Express edition10.2.0.1.0 を
fedora6にインストールしたのですが、
GNOME端末からsqlplusにログイン?(おかしな表現でしたらすいません)
したところ、方向キーを押すと ^[[D ^[[A ^[[C ^[[B (←↑→↓)
と入力されてしまいます。
検索エンジンで調べてみたのですが、^[[の文字を検索できなくて
解決出来ません。
知恵を貸していただけないでしょうか?

478:NAME IS NULL
07/05/11 22:25:29
こういうのはどうよ。
URLリンク(d.hatena.ne.jp)


479:477です
07/05/11 22:53:17
478さんありがとうございます!
linux も oracle も初めてでうまく出来るか不安でしたが
tar zxvf と make install だけで
SQLPLUS上で方向キーが使えるようになりました。

どうもありがとうございます。

480:NAME IS NULL
07/05/12 14:02:08
Pro*CでBLOB型のカラムのデータを更新するサンプルプログラムは
ないでしょうか?

481:NAME IS NULL
07/05/13 22:03:28
>>480

URLリンク(orafaq.com)
URLリンク(groups.google.com)

482:NAME IS NULL
07/05/14 13:01:34
>>457とは別人なんだけど、>>458-461参考にしてデータの移動をやってみたのだが今度はoracleの起動法がわかりません
やったのは
sysdbaでshutdown
バックアップしておいたファイルをコピー
Windowsの再起動

コピー元はEドライブで下が、コピー先はDドライブです

これから先がよくわかりません
サービスネームなしでsysdbaに入れるようなので入ってstartup;をやると
ORA-02778: Name given for the log directory is invalid
が帰ってきます

この先どうすればいいのでしょうか?

483:NAME IS NULL
07/05/14 13:35:36
>>482
ドライブレターが変わった時点で
その方法ではリカバリできん。

MOUNTしてALTER SYSTEM文発行して、
制御ファイル上のREDOログファイルの場所と、
データベースファイルの場所を書き換えろ。


484:482
07/05/14 15:00:44
>>483
何をやっても起動できません
oracleを削除して再インストールした方が早いのでしょうか?

485:NAME IS NULL
07/05/14 15:03:42
>>484
なにをやっても、って何やったんだよ。


とりあえずコマンドプロンプトで下記のコマンド打って

sqlplus /nolog
conn / as sysdba
startup nomount
alter database mount;
alter database open;

どこまでエラーが出ずに進捗したかまず教えろ。
必ず標準出力をコピペしろよ。

486:NAME IS NULL
07/05/14 22:57:06
>>484

つーか、喪前、ドライブレターが変わったんだから、当然alert.logとかの
出力先の指定をinit.oraの中でもちゃんと変えたんだよな?
ORA-02778: Name given for the log directory is invalidって言われて
んだから、init.oraの中のbdump、cdump、udumpの出力先を良く見て
みろや。


487:482
07/05/15 10:33:39
>>485
以下、ログです
Microsoft Windows [Version 5.2.3790]
(C) Copyright 1985-2003 Microsoft Corp.

C:\Documents and Settings\xxxxxxx>sqlplus /nolog

SQL*Plus: Release 10.1.0.2.0 - Production on 火 5月 15 10:21:01 2007

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

SQL> conn / as sysdba
Connected to an idle instance.
SQL> startup nomount
ORA-01078: failure in processing system parameters
LRM-00109: could not open parameter file 'D:\ORACLE\PRODUCT\10.1.0\DB_1\DATABASE
\INITORCL.ORA'
SQL> alter database mount;
alter database mount
*
ERROR at line 1:
ORA-01034: ORACLE not available


SQL> alter database open;
alter database open
*
ERROR at line 1:
ORA-01034: ORACLE not available


SQL>

上書きした*.oraの中身はすべてDドライブに書き換えました
INITORCL.ORAはありませんでした
バックアップをとったときもEドライブの*.oraはすべてバックアップをとりましたが、ありませんでした

init.oraとはinit.ora.4142007111722のことでしょうか?
そのデータならDドライブに書き換えました

488:NAME IS NULL
07/05/15 10:56:42
>>487
init.oraってここではたぶんspfileを指してる。
で、Oracleが必要としてるspfileなりpfilなりを探して、
見つけられなかったもんだから怒られてる。

startup nomount pfile=init.ora.4142007111722
みたいにして指定するか、
レジストリのORA_<SID>_PFILE確認して
正しい場所に書き換えてからstartup nomountしてみろ。



489:482
07/05/15 19:50:30
>>488
レジストリの中にORA_<SID>_PFILEの項目を見つけることができなかったのでファイルを直接指定して実行しました

Microsoft Windows [Version 5.2.3790]
(C) Copyright 1985-2003 Microsoft Corp.

C:\Documents and Settings\FSystem>sqlplus /nolog

SQL*Plus: Release 10.1.0.2.0 - Production on 火 5月 15 19:37:51 2007

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

SQL> conn / as sysdba
Connected to an idle instance.
SQL> startup nomount pfile=D:\oracle\product\10.1.0\admin\orcl\pfile\init.ora.41
42007111722
ORACLE instance started.

Total System Global Area 171966464 bytes
Fixed Size 787988 bytes
Variable Size 145488364 bytes
Database Buffers 25165824 bytes
Redo Buffers 524288 bytes
SQL> alter database mount;

Database altered.

SQL> alter database open;
alter database open
*
ERROR at line 1:
ORA-01157: cannot identify/lock data file 1 - see DBWR trace file
ORA-01110: data file 1: 'E:\ORACLE\PRODUCT\10.1.0\ORADATA\ORCL\SYSTEM01.DBF'


SQL>

ORA-1157の解説を読んで
alter system check datafiles;
を実行しましたが、
System altered.
と、でるだけでこの後alter database openを実行してもエラーが帰ってきました。
これはどこを変更するといいのでしょうか?

490:NAME IS NULL
07/05/15 20:06:08
>>489

alter database rename file 
'E:\ORACLE\PRODUCT\10.1.0\ORADATA\ORCL\SYSTEM01.DBF' TO
'D:\ORACLE\PRODUCT\10.1.0\ORADATA\ORCL\SYSTEM01.DBF'
;

ってのを必要なファイル分、順次実行して、
すべてのデータベースファイルやREDOログファイルのエントリを書き換え汁。



491:482
07/05/16 07:53:27
>>490
ファイルの書き換えを行いました
次に以下のエラーが帰ってきました

SQL> alter database open;
alter database open
*
ERROR at line 1:
ORA-01172: recovery of thread 1 stuck at block 41 of file 2
ORA-01151: use media recovery to recover block, restore backup if needed

調べてみたところ、メディアリカバリが必要とのことだったのでリカバリコマンドを実行したところ、以下のメッセージが帰ってきました

SQL> startup open recover pfile=D:\oracle\product\10.1.0\admin\orcl\pfile\init.o
ra.4142007111722
ORACLE instance started.

Total System Global Area 171966464 bytes
Fixed Size 787988 bytes
Variable Size 145488364 bytes
Database Buffers 25165824 bytes
Redo Buffers 524288 bytes
Database mounted.
ORA-01172: recovery of thread 1 stuck at block 41 of file 2
ORA-01151: use media recovery to recover block, restore backup if needed

リカバリコマンドを実行しても同じエラーが帰ってきます
申し訳ありません
これから先をご教示ください

また、startupでpfileを指定しないとstartupを実行できませんが、どのようにしてoracleにpfileの場所を登録するのでしょうか?
これも併せてご教示ください。

お願いします

492:NAME IS NULL
07/05/16 09:05:49
>>491
それ、ファイル番号2番のファイルがブロック破損してる。

正常と思われるバックアップから上書きコピーして書き戻しても同様のエラーが発生するなら、
Oracleのサポートに連絡して、復旧手順アナウンスしてもらえ。


493:NAME IS NULL
07/05/16 09:08:10
>>491
リカバリしてもダメ、ってのは、
RECOVER DATAFILEを実行したんだよな?
それで>>492試してダメならバックアップしたファイルが壊れてる。


494:NAME IS NULL
07/05/16 12:18:40
>>491

EEでかつRMAN使ってバックアップとか取っていたらMBRという
きのうがるんだが、おそらくそんなことやっていないよな?
既出だが、ブロックが壊れているから、バックアップから戻すしかない。

ちなみにそのファイル2は何だった?
もしラッキーな事に、それがTempファイルだったらDropしても問題無いけどね。
もしくはデータ的にそんなに重要でないのなら、mount状態でデータファイルを
Dropして、無理やりDB上げることも不可能ではないが・・・。

それとspfileを使用してるみたいだから、取り合えず以下のコマンド使えば
いちいちpfileを指定しなくても起動できるようになるよ。

create spfile from pfile='D:\oracle\product\10.1.0\admin\orcl\pfile\init.ora.4142007111722';






495:482
07/05/16 14:58:42
>>493
recover datafileをoradataの中の*.DBFファイルに対して実行しました
その後、alter database openを実行すると、REDO0*.LOGがEドライブにないと警告されました
そこでalter database rename fileを実行後、alter database openを実行したところ、動作しました
データの中身も確認できるようになりました

>>494
create spfileを実行しました

皆様、ありがとうございました

496:482
07/05/16 16:47:13
482です。
データをみれるようになったのですが、データを直接さわろうとすると内部エラーが発生してデータの操作ができませんでした
truncate tableやpurge recyclebinやdrop tableを実行すると
ORA-00604: error occurred at recursive SQL level 1
ORA-00607: Internal error occurred while making a change to a data block
ORA-00600: internal error code, arguments: [4193], [1899], [284], [], [], [], [], []
と、いったメッセージが出てきてtruncateができなかったり、purgeができなかったりします

また、PCの起動時にサービスかドライバが起動できないというエラーメッセージが出てきます
そこでイベントビューアをみてみるとOracle,orclに

イベント ID (16) (ソース Oracle.orcl 内) に関する説明が見つかりませんでした。
リモート コンピュータからメッセージを表示するために必要なレジストリ情報またはメッセージ DLL ファイルがローカル コンピュータにない可能性があります。
この説明を取得するために /AUXSOURCE= フラグを使用することができる可能性があります。
詳細については、ヘルプとサポートを参照してください。次の情報はイベントの一部です: orcl.

と、いう内容の情報メッセージ、警告メッセージが記録されています。

これはoracleのデータのバックアップをとって再インストールした方がいいのでしょうか?

497:NAME IS NULL
07/05/16 22:17:25
>>496
>>496

ブロックがいかれてしまってんだから、そうなっても仕方ないと思われ。
もし出きるのならRMAN使って、Verifyかけてみてみ?

1. RMANベリフィケーションのやり方

DOS> rman target / nocatalog
RMAN> CONFIGURE CONTROLFILE AUTOBACKUP OFF;
RMAN> run {
allocate channel d1 type disk;
allocate channel d2 type disk;
backup check logical validate database;
release channel d1;
release channel d2;
}
RMAN> CONFIGURE CONTROLFILE AUTOBACKUP ON;

2. 壊れたブロック情報を以下のSQLで検索
select * from v$database_block_corruption;


498:NAME IS NULL
07/05/17 18:08:22
この頃ハマったこと。(これ、SQL文を作る上での常識なんだろうか?)

select での検索で、条件が多くなればなるほど嘘のように遅くなることが分かった。
こんなやつ。

select * from hoge where fuga in (1, 2, 3, ...(100個ぐらい値が並ぶ)...);

この in での項目が増えれば増えるほど遅くなる。ところがこの in で指定している
値を create temporary table tmp (no number(10) not null primary key); で
作った表に全部 insert してこうすると速かった。とても速かった。値が多いと
雲泥の差があった。

select * from hoge where fuga in (select no from tmp);

DBサーバ内部での最適化の問題だとは思うが、あまりにも差がありすぎて
びっくりした。(Oracle 9 だったからか?)


499:482
07/05/17 18:45:15
>>497
直らないみたいな感じです
以下、ログです

Microsoft Windows [Version 5.2.3790]
(C) Copyright 1985-2003 Microsoft Corp.

C:\Documents and Settings\xxxxxxx>rman target / nocatalog

Recovery Manager: Release 10.1.0.2.0 - Production

Copyright (c) 1995, 2004, Oracle. All rights reserved.

connected to target database: ORCL (DBID=1140153217)
using target database controlfile instead of recovery catalog

RMAN> run {
2> allocate channel d1 type disk;
3> allocate channel d2 type disk;
4> backup check logical validate database;
5> release channel d1;
6> release channel d2;
7> }

allocated channel: d1
channel d1: sid=154 devtype=DISK

allocated channel: d2
channel d2: sid=143 devtype=DISK

Starting backup at 07-05-17
channel d1: starting full datafile backupset
channel d1: specifying datafile(s) in backupset
RMAN-03009: failure of backup command on d1 channel at 05/17/2007 11:58:07
ORA-19602: cannot backup or copy active file in NOARCHIVELOG mode
continuing other job steps, job failed will not be re-run
channel d1: starting full datafile backupset
channel d1: specifying datafile(s) in backupset
including current controlfile in backupset
channel d2: starting full datafile backupset
channel d2: specifying datafile(s) in backupset
RMAN-03009: failure of backup command on d2 channel at 05/17/2007 11:58:08
ORA-19602: cannot backup or copy active file in NOARCHIVELOG mode
continuing other job steps, job failed will not be re-run
channel d2: starting full datafile backupset
channel d2: specifying datafile(s) in backupset
including current SPFILE in backupset
channel d2: backup set complete, elapsed time: 00:00:02
channel d1: backup set complete, elapsed time: 00:00:03
released channel: d1
released channel: d2
RMAN-00571: ===========================================================
RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS ===============
RMAN-00571: ===========================================================

RMAN-03009: failure of backup command on d2 channel at 05/17/2007 11:58:08
ORA-19602: cannot backup or copy active file in NOARCHIVELOG mode

500:482
07/05/17 18:49:56
その2

RMAN> configure controlfile autobackup off;

new RMAN configuration parameters:
CONFIGURE CONTROLFILE AUTOBACKUP OFF;
new RMAN configuration parameters are successfully stored

RMAN> run {
2> allocate channel d1 type disk;
3> allocate channel d2 type disk;
4> backup check logical validate database;
5> release channel d1;
6> release channel d2;
7> }

allocated channel: d1
channel d1: sid=154 devtype=DISK

allocated channel: d2
channel d2: sid=143 devtype=DISK

Starting backup at 07-05-17
channel d1: starting full datafile backupset
channel d1: specifying datafile(s) in backupset
RMAN-03009: failure of backup command on d1 channel at 05/17/2007 12:00:37
ORA-19602: cannot backup or copy active file in NOARCHIVELOG mode
continuing other job steps, job failed will not be re-run
channel d1: starting full datafile backupset
channel d1: specifying datafile(s) in backupset
including current controlfile in backupset
channel d2: starting full datafile backupset
channel d2: specifying datafile(s) in backupset
RMAN-03009: failure of backup command on d2 channel at 05/17/2007 12:00:37
ORA-19602: cannot backup or copy active file in NOARCHIVELOG mode
continuing other job steps, job failed will not be re-run
channel d2: starting full datafile backupset
channel d2: specifying datafile(s) in backupset
channel d1: backup set complete, elapsed time: 00:00:00
including current SPFILE in backupset
channel d2: backup set complete, elapsed time: 00:00:02
released channel: d1
released channel: d2
RMAN-00571: ===========================================================
RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS ===============
RMAN-00571: ===========================================================

RMAN-03009: failure of backup command on d2 channel at 05/17/2007 12:00:37
ORA-19602: cannot backup or copy active file in NOARCHIVELOG mode

RMAN> configure controlfile autobackup on;

old RMAN configuration parameters:
CONFIGURE CONTROLFILE AUTOBACKUP OFF;
new RMAN configuration parameters:
CONFIGURE CONTROLFILE AUTOBACKUP ON;
new RMAN configuration parameters are successfully stored

RMAN>

501:NAME IS NULL
07/05/17 19:46:23
> ORA-19602: cannot backup or copy active file in NOARCHIVELOG mode

読める?


502:NAME IS NULL
07/05/17 22:23:20
>>499

そこまでOracle対して素人だとは思わなかった。
noarchivelogモードで動いているのなら、mount modeで実行しろ。

SQLPLUS> shutdown immediate;
SQLPLUS> startup mount;

もしくはarchivelog modeにしてからでもいいぞ。

SQLPLUS> shutdown immediate;
SQLPLUS> startup mount;
SQLPLUS> alter database archivelog;
SQLPLUS> alter database open;
SQLPLUS> archive log list;


503:NAME IS NULL
07/05/17 23:40:04
それとRMANベリフィケーションは直すためのものではなく、あくまでベリファイを
かけるものだから。
ここから壊れたブロック先を特定して、そいつに「Unreadable」のマーカーをつける。
そうしたらそのブロックに入っているデータは読めないものの、無事な部分は
読める様になる。
そうなれば後はcreate table as selectなり、export/importなりで無事な部分だけを
救い出せばいい。
壊れたブロックに入っていたデータはバックアップが無い以上、復旧の手立ては無いよ。
これでバックアップの重要性を認識しろ。


504:NAME IS NULL
07/05/18 16:19:11 BLRq5Xmu
初歩的な事なのですが質問させてください。
クライアント(私)は10gなのですがサーバー側は9iです
exp user/pass@servername file=c:\test.dmp
でエクスポートしようとしたのですが

EXP-00056: Oracleエラー942が発生しました。
ORA-00942: 表またはビューが存在しません。
EXP-00000: エラーが発生したためエクスポートを終了します。

このようなエラーが出るのですがどなたかわかりますか?
自分なりに調べたのですがわからないままです^^;
もちろんテーブルなどの中身はしっかりあります。
ちなみに10gのサーバーからのエクスポートは普通にこのコマンドで出来ました。
クライアントとサーバー側のバージョンが違うとエクスポートが出来ないという
事はありますか?初歩的な事ですいません。お願いします。

505:NAME IS NULL
07/05/18 16:34:04
なにをエクスポートしたいのですか?

506:NAME IS NULL
07/05/18 16:35:05
DB全体のです。

507:NAME IS NULL
07/05/18 17:56:38
>クライアントとサーバー側のバージョンが違うとエクスポートが出来ないという事はありますか

ある。


508:NAME IS NULL
07/05/18 18:01:16
>>504
サーバにある9iのexpでダンプとれ。


509:NAME IS NULL
07/05/18 23:17:48
>>504

基本的に異なるバージョン間でのexpは、低いバージョンのものを使って
行うことになっている。
つまりあなたの場合には9i側のexpを使わないとならない。
impは10g側のを使えばok。


510:NAME IS NULL
07/05/19 09:13:12
いつの間にかクライアントPC自らが質問を書き込むことが出来るようになったとは驚き。

511:NAME IS NULL
07/05/20 01:05:37
鯖側がSolaris/Linuxで、クライアントがウィンドウズって場合、sql発行するのもSQL*Plusのウィンドウズ版が必要?

512:NAME IS NULL
07/05/20 01:27:54
>>511

Telnetで鯖にログインすればいいんでないの?
どうしてもクライアント側でSQL*PLUS立ち上げたかったら、確かにSQL*PLUSの窓版が
必要だけど、EEのCDとか買えば窓のクライアントとかは同梱されていたりするけどね。

513:NAME IS NULL
07/05/20 03:01:45
インスタントクライアント(windows&linux)がある。
開発用途に限定するならば、モノホンもDLできるし。


514:482
07/05/21 09:11:18
>>502
shutdownができませんでした

データの復旧をあきらめましたので、現在、エラーがでたり、OSのスタート時にサービスの起動でエラーがでる状況をなおしたいのですが、何か方法はありませんか?

515:NAME IS NULL
07/05/21 09:16:57
>>514

shutdown abort使え。
O/S関係のエラーだが、サービスはoradim使って作成したんだろうな?

516:482
07/05/22 08:15:48
>>515
shutdown normal/immediateからでしかarchivelogにできないのですが

サービスはインストールした状態のままです

517:NAME IS NULL
07/05/22 11:17:45
>>523

だったらshutdown abortしてから、startupして、それからshutdown immediateすれば良かろう。

窓は専門じゃないで、なんとも言えんが必要だったらoradim使ってサービス再作成してみれ。

%ORACLE_HOME%\bin\oradim.exe -delete -sid <SID>
%ORACLE_HOME%\bin\oradim.exe -new -sid <SID> -startmode m
%ORACLE_HOME%\bin\oradim.exe -edit -sid <SID> -startmode a




518:482
07/05/22 11:21:26
>>517
そうやってもimmediateで処理がずっとストップするのですが

519:NAME IS NULL
07/05/22 12:08:09
「ですが」ばっかりだけど少しは自分で考えたのか?

荒らしにしか見えんぞ。

520:NAME IS NULL
07/05/22 16:03:37
>>518
修復するには今までの作業と同じ位の作業量は残っているな
今は序盤もいいとこだし、素直に再構築しろ

521:NAME IS NULL
07/05/22 21:23:27
>>518

バックアップ無くてぶっ壊れてるんだから仕方ないだろうな。
まあ、出来るとしたらshutdown abortして、startup mount、recover database、shutdown、startup mount
だったらいくんじゃねぇか?

いずれにせよあなたの技術レベルではこの先のことも理解できるとはとても思えないが・・・。

522:NAME IS NULL
07/05/22 23:57:37 fABphS2n
新社会人なのですが、来月から配属されるプロジェクトを選択しなければいけません。(初配属です)
プロジェクトの一つにPL/SQLを使用したOracleのERPパッケージの開発プロジェクトがあるのですが
正直悩んでいます。
研修中にSQLをほんの少しと、Javaを習っていました。ちなみに中小独立ITです。

EBSが何か、どんなパッケージ開発なのかなどの知識は全くないのでとても幼稚な質問になってしまうのですが

・PL/SQL言語を学んで、この先役に立つのか(Oracleプロジェクトを抜けた後にも活かせるのか)
・PL/SQL言語の大変な所
・ERPパッケージ開発のメリット・デメリットは

などが気になる点です。非常に抽象的な質問で、一概には言えないことばかりだと思いますが
個人的な意見で良いので是非お願いします。
サイトや本などで調べてはみたのですが、現場の技術者からの意見が気になるので、ここで質問させて頂きました。

523:NAME IS NULL
07/05/23 00:31:43
>>522
中間管理職辺りで誰が仕切っているかが重要
COBOLerの下に配属されなければどこでも同じ

ただ優秀なリーダーの下にしか、全ての意味で
おいしいプロジェクトは来ないから
バカマネ/リーダーにつくと、もれなく辞めたくなるだろう

524:NAME IS NULL
07/05/23 00:34:32
他の案件に何があるか判らないから一概に比較は出来ないけど,
PL/SQLの長所は互換性,Oracleが動く環境なら大概動く.
P○PみたいにマイナーVerUpしただけで動かなくなるなんてことは無い.

PL/SQL言語の大変なところは,互換性の裏返しで構文が古臭い.
業務ロジックを実装するには十分だと思うけど,
それ以外のことをやろうと思うと途端に敷居が高くなる.

ERPパッケージ開発は基本的に有り物ベースで作るだろうから,
仕事としては退屈.多分仕様通りにパッケージの部品をくっつけて終わり.

>>ちなみに中小独立IT
 ここが一番不安なポインヨ.
 さっさと覚えること覚えて,ジョブチェンジ考えとけ.

525:NAME IS NULL
07/05/23 00:51:47
>>523
うちの会社のリーダーはコボラーではなかったとおもいますが、
発注先の会社の管理職まではわかりません。

>>524
丁寧に答えて頂いてありがとうございます。

>仕事としては退屈.多分仕様通りにパッケージの部品をくっつけて終わり.
そうなんですか。ベースがあって、それを相手に合わせてカスタマイズっていうのがメインだというのは
知っていたのですが、やっぱり有り物をくっつけたりするだけなんですね。
面白そう!っていうイメージはあんまり沸かないですね・・・

中小独立ITなので、3〜5年後くらいで転職するとつもりでいるんですが、
その時に転職の武器になる言語なのかなーという不安があります。

526:NAME IS NULL
07/05/23 02:41:12
>>524
>>ちなみに中小独立IT
> ここが一番不安なポインヨ.

大手ほどなんじゃこれ?っていう若手が多いし&辞めない
傘下のグループ企業の若手の方は優秀だけど良く転職してるな
大手は情報だけは集まるから全社レベルの知識データベースで
仕事できてるのを自分の能力と勘違いしてるんだよね

527:NAME IS NULL
07/05/23 07:35:06
>>522

PL/SQLはOracle関連の製品ではそれなりに重宝されるが、それ以外では
全く潰しが効かないという諸刃の剣。

でもOracle EBSの案件って最近の日本だとそれなりにあるものなのか?
4年ぐらい前の情報だが、俺が知っている大手でOracle EBS使っていたのって
日本だとCanonとRICHOとかぐらいだった気がしたが・・・?

まあ、その反面、欧州および北米では値段の安さも手伝ってか、Oracle EBSが
結構使われていたりするよ。
俺は日本にいた時には純粋にOracle DBだけで生きていたんだが、海外に出て
否応無くEBSを覚えざるを得ない状況になった('A`)

最もOracle EBSは腐ったアプリという意見は今でも変わらないカーッ(゚Д゚)≡゚д゚)、ペッ

528:NAME IS NULL
07/05/23 13:33:10 8Pm4t5N2
質問です。
ORA12154とかORA00065とか、
番号を入力するだけで検索できるサイトがあれば教えてください。

529:NAME IS NULL
07/05/23 14:50:02
OTNくらい知っとけ。
  URLリンク(otn.oracle.co.jp)

尤も、エラーメッセージのPDF検索した方が早いかもな。

530:NAME IS NULL
07/05/23 21:07:32
>>528

oerr コマンドも覚えておくといいかもね。


531:NAME IS NULL
07/05/23 23:02:31
まぁ、マルチなんだどな。

532:NAME IS NULL
07/05/24 00:04:02 sIsyqRlw
ありがとうございました。

533:NAME IS NULL
07/05/24 18:25:12
ネタじゃなくてマジでわからんので教えてください。
STATSPACKってなんて読むの?すたっつぱっく?


534:NAME IS NULL
07/05/24 18:38:55
しゅたっつぱっく

535:NAME IS NULL
07/05/24 19:20:17
>>533
スタットスパック
スタットスパンキングするともいう

536:NAME IS NULL
07/05/24 22:20:03
>>533

マジレスしてやるが、スタッツパックだ。
少なくとも日・欧・北米ではそう読んでいる。

537:533
07/05/25 14:41:21
ありがとうございます。すたっつぱっくでいいみたいですね。

538:NAME IS NULL
07/05/26 01:33:30
OTNの有償プログラムって契約してる人居る?
あの開発ライセンス使ってモノ作っても運用に回したかったら
開発した環境用の正規ライセンス購入しろ、みたいになってて
存在意義がわからなかったんだけど、何が目的で加入してるの?

539:NAME IS NULL
07/05/26 01:39:51
メディアがもらえるってことじゃね?
OTNを使わずに正規ライセンスを買ってもメディア代は別だし。


540:NAME IS NULL
07/05/26 01:53:37
>>538
フリーランサーがサポート情報にアクセスできるからとかじゃないか?

541:NAME IS NULL
07/05/26 01:59:35
仕事でやってるんなら、アカウント借りりゃ済むやん。


542:NAME IS NULL
07/05/26 03:03:05
>>541
派遣ならいいだろうけど
客のすべてが保守契約してないわな

543:NAME IS NULL
07/05/26 04:44:55
そもそも保守契約無しの客って地雷だと思うが。問題が起きたときノンサポートじゃん。
OTNの開発ライセンスで運用しちゃってる割れ廚?

544:NAME IS NULL
07/05/26 15:31:32
>>543
よく考えろよ、縁故なら別枠だろうが
保守契約できる位に金がだせるところはフリーなどが入る余地はない
個人で受注請負で入り込めるところといえば
オラクルをビックカメラとかで買ってるようなところだろ

545:544
07/05/26 15:45:58
あ、ちなみにフリーでもないしOTNの開発者ライセンスも持ってないぞ
買うとしたら、「それくらいしか」使い道がないだろw

546:NAME IS NULL
07/05/26 19:32:21
Oracleを一から勉強したいんですけど、
基礎的なことが載っているサイトを知りませんか?
ググってもそれらしきサイトが見つからなくて困ってます。

547:NAME IS NULL
07/05/26 20:17:48
>>546

URLリンク(otn.oracle.co.jp)


548:NAME IS NULL
07/05/27 16:26:41
オラクル廚がフリーになっても食えないってことだな。

549:NAME IS NULL
07/05/27 21:15:48
>>548
オラクルだけじゃ食っていけないだろうな。


550:NAME IS NULL
07/05/27 23:35:40
オラクルに入社すればいいじゃん

551:NAME IS NULL
07/05/29 14:26:22 UJceAzrI
SELECT QQQ.CURRVAL FROM DUAL;

ORA-08002: QQQ.CURRVALはこのセッションではまだ定義されていません

なぜこんなエラーが出ますか

552:NAME IS NULL
07/05/29 14:39:46
>>551
日本語でOK

つかQQQってどう定義されてるわけ?

553:NAME IS NULL
07/05/29 15:00:49
>>551
あなた、なぜ、ググル、しませんか?

554:NAME IS NULL
07/05/29 15:04:19
>>551
QQQがSEQUENCEと仮定すると、
作ったばっかりの時には
NEXTVALしないとCURRVALは取れないよ。
つ〜か、まずググれよwww


555:NAME IS NULL
07/05/29 17:50:02
select months_between(sysdate,'07-9-27') from dual;

指定した付きが向こうですとか出ましたけど、どういうことなんでしょうか。

556:NAME IS NULL
07/05/29 18:50:07
>>555
TO_DATEで日付型にしてやれよwww


557:NAME IS NULL
07/05/29 20:25:40
CREATE OR REPLACE FUNCTION PREV_DAY( P_DATE IN DATE, P_DAY IN CHAR )
RETURN DATE
IS
BEGIN
RETURN NEXT_DAY(P_DATE - INTERVAL '7' DAY, P_DAY);
END;

というPREV_DAY.sqlをつくってsqlplusで
get PREV_DAY.sql
/
とやると、
PLS-00103: 記号""が見つかりました。 次のうちの1つが入るとき:
return
とコンパイルエラーが出ます。
なのに、このsqlの平文をsqlplusへコピペするとプロシージャ作成できてしまいます。
何故エラーが出るのか解りません。

558:557
07/05/29 20:28:49
>>557
文章が途中になってしまいました。
get PREV_DAY.sql
/

と書いたファイル createProc.sqlを使って
sqlplus scott/tiger @createProc.sql
とやるのが理想なんですができないでしょうか。
まずは何故エラーなのかを知りたいのですが解りますでしょうか。

559:NAME IS NULL
07/05/29 23:24:22
>>557

バージョンぐらい書け。
9i R1だったらバグにヒットしている可能性が大。

560:557
07/05/30 16:25:45
>>559
すみません。10gのXEです。

561:NAME IS NULL
07/06/01 01:58:41
うちの10gXE win32 じゃ、問題なく実行できるぞ。

562:NAME IS NULL
07/06/05 07:14:04 S2M66NQt
Oracle8iのデッドロックについて教えて下さい。

(1)複数レコードのテーブルAを、複数並列するdelete テーブルA;した場合、デッドロックが発生する可能性はあるのでしょうか?
(2)同じくテーブルAにdelete テーブルA;と、並列して、例えばdelete テーブルA where rownum = 3;->rownum = 1->rownum = 2の計 3 SQLを順番に実行するトランザクションがあった場合、デッドロックが発生する可能性はあるのでしょうか?

よろくしお願い致します。

563:NAME IS NULL
07/06/05 07:23:53
>>562
デッドロックは一車線通行の出会い頭で絶対にバックしない後続車が
双方にきているような状況で譲り合いができないときに発生する。
つまり、その例では発生しない。

564:NAME IS NULL
07/06/05 07:48:39 S2M66NQt
>>563
ありがとうございました。
どこまでがデッドロックするのか、非常に気になっていました。助かりました!

>>562の(1)と(2)がデッドロックする可能性が無いのであれば、注意すべきは、順番を固定したSQLが2つ以上のトランザクションだけになるのですね。

(トランザクション例1)
select * from テーブルA where rowid = '1' for update;
select * from テーブルA where rowid = '2' for update;
(トランザクション例2)
select * from テーブルA where rowid = '2' for update;
select * from テーブルA where rowid = '1' for update;
(トランザクション例3)
select * from テーブルA for update;

これだと、例1と例2が並列する場合だけデッドロックの可能が有って、例3と例1、または例3と例2、ましてや例3と例3は気にしないで良かったのですね。
ほっとしました。ありがとうございます。

565:NAME IS NULL
07/06/05 12:17:17
create user test
identified by test
default tablespace user_data
temporary tablespace temporary_data
quota unlimited on user_data;

表領域user_dataは存在しません
ってどういうこと?

566:NAME IS NULL
07/06/05 16:25:29
>>565
そのままだと思うが?
user_dataって票領域、作成したか?


567:NAME IS NULL
07/06/05 17:44:28
デフォルトで存在しているものと思ってましたが

568:NAME IS NULL
07/06/05 17:58:07
>>567
デフォルトで存在するのはUSER表領域だろ。

569:NAME IS NULL
07/06/05 17:58:40
>>567
ちがった。
USERS表領域だ。

570:NAME IS NULL
07/06/05 22:09:17
USERS 表領域はデフォルトでも存在しないが。

CREATE DATABASE 文を見直してみよう。




571:NAME IS NULL
07/06/06 19:38:02 OUHu+6Q0
COL_A,COL_B,COL_Cの列がある表のCOL_Aにインデックスが貼ってあって、select文のwhere句でCOL_A='hoge' AND COL_B='foo'と記述した場合に、インデックスは効きますか?型はあっている前提です。


572:NAME IS NULL
07/06/06 19:53:06
>>571
RBO? CBO?
いずれにせよ、実行計画とって
確認してみた方が早いよ。


573:NAME IS NULL
07/06/06 20:31:36
>>571

基本的に言ってCOL_AのIndexのRange Scanで絞られるはず。
まあ、>>572が言っているみたいに実効計画取ったら一発だけどね。

574:571
07/06/06 20:46:52 hrrOQWwo
>>572,573
レスありがとうございます。
10gなんで、CBOだと思うのですが…。
実際やってみないと判らない…ということですね。

最大○億件と見積もられているテーブルに対して、
検索画面をつくれ…つう、要件で、けんさく条件が多いんです。
そこで、必須条件を設けて、ソコにINDEX貼ってほかの任意条件は
どうするよ?ということで、、。
必須項目のカラムにだけはればINDEX効くだろう派と、いや、効かねぇんじゃない
派で意見がまとまらず…。
効く確証はないっつうことですね。
ん〜〜困った。

575:NAME IS NULL
07/06/07 00:37:41
>>574

何億件というからには当然パーティショニングしているんだよな?

576:NAME IS NULL
07/06/07 02:39:57
>>574
必須条件を1つ入れても
5つに分類しかされていないとか
偏りが大きいとかだとすげー意味ない

577:NAME IS NULL
07/06/07 05:21:22
>>574
CBOならコストに依存して、
INDEXの利用に関しては固定的ではないから、
オプティマイザの判断次第。

・・・にしたって、>>576の言うようにINDEX項目にするデータ自体に
カーディナリティが低いなどの問題が有れば、意味無いし。


578:571
07/06/07 08:46:04 FbZnvSWG
当初、この表に対して検索するという要件はなかったので、費用面からパーティショニングオプションをつけてなかったんです。
どうしても、オプション無しではダメそうであれば、オプション導入も考慮するって方向で、まず、色々調査してます。
索引貼る対象の必須項目はバラツキが大きく、かなり絞られるかと思います。


579:NAME IS NULL
07/06/07 09:13:19
>>578
> 索引貼る対象の必須項目はバラツキが大きく、かなり絞られるかと思います。

だったらINDEX作るだけでいけるように思うがな。
10gなら定期的に統計情報とるようになってるはずだし。



580:NAME IS NULL
07/06/07 11:04:19
億もある表に対する検索は正直言ってパーティション無しでは辛いと思うぞ。
場合によってはIOT表の導入とかも考えておいたほうがいいだろうな。


581:NAME IS NULL
07/06/07 11:23:53
>>580
そうかね?
意外と何十億件くらいなら捌けるもんだが。

582:NAME IS NULL
07/06/07 12:16:35
>>581 同じ土俵にいて良いものと悪いものがあるぞw

参照しない約束、約束〜って、レコード数だけでなくカラム数もレコード長も遠慮なしに
情報てんこもりで非正規化状態の過去ログテーブルかなんかだろな。
…どう見てもヒアリング不足です。本当にありがとうございました。

583:NAME IS NULL
07/06/07 12:23:51
>>582
> 情報てんこもりで非正規化状態の過去ログテーブル

俺が扱ってるのは似たようなもんだがwww
3局からの計測データを数秒周期で取り込んで、
かたや2台の表示用PC上で
10秒周期で最新データの表示してるだけだがな。


584:NAME IS NULL
07/06/07 12:30:11
>>583
そんな数値データだらけのテーブルならオンメモリでもいけそうだ

585:NAME IS NULL
07/06/07 18:26:12
社内の顧客管理用のマシンが最近以上に重いのだけど、Oracleのせいなのか
どうか切り分けたいんだけど、言いベンチマークソフトってないっすかね?

586:NAME IS NULL
07/06/07 18:45:18
>>585
GASAIREでモニタリングしてみることをお勧めする。


587:571
07/06/07 20:03:48 eZC/8BeQ
諸氏
レスありがとうございました。
とりあえず、
一番入力されるであろう項目にインデックスを張る。
SQL記述に関する規約を作成し、ベンダーに渡す。
開発環境構築名目でサーバを用意し、サンプルデータで実行計画をとる。
チューニングしつつ、画面設計し、顧客の説得をはかる。

で落ち着きそうです。
御世話になりました。

588:NAME IS NULL
07/06/07 20:27:58
>>585

マシンのタイプぐらい書いたらどうだ?

589:585
07/06/08 09:37:56
>585
失礼しました。
使用しているマシンは最近刷新しまして、DELL PowerEdge 2950で、OSはRH ES4で運用しています。
情報自体は2万件程度で、個人の情報としてはそれほど大きいモノではないはずなのですが、考えていたほど
レスポンスが上がってきません。
無論、ネットワーク関係も調べてみたのですが、問題はありませんでした。
まだ検証しないといけない部分は多いのですが、Oracle自体も疑っていこうとベンチマークソフトを探して
ました。

590:NAME IS NULL
07/06/08 10:20:45
>>589

マシン自体のスペックを測りたいのか?
それともDBベンチマーク取りたいのか?
DBベンチマークソフトならTPC-Cとかあるけどな。
CPUを計りたいのならSPECJBBなんかが使える。
レスポンスが悪いとかって言ってるけど、ディスクI/Oとか見てみたのか?
STATSPACKはどうだった?
タコなSQLが流れていて、全豹走査が置きまくりでレスポンス悪いなんて
こともあるぞ?


591:NAME IS NULL
07/06/08 10:39:35
ベンチマークってのは、障害原因を探るためのものじゃないし。
まずは、topとかsarとかパフォーマンスモニタでほんとにOracleのプロセスが原因かどうか見極める。


592:585
07/06/08 11:11:00
>590-591
確かにそうですね。(汗)
もうちょっと障害発生を切り分けてみようと思います。
ありがとうございました。

593:NAME IS NULL
07/06/09 04:31:22
Oracle DB 11g R1が6月11日にリリースされるそうな。
取りあえずRACでも組んで遊んでみっかな。


次ページ
最新レス表示
スレッドの検索
類似スレ一覧
話題のニュース
おまかせリスト
▼オプションを表示
暇つぶし2ch

4327日前に更新/231 KB
担当:undef