Oracle 質問総合スレ ..
[2ch|▼Menu]
369:NAME IS NULL
07/04/06 08:27:03
>>367

ああなるほどね。やっと >>367 の言ってることがわかったよ。
ちゃんと書かないお前が悪いな。


370:NAME IS NULL
07/04/06 22:21:59
DB板ってなんでこんな人間しかいないんだ?w
みんなコミュニケーション下手すぎwww

371:NAME IS NULL
07/04/07 21:04:10
しかしあら不思議!SQLでしゃべるとみんな饒舌になるのでした

372:NAME IS NULL
07/04/07 21:33:26
>>370

ここの人達、バッファが足りなくてちょっとディスクリード起こしてしまっているんです。

373:NAME IS NULL
07/04/08 13:47:14
>>355
sql*loader使わないと無理

374:NAME IS NULL
07/04/09 21:20:27 dgbyTs5E
windows版oracle10G パッチの適用方法を教えて頂けないでしょうか?
readmeにはUNIX版しかないので困っております。どこかに説明してあるサイトやどなたか教えて頂けないでしょうか?


375:NAME IS NULL
07/04/09 21:31:30
ouiを起動して、パッチのjarを指定するだけ。


376:NAME IS NULL
07/04/09 21:45:39 dgbyTs5E
>>375
CDから解凍する必要はないですか?

377:NAME IS NULL
07/04/09 22:16:59
あったっけ?
っていうか、やってみればいいじゃん。
パッチのリストが読み込まれればそれで成功でしょ。
甘利にも簡単なことなんで、いちいち細かいことを覚えてないって人が俺も含めてほとんどだと思うよ。


378:NAME IS NULL
07/04/10 21:56:22 D+v1PS8Y
sqlplusでデータベースに接続出来ない。
ORA-12154: TNS: 指定された接続識別子を解決できませんでした
↑これ。
tnsnames.oraとか知らんから馬鹿でもわかるように解決する手順教えてくれ。

379:NAME IS NULL
07/04/10 22:20:12
>>378
サポート契約しているベンダーへレッツゴー。

380:NAME IS NULL
07/04/11 07:51:05
>>378
Oracle Netの勉強汁www
じゃなきゃサポート契約汁www

381:NAME IS NULL
07/04/17 02:33:01 VDbMfobx
接続に関して躓いているので、アドバイスをください。

環境はlinux に10g を入れてサービスとして起動しようとしています。

一台のマシンにインストールしたオラクルに対して
リスナーを設定し、複数のDB (=インスタンス)を作成したわけですが、
片方のDB に対してアクセスができませんでした。

tnsname の設定は問題ないと思っています。
listener の設定が不安です。
調べていると、listener のファイル内に作成した各DB のSIDを書くような記述が見受けられるのですが、
netca で行うリスナーの設定では、そのような入力は求められませんでした。

複数のDB へのアクセスを一つのリスナーで受けることは可能なのでしょうか?
また、その場合のlistener.ora の記述方法はどういったものになるのでしょうか?

382:NAME IS NULL
07/04/17 07:36:18
>>381
できる。

listener.oraの記述については、マニュアル
「Oracle Database Net Services リファレンス」の
「リスナー・パラメータ(listener.ora)」あたりを
参照してもらえば分かると思うけど、
SID_LIST_listener_name=
  (SID_LIST=
   (SID_DESC=
    (GLOBAL_DBNAME=global_database_name)
    (SID_NAME=sid)
    (ORACLE_HOME=oracle_home))
   (SID_DESC=...))
のように書く。

要はSID_DESCのセクションを複数記述する。


383:381
07/04/17 08:43:50 VDbMfobx
>>382
ご回答ありがとうございます。やってみます。
ちなみに、リスナーを複数用意するのはどういった場合なのでしょうか?
一つでも使えるのに、複数作成することもあるのですか?

384:NAME IS NULL
07/04/17 09:01:39
>>383
複数NICで負荷分散させたいときとかに、
複数リスナー立ち上げる。

385:NAME IS NULL
07/04/18 02:10:18
>>384

