Oracle 質問総合スレat DB
Oracle 質問総合スレ - 暇つぶし2ch369: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を取りたまえ。アプリ自体のバグかもしれないし、これで切り分けができるだろう。
② Oracleのバグとは思えない。もし、万が一、バグがあるとするなら、.NET Framework自体のバグかもね。

とのアドバイスをいただきました。
①は確かにそのとおりで納得しました。
が、②の意見は…もし.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にできないのですが

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

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でも組んで遊んでみっかな。

594:NAME IS NULL
07/06/10 22:21:48
SQL始めて2日か3日程の者です。分からないことがあったので、アドバイスを頂けないでしょうか?
使っているのはOracle10gにあるSQL*PLUSというものです。
表A;codeと会社名が書いてる表(001 A社 002 B社といった感じの表)
表B;codeと設立日が書いてる表(001 1950/6/4 といった感じの表)
表C;code(表AやBのcodeの数字の後ろに期数が書かれ、目標達成ならP,未達成ならMとその後ろに書かれた数字)のある表{00157P 00153P 00212M等の書かれた表)
このデータがあるとき
①現在月(今なら6月)が設立月になっている会社を出し、設立何年目かを出すSQL分(A社 57期といった出力)
②各会社の期(設立から1年目で1期・・・と計算する)を算出(A社 57期といった出力)
③この結果を、会社名と期を列に持つ表にINSERTする
④表Cから、達成している会社名と期を出す(A社 57期 A社 53期といった出力)
調べても、例を使ったサイトとかが中々見つからず、困り果ててます。明日中に解かないといけないので、どうか助言をお願いします。

595:NAME IS NULL
07/06/10 22:53:17
作業 お見積り票
 ニコニコ・インテグレーター

今回の作業の
> PG 1名: 8h 拘束
> \350 x 8h : \2,800

プロジェクトマネージメント料
> \70,000 : \70,000

特別 お値引き
> \2,800

税込み計: \73,500-

596:594
07/06/10 23:00:59
①と②は自己解決なんとかできました。
③と④が未だ謎ですので、アドバイス等ありましたらお願いします
m(_ _)m

597:594
07/06/10 23:02:49
書き忘れです。③の「この結果」っていうのは、②の出力結果のことです。
連続投稿失礼しました。

598:NAME IS NULL
07/06/10 23:14:53
>>597

ヒント

insert into c select a.col2, b.col2 from a,b where a.col1=b.col1 and .....;

まあ、ようはinsert into c [2で使ったSQL]でいける。

599:NAME IS NULL
07/06/11 22:44:26
現在、汎用系SE(?)PGやってます。(基本的にはコボラーです)
将来の不安解消のための手段のひとつとしてOracleの勉強をしようかと思っています。
そこで質問があるのですが、現在、システム導入に当たって使用されるOracle
って10gがほとんどでしょうか?
私が関わったことある平成15~19年導入システム(汎用機→オープン系・1プロジェクトです。)
ではOracle8iが使われていました。
現在も8iや9iの需要はあるのでしょうか?保守はあると思うのですが…
新規導入は基本的に10gになるのでしょうか?
わかる方、申し訳ありませんが、教えて下さい。
よろしくお願いします。

600:NAME IS NULL
07/06/11 22:49:23
>>599
今なら新規導入は9iか10gになると思うよ。
そのうち11が出るから、9iも近々消えるだろうけどな。


601:NAME IS NULL
07/06/11 22:54:37
Windows版ならわざわざ9iにするメリットもないし。
Unix版でもやはり11が出ようかという時期に9iってのもなんだし。


602:NAME IS NULL
07/06/11 23:04:20
>>599
Oracle8iのサポート期間って終了しませんでしたっけ?
今からの新規案件は10gRelease2でしょうね、やっと安定した感があるので暫くは続くと思われです
(先のことなので予想半分ですが、11のRelease2が安定するまで)

603:599
07/06/11 23:57:22
>>600-602
アドバイスありがとうございます。
10gを勉強することにしました。

604:NAME IS NULL
07/06/12 11:26:49 oQuF+3Qh
保守なのでoracle8iを使ってます。
新しい登録するべきデータがテーブルの項目の桁数より大きくて困っています。
主キーに登録するデータではないのですが、
char型の項目の桁数を変更する方法はありますでしょうか?

方法がありましたら、検索のヒント又は関数名を教えてください。

605:NAME IS NULL
07/06/12 12:00:43 Y5HKReaS
くだらない質問なんですが
NVLって何かの略称ですか?
NVLだと言葉から意味がいまいちつかめなくてイメージがわかないんです

606:NAME IS NULL
07/06/12 12:58:59
>>605

Null VaLueの略だろ。
つまりNull値を指定した値で置き換えるという意味だ。

607:NAME IS NULL
07/06/12 13:07:40 Y5HKReaS
>>606
お陰で疑問が解けました
ありがとうございます

608:604
07/06/12 13:17:37
結局、別の項目を追加して放り込んでおくことにしました。
すみませんでした。

609:NAME IS NULL
07/06/12 14:01:43
>>605
Null-Value-Logic だよん

610:594
07/06/12 22:40:59
ヒント有難う御座いました。無事に解けました。
今現在は、VisualStudioで造ったプログラムにSQL文を書いて、Oracleに接続させてテーブルをselectしたりという、ODBC接続というものをやってます。
・VSでwin32コンソールアプリケーション(設定にMFC付与)でプロジェクトを作成
・最初から書かれてあるメインソースの「//アプリケーションの動作を記述するコードをここに挿入」の箇所から下に、ネットにあったサンプルを貼り付け
・Oracle接続するIDやPASSを書く箇所を、strCON = "DSN=dsn;UID=いつも使うID;PWD=いつも使うPASS"と書き換え
・strSql=""の箇所には、select * from 造ったテーブル、とSQL文を書いた。
以上の作業を行ったあとに、実行したのですが、実行する行「CRecordset rs (&db)~」でデバッグエラーが出ました。
このエラーの原因が分からないので、何かアドバイス頂けたらと思います。よろしくお願いします。
(貼っていいか分かりませんが、サンプルソースのURL「URLリンク(homepage1.nifty.com)」ここの、MFCでSELECTのソースです。貼ったのは。)
使用ソフト(VisualStudio2005、Oracle10g(ver.10,1,0,2,0))

611:NAME IS NULL
07/06/13 03:00:54
>>610

つ~かさ、ODBCでDB繋げにいくんだったらDSNの設定したのかい?
スタート→設定→管理ツール→データソース(ODBC)でまずは繋がる様にしないと
ならんだろ。
そのためにはtnsnames.oraの設定もしないとならないと思ったぞ。
そこで初めて設定してたDSN名をstrCON = "DSN=dsn;"の所で指定できる。

612:NAME IS NULL
07/06/20 22:58:28
オラクルマスターシルバーを取得したいと考えているのですが
特にお勧めの予備校?ってありますか?
埼玉浦和所沢 東京池袋新宿辺りでいいのがあったらいいなと思っています
どうかご教示くだsだい。お願いいたします。


613:NAME IS NULL
07/06/20 23:11:52
10gです。
sqlplusにて検索すると、データの後ろにやたらと空白が出力されます。
回避する方法はありますでしょうか?

例えば、

ID CHAR(5)
NAME CHAR(10)

のようなテーブルがあるとして、sqlplusでの出力結果が

ID          NAME
--------------- ------------------------------
XXXXX       NNNNNNNN
ZZZZZ       YYYYYYYYY
YYYYY<- 空白 -> UUUUUUUU

のようになります。本来であれば、

ID    NAME
------ ----------
XXXXX NNNNNNNN
ZZZZZ YYYYYYYYY
YYYYY UUUUUUUU

のように出力されるものだと思うのですが・・

614:NAME IS NULL
07/06/20 23:22:15
column format ID a5


615:NAME IS NULL
07/06/20 23:24:12
まちがえた
column ID format a5
だな。


616:NAME IS NULL
07/06/20 23:43:27
9iの頃は空白は出力されなかったのですが、
10gではcolumnコマンドを使って、カラム毎に設定が必要ということですか?

617:NAME IS NULL
07/06/20 23:45:24
>>616
UNICODE使ってないか?

618:NAME IS NULL
07/06/21 00:09:14
文字コードはOS、oracle共にEUCです。

619:NAME IS NULL
07/06/21 00:14:20
>>618
端末の文字コードじゃなくて、DBの方ね。

620:NAME IS NULL
07/06/21 00:22:35
EUCです。

621:NAME IS NULL
07/06/21 02:27:18
>>612

シルバーぐらいだったらオラクルマスターの参考書買って勉強した方がいい。