複数NICの場合はにはO/S側でチーミングなりボンディングすればいいんでないの?

386:NAME IS NULL
07/04/18 02:24:47
レイヤーが違うから、どっちがいいかは設計方針によるんじゃないの?
listenerでやる方が高度なことができるけど、反面Oracleのバグや仕様に悩まされることもあるかもしれない。
とかね。


387:NAME IS NULL
07/04/18 09:47:54
アプリケーションプログラムの接続のためにlistener.oraにSIDやGLOBAL_DBNAME
を設定するのは邪道。これはOracle8のころのやりかた。

Oracleインスタンスの初期化パラメータLOCAL_LISTENERを設定し、Oracleインスタンス
からOracleリスナーに自分を登録させるのが今の方法。

388:NAME IS NULL
07/04/18 13:43:26
なるほど。


389:NAME IS NULL
07/04/20 16:49:47 W5Lcj5GJ
オラクルとアクセスとSQLの違いを教えてください。
何を導入したらよいのか解らず困っています。
よろしく御願い致します。

390:NAME IS NULL
07/04/20 17:23:40
違いが多くて同じ箇所をあげたほうが早い。全く別物だと思ってOracleの入門書からはじめよう。

391:NAME IS NULL
07/04/20 19:07:33 v3OhOLUY
沖縄県の方へ(命に関わる注意事項です)

沖縄県での選挙ですが、どうか民主党だけは避けてください。県民の生命に関わる可能性があります。
民主党の最大の公約は一国二制度(※)ですが、一度「一国二制度 沖縄 三千万」で検索をお願いします。
この際、民主党のHPで調べても良いです。以下の注釈↓と矛盾することは書いてないはずですから…

※一国二制度
 簡単に言えば沖縄を中国と日本の共有物にし、そこに3000万人の中国人を入植させます。
 (つまり沖縄人口の 96% を中国人にして、実質、沖縄を中国人の居住地とします。)
 さらに「自主」の名の下、沖縄で有事が起きても自衛隊は干渉できません。
 3000万人の中国人が、少数派となった130万人の日本人に何をしても、です。
 そして反日教育を受けた中国人の反日感情の強さは、ほとんどの日本人の理解を超えるものです。

今回の選挙で民主党が勝った場合、「自主」「発展」を連呼しつつ段階的に進めていくことになります。
自主と言っても、自主を認めるのが「住人の96%が中国人となった」後だということに気をつけてください。
発展と言っても、新沖縄の少数派となった「少数民族日本人」の発展ではないことに気をつけてください。

392:NAME IS NULL
07/04/20 21:17:46
>>389
そんなこと聞いてるようなレベルならアクセスにしとけ
つかSQLてMYSQLのことか?

393:NAME IS NULL
07/04/21 02:31:48 Vxfi8HR4
ここで言っているインスタンスってDB のことでいいですか?
DBCA とかで, DB 作成というのがありますが、それはインスタンスの作成である。と。

394:NAME IS NULL
07/04/21 09:50:03
DBとインスタンスは1対1に対応するからね。

DBCAで作るのはDBだな。
インスタンスはSGAとプロセスの集合を指す。


395:NAME IS NULL
07/04/21 11:46:51
>>394

必ずしも1対1とは限らない。
RACの様に複数インスタンス対1DBという対応だってありうる。


396:NAME IS NULL
07/04/21 17:47:21 iUeSgJd/
低レベルな問い合わせですみません。
教えて下さい。
バージョンは9iです。

・SQL1文で
・SELECTの結果を見て、動的にFROM句/where句を変えたい。
・正確にはプロCOBOLん中で使います。
・PL/SQLは使用できません。

↓実イメージ
SELECT
名簿.生徒名,
名簿.理系文系区分
理系費用.学費,
文系費用.学費
from
名簿, 理系学費, 文系学費

(このままだと、学費テーブルとのジョインが上手くいかないのはわかっています。)
名簿テーブルの理系文系区分が、理系だったら、理系費用テーブルをジョインしたい。
文系だったら、文系費用テーブルをジョインしたい、みたいな。。。

一応、解決策は一つ思い付いています。
理系と文系のそれぞれ費用テーブルにジョインした問い合わせを、
UNIONすればイイってな感じは思いついてます。
ただ、SQLん中でIF文とか書けるのかなぁ、というのがわからなくて。


397:NAME IS NULL
07/04/21 18:51:54
>>396
IF文は要らない。
名簿テーブルの理系/文系の部分集合と結合できれば良い。

select a.生徒名,a.理系文系区分,b.学費
from 名簿 a,理系学費 b
where a.理系文系区分=理系
union
select a.生徒名,a.理系文系区分,b.学費
from 名簿 a,理系学費 b
where a.理系文系区分=理系


398:NAME IS NULL
07/04/21 19:15:08
文系は廃止です!

399:NAME IS NULL
07/04/21 19:24:34
やさしいな
漏れなら参考書で調べたのか?と聞いてやりたいが

400:396
07/04/21 20:44:57 iUeSgJd/


>>397
ありがとうございます。
しかし、私の書き方が悪かったようです。すみません。
397様の書いてくださった問い合わせ文はイメージできていたんです。

ただ、別の解決策がないのかを模索していました。
(PL/SQL以外で)SQL文の中にIF文が書けるのか、
動的に構文を書き換える事が出来るのかが知りたかったのです。

>>399
調べてみました。
IF文で逆引きを行うとCASE文しか見つけれませんでした。。。


401:NAME IS NULL
07/04/22 00:11:59
>>396
個人的には学費テーブルを文系用、理系用に分割していることが
設計ミスのようにも感じますが、

>IF文で逆引きを行うとCASE文しか見つけれませんでした。。。
そのCASE文&スカラー副問合せを使用して、

SELECT 生徒名,理系文系区分
,CASE 理系文系区分
 WHEN '文系' THEN (SELECT 学費 FROM 文系学費)
 WHEN '理系' THEN (SELECT 学費 FROM 理系学費)
END 学費
FROM 名簿

402:396
07/04/22 00:49:45 4IKXQWUf
>>401
ありがとうございます。
月曜になれば、実際に端末叩いて確認できるのですが、
今現在、確認手段がないので、よろしければ、も一つご教授下さい。

下記のような問い合わせは成立するでしょうか?

SELECT a.生徒名, a.理系文系区分, a.授業科目コード
,CASE a.理系文系区分
 WHEN '文系' THEN (SELECT b.学費 FROM 文系学費 b WHERE a.授業科目コード = b.授業科目コード)
 WHEN '理系' THEN (SELECT c.学費 FROM 理系学費 c WHERE a.授業科目コード = c.授業科目コード)
END 学費
FROM 名簿 a


> 個人的には学費テーブルを文系用、理系用に分割していることが
> 設計ミスのようにも感じますが

本来的には2つの問い合わせを作成するハズで、
それが正統のハズが大人の事情で orz

403:NAME IS NULL
07/04/22 01:43:37
>>396
>下記のような問い合わせは成立するでしょうか?
構文的、SQLなどから推測できるテーブル構成的には
問題ないかと思います。

404:396
07/04/22 02:01:01
>>403
ありがとうございました!
助かりました!

405:NAME IS NULL
07/04/22 11:59:16
>>402
授業科目コードが文系学費テーブル|理系学費テーブルの一意キーであれば。



406:NAME IS NULL
07/04/22 14:42:56 RabniuWG
テーブル作成シェルを流して、その後、
もう一度、テーブル作成シェルを実行すると、エラーとなりますよね?
(drop tableで一旦、テーブル削除をしないと。)
でも、1回目に流したテーブル作成シェルのテーブル名が大文字で、
2回目に流したテーブル作成シェルのテーブル名が小文字の場合って
正常にテーブルが作成されてしまいませんか?

407:NAME IS NULL
07/04/22 14:50:33
>>406
Oracleの場合、オブジェクト名は大文字・小文字区別されないよ。
どうなるか分かるよな?

408:NAME IS NULL
07/04/22 15:43:14
>>407
テーブル作成時にダブルクォーテーションで囲むと
明示的に大文字・小文字が区別されるよ!