622:NAME IS NULL
07/06/21 02:42:24
>>613

俺の環境では9iも10gも同じように表示されたぞ?
ちなみにクライアントも10gだったけど。

623:NAME IS NULL
07/06/21 09:14:26
昨日から oracle.co.jp に繋がらないけどメンテ中?

624:NAME IS NULL
07/06/21 11:03:19
>>623

普通に繋がるけど?

625:NAME IS NULL
07/06/21 11:29:35
パブリックシノニムの一覧を表示する方法を教えてください

626:NAME IS NULL
07/06/21 13:34:23
>>624
こっちもルーティングが変わって繋がるようになった。
tracertを比較するとプロバイダの出口付近で詰まってたみたいでした。

627:NAME IS NULL
07/06/21 18:25:56 p/jATL4d
Oracle SQLDeveloperを落としてきて
check for updateをかけると
途中でWeb Account user name and passwordを聞いて来るのですが
普段Oracleの掲示板などにログインしているusernameとpasswordを入れても
違うと怒られます。
これ以外にWeb Account user name and passwordなんてものがあるのでしょうか??


628:NAME IS NULL
07/06/21 18:36:10 p/jATL4d
JapanのIDしか持ってない、とか。


ていうかUSの新規登録サイト、動かないっぽいんだけど。

629:NAME IS NULL
07/06/21 23:22:26
>>625

select * from dba_synonyms where owner='PUBLIC';
で、いいじゃね?

630:NAME IS NULL
07/06/23 01:20:19
かなり初歩的な質問と思うのですが、Oracleでエスケープすべき文字は「'」
(シングルクォート)だけでしょうか?
Oracleのバージョンは10.1.0.2です。

631:630
07/06/23 01:25:22
付け足します。
insertやupdateで文字列を追加、更新したりする時です。

632:デフォルトの名無しさん
07/06/24 23:57:45
>611さん
お礼遅れましたが、出来ました。アドバイス感謝です。

もう一つ分からない点が出てきてます。
存在しない行をDML文で操作した時に、エラーメッセージを出す方法が思いつきません。
例えば表を作って、列名「CODE」を作成してそこに「001,002,003」と3つ行をインサートし、
その後UPDATEやDELETE文で、「UPDATE ~ CODE='005';」としたとき、SQLPLUSでは、「0行が更新されました」
と出て、正常に処理が終わっています。
私が造りたいのは、この時にプログラムで
「存在しない行をDML文で操作したらエラーメッセージをcoutする」という処理にしたいんです。
SELECT文で存在しないデータを取り出す時のエラーメッセージは造れましたが、
DML文は、0行更新や0行削除のときも、正常に1行更新や1行削除の時も、プログラム上の動きが全く一緒なので
場合分けができないなぁと思ったんですが。
(DML文発行の時のロジックは、以下を外部関数Transにして{変数strSQLにSQL文を格納させてます}
{
CDatabase db.BeginingTrans();
try{
db.ExecuteSQL((LPCTSTR)strSQL); }
chatch (...){
&Database::RollBack; }
db.CommitTrans();
}
これを、UPDATEやDELETEしたい時に呼び出して使ってます。)

何かしらアドバイスありましたら、宜しくお願いします。

633:611
07/06/25 23:59:43
>>632

俺、VBから離れてもう7年以上経っちまってんだけど・・・?
とりあえずinsert、update、delete処理を打った時に、更新行が0という戻り値だったら
Counterを増やすという処理でいいんじゃないのか?

634:NAME IS NULL
07/06/28 11:15:49
VISTAからオラクルDBにODBC接続するとき、Microsoft ODBC for Oracle でないと
対応していないソフトがあって、XPの端末なら問題なく接続できるんだけれど
VISTAで同じ設定で接続するとエラーになって接続できないんだけれど
これは、ODBCドライバーのバージョンかなにかに問題があるのでしょうか?
接続先のOracleのバージョンは8,9の二つを試したけれど両方ともだめでした。
ちなみにOracle ODBC Driverなら接続できました。

635:NAME IS NULL
07/06/28 12:39:09
エラーの内容は?それを見ないと判断できんぞ。

636:NAME IS NULL
07/06/28 12:48:35
'Microsoft ODBC for Oracle' は、内部コマンドまたは外部コマンド、
操作可能なプログラムまたはバッチ ファイルとして認識されていません。