そんなことするやつ少ないとおもうけど

409:NAME IS NULL
07/04/22 15:53:16
>>406
大文字と小文字のテーブルができただけ
何が問題なんだ?

410:396
07/04/22 20:13:05
>>405
ありがとうございます。
認識いたしました。

411:NAME IS NULL
07/04/24 14:58:39 Fp+zC6oF
あるテーブルの主キーでの削除に非常に時間が掛かるのですが、
どういったことが原因として考えられるでしょうか?

外部キーで沢山参照されているテーブルだったので、それらの
cascade削除をしないようにしてみたのですが、処理時間に大きな
改善は見られませんでした。

412:NAME IS NULL
07/04/24 15:37:26
>>411
トレース取ってみて、
SELECTでのレコード取得時と、
DELETE時のCOST比較してみたら?

413:NAME IS NULL
07/04/24 16:07:30
>>411
何件中何件削除してる?

414:NAME IS NULL
07/04/24 23:01:59
>>411
検索性能重視のテーブルでインデックスいっぱいあったりする?

415:NAME IS NULL
07/04/25 01:03:22
リリースノートによると、oo4o 9.2.4.4はWin2003に対応していないと
なっていますが、問題なく動作しています。
オラクルがいう「システム要件」というのは、絶対なんでしょうか?


416:NAME IS NULL
07/04/25 01:10:56
サポートの問題とかいろいろある。


417:NAME IS NULL
07/04/25 09:40:07
>>415
日本オラクルが「問題有りませんよ」と
公式発表しているのがシステム要件だろ。

それ以外の組み合わせで何か起きてもサポート対象外だし、
何か起きるかどうかも日本オラクルでは把握すらしてないだろwww


418:NAME IS NULL
07/04/25 22:02:39
>>415
動作保証されていない組み合わせだと
表面上うまく動いているように見えるかもしれないし、
間違った操作でもそのまま何も言わずに動いてくれるかもしれないし、
バックアップをリカバリしたときに元通りにならないかもしれないし、
って感じなのかもね。

419:NAME IS NULL
07/04/25 23:53:04 idDHPFKk
オラクルサーバーの物理的な入れ替えというのを行うために
今あるデータベースを一時的に外部にまるまる保存したいんですが、
現実的な方法ってどういうものがありますか?

データベースはテーブル数などは多いけど容量的には小さいものです。
ユーザー名なども保存して再び同じ設定で使いたいのですが、
なにぶんこういう経験がゼロなもので何から調べて良いのかもわかりません。

丸投げに近い形で済みませんが、どうか宜しくお願い致します。

420:NAME IS NULL
07/04/26 00:41:34
inportとexport

421:NAME IS NULL
07/04/26 00:51:12
>>420
お前、微妙に意地悪だな。

422:NAME IS NULL
07/04/26 19:03:57
>>420
ありがとうございます。
オラクルのメニューの中にあるエクスポートを実行しようとしたら
ユーザー名とパスワードが通りませんでしたが、
なんとか頑張ってみます。

423:NAME IS NULL
07/04/26 20:17:29
>>422
新しいサーバに同じバージョンで移行するなら
コールドバックアップしてリカバリでも良いんだけどな。

まぁ、どっちも手間的にはたいして変わらんと思うけど。


424:NAME IS NULL
07/04/26 20:37:32
>>423
コールドバックアップですか?
またググってみます。

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

425:NAME IS NULL
07/04/27 00:30:36
ストアドプロシージャに登録してバッチ処理を行うのですが
処理中の件数をリアルタイムに表示する方法はありますでしょうか?
通常はできなさそうなのですが何とか表示したいのです。。。

426:NAME IS NULL
07/04/27 01:06:45 HdP4V3Wp
ソートを2重にしたいんだけどオラクルではどうすればいいのでしょうか?
例えば「値段」を降順に並べたあと、もし値段の値が一緒だった場合「商品名」が昇順に並ぶようにしたいのですが

427:NAME IS NULL
07/04/27 01:10:05
>>426
order by 値段 desc, 商品名 asc

428:NAME IS NULL
07/04/27 01:10:52
>>425
処理度合いテーブルを作って,自律型トランザクションで進行状況を出力する.
別アプリでそのテーブルを照会する.

>>426
Order by 値段,商品名

429:NAME IS NULL
07/04/27 02:07:59
>>428
ふむ〜やっぱりそれしかないですかね〜
telnetから処理を行っているので実行したら処理終了まで
無通信の状態になってしまい切断されてしまうのです。
そもそもtelnetを使うのが間違いですかね・・・orz

430:NAME IS NULL
07/04/27 03:03:14
>>429
ストアドでUTL_FILEつかってログ出力させ、それをtailするのが一番簡単だとはおもう。
どっちにしろ、何かしらバッチのログを採るのが普通でしょ?


431:NAME IS NULL
07/04/27 05:36:02
>>419

鯖の種類何よ?
ちなみに移行元の鯖と移行先との鯖は同時に立ち上げ可能なのか?
それで大分手間も代わってくるけどな。

432:NAME IS NULL
07/04/27 05:38:13
>>429

Telnet側でKeep Aliveパケット送ればいいじゃん?

433:NAME IS NULL
07/04/28 01:28:32
ログは撮りますけどUTL_FILE使用しなければ処理終了後に一括出力ですよね・・・
telnet切断は無通信時間を延ばしてもらうことで対応することにしました^^;

434:NAME IS NULL
07/04/28 02:12:56
telnetってフォアグランドで何か実行していても切れたっけ?
って思ったけど、
OSが切断しなくても途中のNW機器が切ってしまうことがあるな。


435:NAME IS NULL
07/04/28 06:35:40
>>433

screenなりいれて、鯖側でやればいいじゃん?

URLリンク(q-eng.imat.eng.osaka-cu.ac.jp)

436:NAME IS NULL
07/04/28 23:23:42
質問です。
C言語でOracle10gを利用することになったのですが、
接続の方法にはPro*CとOCIの2つしかないのでしょうか?
また、OCIの場合、connectやselect,insert等をC言語の関数化することは可能でしょうか?

437:NAME IS NULL
07/04/28 23:33:25
>>436
どうとでも出来る。
まずはやってみろ。


438:308
07/04/29 13:33:30
>>310-314

ありがとうございます。
早速やってみたところ、極めて稀にはなったのですが、やはり発生します。
そもそも一セッションしかDBに接続していないのに、
なぜだろうと。。。勢い余ってOracleのサポートにTELしてしまったところ

@ SQL traceを取りたまえ。アプリ自体のバグかもしれないし、これで切り分けができるだろう。
A Oracleのバグとは思えない。もし、万が一、バグがあるとするなら、.NET Framework自体のバグかもね。

とのアドバイスをいただきました。
@は確かにそのとおりで納得しました。
が、Aの意見は…もし.NET自体のバグだとすると… (((( ;゚Д゚))))ガクガクブルブル!

439:NAME IS NULL
07/04/29 15:37:10
>>438
バグはどこにでもある。


440:NAME IS NULL
07/04/29 15:43:49
.NET Framework本体より、ODP.NETの方が潜在的にバグが多そうだしなw


441:NAME IS NULL
07/04/29 20:44:57
Oracleの資格取ったけど、会社ではDB2なんだよね。
家ではOracleDBを入れてみたいんだけど、もっとも安いOracle製品ってどれ?
値段も教えてほしい。

442:NAME IS NULL
07/04/29 20:50:14
大型連休上げ

443:NAME IS NULL
07/04/29 20:57:17
>>441
URLリンク(japan.cnet.com)

444:NAME IS NULL
07/04/29 21:31:04
>>441
Express Editionがタダ。
一番安いのはPersonal Edition。

Enterprise Editionでしか使えない
いろんなオプションとかも
(ライセンス違反なしで)試したいなら
Personalを買うのが良い。


445:NAME IS NULL
07/04/29 21:57:11
試すだけならEEもダウンロードできるだろ

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にできないのですが

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


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

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