637:NAME IS NULL
07/06/28 13:17:13
エクセルからODBC接続しようとした場合、データソース名やユーザ名、パスワードを入力後
接続のテストボタンをクリックすると”プロバイダの初期化中にエラーが発生したため、
接続のテストに失敗しました。Oracleエラーが発生しましたが、エラーメッセージは
Oracleから取得できませんでした。”というメッセージが出ます。
まったく同じ条件でXPでやると問題なくいきます。
条件的に違うのは、ODBCドライバーのバージョンくらいです。

638:NAME IS NULL
07/06/28 14:16:45
ODBCといっても、ADO-ODBC経由もあるよね?
大して違わないかもしれないけど、やってみたら?


639:611
07/06/29 03:26:19
>>634

( ´ー`)つPatch 5337014: 10.2.0.3 PATCH SET FOR ORACLE DATABASE SERVER


640:NAME IS NULL
07/07/02 12:26:34 EJs3Qu6o
javaからoracle-xe 10iに接続しようとして
「ORA-12705: Cannot access NLS data files or invalid environment specified

というエラーメッセージがでます。
環境変数は確認して問題ないと思うんですが、
データベースのキャラクタセット、各国語キャラクタセットを確認すると
AL32UTF8、AL16UTF16と一致していませんでした。
これが原因なんでしょうか?

641:NAME IS NULL
07/07/03 05:25:55
>>640

鯖のタイプぐらい書け。
稀にだが、NLS関係の環境変数の設定で$ORACLE_HOMEとかが含まれていると
駄目だったりすることがある。
絶対パスで環境変数を指定すれば大丈夫だったりするが・・・。

642:NAME IS NULL
07/07/04 00:41:06
そのジャバで環境変数だけ出力するプログラム書いて実行した結果を貼れ。

643:NAME IS NULL
07/07/08 06:47:23 GkdOGLBy
質問です
DB:oracleXE 10g
使用ツール:common SQL Environment (ver.1.59)

上記の環境で、select lengthb('ああ') from dual
を実行すると、結果が4になると思いきや、6になります。
これは何が原因なのでしょうか?


644:NAME IS NULL
07/07/08 07:05:50
>>643
文字コードがutf-8何じゃないの?
utf-8なら「あ」は3バイトだったはず。


645:643
07/07/08 08:25:10
>>644
レスありがとうございました。当方vista使用のため、デフォルトがutf-8なのかもしれません。
文字コードの変換についてもうちょい調べてみます。


646:643
07/07/08 22:35:14
OS:Windows Vista
DB:oracleXE 10g
使用ツール:common SQL Environment (ver.1.59)

上記環境にて、
SELECT VALUE FROM NLS_DATABASE_PARAMETERS
WHERE PARAMETER='NLS_CHARACTERSET'
を実行したところ、AL32UTF8 の値を取得しました。

GRANT ALL PRIVILEGES TO USERNAMEで権限を与えた(つもり)の後、
UPDATE NLS_DATABASE_PARAMETERS SET VALUE = 'JA16SJISTILDE'
WHERE PARAMETER='NLS_CHARACTERSET'
を実行しようとしましたが、
ORA-01031: 権限が不足しています。
のメッセージが出力されました。

Internet ExplorerのエンコードがSJISだと文字化けが起こるので、oracleの文字コードのみ
変更したいのですが、この場合はどのようにしたらよいのでしょうか?

647:NAME IS NULL
07/07/08 22:56:33
>>646

DBの文字コードは CREATE DATABASE 文でしか指定できなくて、
後からは変えられないんじゃないのかな。

648:NAME IS NULL
07/07/08 23:06:48
>>646

DBのキャラクターセットを変更したい場合には、既存のキャラクターセットの
スーパーセットにしか変更する事ができない。
つまりUTF8はUS7ASCIIの完全なスーパーセットであるから変更は可能だが、
JA16SJISからJA16EUCはスーパーセットではないため変更は出来ない。
この場合にはDBのFull Exp/Impで対応する。

649:643
07/07/08 23:30:54
>>647
なるほど。それでは
select lengthb('ああ') from dual
などの場合はあきらめるしかなさそうですね。
oracle全体の文字コードを設定するファイルがあると思ってました。

>>648
ありがとうございました。

650:NAME IS NULL
07/07/09 00:18:38
SQL☆PLUSでINSERT文を繰り返したいのですが
なにかループさせる方法はないでしょうか?

651:NAME IS NULL
07/07/09 05:31:43
>>650

PL/SQL使えばいいじゃん。

652:NAME IS NULL
07/07/09 22:45:19
>>650

PL/SQL使えばいいだろ?
こんな感じに?

begin
for i IN 1..5000 LOOP /* 5,000 rows insert */
insert into hoge values ('boge','boe');
commit;
end loop;
end;
/


653:NAME IS NULL
07/07/13 00:10:20
教えてください。
SELECTの監査証跡を取る設定にしてるとき、
サブクエリを1つ使ったSELECT文を発行した場合、
監査レコードは2件作られるんでしょうか?

654:NAME IS NULL
07/07/20 01:35:19
スレ違いでしたらすいません。
今、OCIを使ってOracle10gのテーブルにデータを挿入するプログラムを作っている
のですが、OCIExecute()関数実行中にネットワークに障害がおきてしまうと、復旧
するまでずーっとその関数内でで止まったままになってしまうかと思います、
こういう場合、皆さんはどのようにしていますか?

655:NAME IS NULL
07/07/20 04:17:56
>>654

N/W障害なら普通はTCP/IPのタイムアウトでORA-3113/3115が返されるだろ。
まあ、TCP/IPのタイムアウトは鯖や設定によっても違うけど、大抵は10分とか
そんなんだろ。

656:NAME IS NULL
07/07/23 19:28:04 tP2GglY4
Oracle10gって
DOS窓でoracle実行でアラートログにORA-600って吐かれない風に変わったの?
検証したいんだが。。

657:NAME IS NULL
07/07/24 09:25:36
不吉な番号を書くな。出るだろ。季節だし。

658:NAME IS NULL
07/07/24 13:23:47
言霊の信者か。


659:NAME IS NULL
07/07/24 17:45:58 BbH3ih3M
Windows のバッチファイルから、PL/SQLをキックしたいのですが
やり方がわかりません。
D:\oracle\product\10.2.0\client_1\BIN\sqlplus.exe XXX/XXX@ORA92
 ここまではOKなんですが、パッケージがキックできません。

660:NAME IS NULL
07/07/24 18:23:42
>>659
sqlplus.exe XXX/XXX@ORA92  @hoge.sql
SQLを書いたファイルが必要

hoge.sql
---
execute xxx;
exit
---

661:NAME IS NULL
07/07/25 09:55:36 b2CcIo5r
ありがとうございます、packageの場合がわかりません。

662:NAME IS NULL
07/07/25 10:22:37
execute パッケージ名.xxx
ではだめ?

663:NAME IS NULL
07/07/25 16:32:53 b2CcIo5r
BEGIN XX_XXXXXX; END;
*
行1でエラーが発生しました。:
ORA-06550: 行1、列7:
PLS-00221: 'XX_XXXXXX'がプロシージャではないか、または未定義です。
ORA-06550: 行1、列7:
PL/SQL: Statement ignored

このエラーが出まして動きません。
パッケージ名の後ろは何を書けばよいのですか?

初心者ですみません。

664:NAME IS NULL
07/07/25 17:05:06 vso8Zt4w
パッケージの実行は開始してると思うが
パッケージそのもの記述がよろしくないのでは?
普通にSQL*Plusを開いてhoge.sqlをコピペして実行してみると
同じエラーが出ると思ふ。
つまりキックはできたがsqlの実行がNG。
エラーメッセージを頼りに他のパッケージとの依存関係はないか
文法的に間違いはないのかよく見てみー。



665:NAME IS NULL
07/07/25 20:44:17 AW0ipeA1
初心者ですみません。

もらったパッケージなんでごめんなさい。
文法を確認してみます。

666:NAME IS NULL
07/07/26 10:01:11 vEHhwLTe
>>664
execute xxx.xxx;
で動きました。素人でご迷惑をおかけしました。

667:NAME IS NULL
07/07/30 21:10:01 2PDkD7wn
素人です。

windows vistaにオラクル10gのトライアル版(Release2)をインストールしようとすると、「OSに互換性がない」と怒られます。
システム要件を見るとvistaでも良いはずなのですが・・・

vistaにトライアル版入れる方法教えて下さい。

668:NAME IS NULL
07/07/30 22:46:49
>>667

どうやらPatch 5860454をインスコする必要があるみたいだな。
パッチの入手方法はMetalinkとかのアカウント持っていない人のやり方は知らん。

面倒だからU.S. OTNからVista版ダウソしろ。
そっちの方が早いだろ。

URLリンク(www.oracle.com)

669:667
07/07/31 19:33:52 upH6NrcM
>>668
そうか、U.S.という手があったか!
㌧クス



670:NAME IS NULL
07/08/01 10:14:13 +sJRPFfW
Oracle で ociを使ってプログラムを作るときに、
コネクションプーリングとか自前で実装するのが定石なんでしょうか。
それとも、そういった機能がすでにあるのでしょうか?

671:NAME IS NULL
07/08/01 16:14:15 O24DaM8E
初歩的な質問ですけど、失礼します。

VisualStudioでOracleに接続しようとすると
「ora-12154 サービス名を解決できませんでした」

と出てしまい、接続できません。

SQL+などでは、問題なく接続できます。

VisualStdioのほうで何か設定などが必要なのでしょうか?
板違いだったらすいません。

672:NAME IS NULL
07/08/01 17:49:56
>>671
ODBC

673:NAME IS NULL
07/08/01 23:20:16
>>671

>>263ぐらいヒントがあるな。

674:NAME IS NULL
07/08/02 08:56:14
最近、DBを勉強し始めたものです。

テーブルロックについてつまずいてます。

oracleにはテーブルロックのモードが5パターンあります。
・行共有テーブルロック
・行排他テーブルロック
・共有テーブルロック
・共有行排他ロック
・排他ロック

共有という言葉が引っかかるのですが、ロックを共有して
行うことができるという意味合いなのでしょうか?
だとすると、行排他テーブルロックと行排他テーブルロックは
同時に取得可能なので、上記のような意味合いとは違うのかなぁ
と思ってます。

共有という言葉の意味合いについて教えてもらえないでしょうか?

675:NAME IS NULL
07/08/02 10:00:10
>>674
URLリンク(biz.rivus.jp) とか。

676:674
07/08/03 09:29:51
>>675
理解できなかったです。orz。


677:NAME IS NULL
07/08/03 11:40:15
>>676
自分も共有に違和感はあったが慣れるまでshare lockと読んでおけばいいじゃん
share:分けること。分配。分担。
独占使用していないロックってこと

678:NAME IS NULL
07/08/03 13:04:49
Oracle のユーザ sysやsystemのパスワードが最後に変更された
日付を確認するにはどうすればいいのでしょうか?
内部統制でパスワード変更日を表示しろと言われて困っています。

679:NAME IS NULL
07/08/03 16:20:15
DEFAULTプロファイルでPASSWORD_VERIFY_FUNCTION有効にして、
ファンクションの中身を適当にカスタマイズすればいいんじゃね?


680:NAME IS NULL
07/08/03 18:23:43
>>677
違和感感じてるのは私だけかと思ってましたが、
いい意味で違ったみたいですね。

ありがとうございました。

681:NAME IS NULL
07/08/04 02:19:39
>>678

after alterトリガー使えばいいべ。

1. sysスキーマに監査用の表を作成

create table audit_password_change
(
username varchar2(10),
changed_by varchar2(10),
timestamp date
);

2. after alterトリガーをsysスキーマ内に作成

CREATE or REPLACE TRIGGER captuer_alter_user AFTER ALTER on database
BEGIN
IF (ora_dict_obj_type='USER' and (ora_dict_obj_name='SYSTEM' or ora_dict_obj_name='SYS') and ora_des_encrypted_password is not null) THEN
insert into audit_password_change
values (ora_dict_obj_name,
ora_login_user,
sysdate);
END IF;
END;
/

3. 実際にsysのパスワードを変更してみる。

SQL> show user
USER is "SYS"
SQL> alter user system identified by hogeboge;

4. 監査表をセレクト

SQL> select username, changed_by, to_char(timestamp,'YY/MM/DD HH24:MI:SS') changed_date from audit_password_change;

USERNAME CHANGED_BY CHANGED_DATE
---------- ---------- -----------------
SYSTEM SYS 07/08/03 13:13:51



682:NAME IS NULL
07/08/05 15:32:53 658vIUe0
OTNでOracle Database 10g Release 2(10.2.0)for Microsoft Windows 32bit
のトライアル版をダウンロードしましたがsetup.exeを起動すると
「内部エラーが発生しました。」とでてしまいます。
OSはWindows vista home basic です。
vista では動かないんですかね?

683:NAME IS NULL
07/08/05 16:32:48
URLリンク(www.oracle.com)



684:NAME IS NULL
07/08/05 20:37:09
>>682

全部とは言わないが、前後30ぐらいのスレぐらい嫁や。
Vistaで検索ぐらいしろや。
>>668ぐらい見てみろや。

685:NAME IS NULL
07/08/05 20:55:06
素朴な疑問ですが、oracleで数十テラバイトのデータを運用しても、
特別パフォーマンスが落ちるようなことはないですか?
インデックス等のチューニングをしていれば、データサイズによるボトルネックは
ある程度無視できるのかな。
oracleはデータサイズ無制限って聞いたことがあるので。

686:683
07/08/05 20:56:48
>>684

前後30ぐらいって、後30はどうやって見るの?


687:NAME IS NULL
07/08/05 20:59:28
>oracleはデータサイズ無制限って聞いたことがあるので。

誰から聞いたんだ。
そんなデマ。

688:NAME IS NULL
07/08/05 21:41:04
100TBのデータベースもある。


689:NAME IS NULL
07/08/05 23:26:52
で、685はどうなの?

690:NAME IS NULL
07/08/06 00:20:17
質問があいまい過ぎる。
基本的にはデータサイズというかレコード件数によってパフォーマンスが変わってくるのは当たり前。
あとはレコードサイズに対してブロックサイズが適切かどうか、など物理設計レベルでも影響受けるけど。


691:NAME IS NULL
07/08/06 06:27:38
oracle 10gですが、どうしてこんなにメモリ食うんですか?

692:NAME IS NULL
07/08/06 08:17:05
>>691
仕様。

つかOracle7のころのサクサク感をもう一度、
と思ってるのは、俺だけじゃないと思うんだが、
バージョンが上がるごとにどんどん重くなるよ。orz


693:678
07/08/06 10:02:54
>>679,681
ありがとうございます。やってみます。

694:NAME IS NULL
07/08/06 18:01:40
yyyy m str
---------
2007 4 aaa
2007 5 bbb
2007 6 ccc
こんなテーブルがあったとして、selectの結果を
1レコードに収めるいい方法ありますか?

yyyy str4 str5 str6
----------------
2007 aaa bbb ccc
こんなイメージです。月別で行になっているのを列で表示したいのです。

一応これで出来るみたいなんですが、もしや
もっとスマートな書き方があるのかなと思いまして。
select str,(select str from tbl where yyyy=2007 and m=5),
(select str from tbl where yyyy=2007 and m=6)
from tbl where yyyy=2007 and m=4

宜しくお願いします。

695:NAME IS NULL
07/08/06 20:32:57
>>694

コンカチネーションの||を使えば出来そうなきもするけどな。



696:NAME IS NULL
07/08/06 21:12:46
>>694
クロス集計

697:NAME IS NULL
07/08/06 23:40:22
Oracleデータベースサーバではなく、Oracle ClientのインストールでもOEMは使用出来ますか?

698:NAME IS NULL
07/08/07 00:08:30
>>697

昔ながらのJavaベースのクライアント型OEMなら。

699:694
07/08/07 10:25:47
>695-696
回答ありがとうございます。

クロス集計を調べてみたら下記のやり方で
期待通りの出力になりました!感謝!

select
sum(decode(m,4,str,0)) "str4",
sum(decode(m,5,str,0)) "str5",
sum(decode(m,6,str,0)) "str6"
from tbl
group by yyyy;

700:NAME IS NULL
07/08/07 19:16:42
初心者です。質問させてください。

時間を扱うのはどの型で決めればいいと思いますか?

時間といいますと、一時間や二時間の時間の単位で、日付などの時刻ではない場合です。
DateTimeやTime型が一般的なのでしょうか?

701:NAME IS NULL
07/08/07 22:56:06
>>700

で、あなた自身はどう思うの?
まずどういった検索条件で使われるかが分かると、どのデータ型がいいかも
分かってくると思うけど?

702:NAME IS NULL
07/08/08 11:44:52
>>700
SQLリファレンス「Oracle SQL の基本要素」の「データ型」参照。
時刻ではない、ってのは、リファレンスでいうところの「期間」?
であれば INTERVAL DAY TO SECOND か、または簡単に整数型。


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