
Oracle9iでテーブル内容をスプール出力していますが、カラム単位で余白を削除したい
(トリムをかけたい)ので以下のようにカラムを連結させてスプールしています。
set colsep ','
spool test.csv
select
a ||','||
b ||','||
c
from test_table
spool off
実際の項目数は100以上あり、レコードの最大長も数千バイトになりますが、
各項目にMAXの値を入力して上記スプールを実行したところ、以下のエラーメッセージが
出力されました。
「ORA-01489: 文字列を連結した結果、長さが最大長を超えました」
データを連結した結果の長さが上限を超えたということなのでしょうが、
この最大長はどこで設定されているものなのでしょうか?
また、そもそもスプール出力でトリムが効かないためにこのようなやり方で
出力していますが、他によい方法をご存知の方いましたら教えて下さい。
よろしくお願いします。
No.4ベストアンサー
- 回答日時:
>>Code Tipsの内容も実際に試してみたのですが、結局のところ項目を連結させる
>>やり方では4000バイトまでが限度ということだと判断したのですが
4000バイトまでが限度 とは、どのような理由からでしょうか?
以下のSQLで4000バイトオーバーは可能です。(32KBの壁はあります)
既に完成度の高いスクリプトがデバッグ済みで存在するのに
同じものを 1からコーディングするのは、(自分の勉強にはなるとは思いますが) 意味のない行為だと思いますので、
Code Tipsをお勧めしました。
SPOOL HOGE.TXT
SET PAGESIZE 0
SET LINESIZE 32767
SET LONG 40000
SET LONGC 40000
SET TRIMSPOOL ON
SET FEEDBACK OFF
SET VERIFY OFF
SELECT
TO_CLOB('')
|| LPAD('1', 4000,'1')
|| LPAD('2', 4000,'2')
|| LPAD('3', 4000,'3')
|| LPAD('4', 4000,'4')
|| LPAD('5', 4000,'5')
|| LPAD('6', 4000,'6')
|| LPAD('7', 4000,'7')
|| LPAD('8', 4000,'8')
|| LPAD('9', 4000,'9')
|| LPAD('0', 4000,'0')
FROM DUAL
/
SPOOL OFF
回答ありがとうございます。やはり認識間違っていたようですね。
OcacleのSQLリファレンスで連結演算子の説明に「どちらかの文字列がVARCHAR2型の場合、
連結結果はVARCHAR2型となり、最大文字数は4000」とあります。
また、「どちらかがCLOB型の場合、結果は一時CLOB型になります」とも書いています。
GoFさんの例示されているSQLを見ると、CLOB型のデータと連結してやれば、4000バイト以上の
連結も可能ということなのでしょうか。
(最大長はCLOB型の4GBなのかと思いましたが32KBなのですね)
確かに文字列連結は4000バイト以上可能なのですが、実際にエラーの出ていたスプール処理を
以下のように変更して試してみたのですが、実行結果が何分待っても帰ってこない状態になって
しまいました。(4GBを項目数分連結するので処理に時間がかるのでしょうか?)
spool test.csv
select
to_clob('') ||
a ||','||
b ||','||
c ||','||
//以下100項目以上連結
from test_table
Code Tipsの#764は実際に試したのですが、単純に文字列連結を行っているようで、
質問と同様のエラーが出てしまいます。
#675は内容がやや複雑で実行内容がよく理解できなかったのと、TO_CLOB等も使用していないよう
なので#764と変わらないのかと思い実行は控えていました。
暗黙的な変換等、基本的な部分を理解できていないこともあり、せっかくの回答も生かせていないようです。
もう少し勉強して試してみたいと思います。いろいろとありがとうございました。
No.3
- 回答日時:
SELECT TO_CLOB('') || LPAD('A', 4001, 'C') FROM DUAL ;
通常 暗黙変換 により VARCHAR2に変換されます。
VARCHAR2の最大長は 4000バイト
すぐ下に同じような質問内容があるので、そちらのスクリプトを使用した方がよいと思います。
参考URL:http://oshiete1.goo.ne.jp/kotaeru.php3?q=1460873
回答ありがとうございます。返事が遅れてしまいもうし訳ありません。
連結する文字列のどちらかがVARCHAR2の場合、連結した結果はVARCHAR2の文字列となり、
最大4000バイトとなるということですね。
SQL文の内容はCLOB型のデータと連結すれば連結結果はCLOB型となり、
最大長は4GBとなるのでエラーとはならないことを言われているのでしょうか。
Code Tipsの内容も実際に試してみたのですが、結局のところ項目を連結させる
やり方では4000バイトまでが限度ということだと判断したのですが、上のCLOB型の
組み合わせ次第では4000バイト超のデータも出力可能なのでしょうか?
質問ばかりで申し訳ないのですが、認識間違ってましたら、
反応して頂けないでしょうか。
よろしくお願いします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
ORACLEから各テーブルをCSV形式で出力するコマンド
Oracle
-
CLOB型へのINSERT
Oracle
-
selectした結果の余計な余白を取るにはどうしたらよいのでしょうか
Oracle
-
-
4
SQLPLUSで結果を画面に表示しない
Oracle
-
5
SQLローダーCSV取込で、囲み文字がデータ中に入っている場合について
Oracle
-
6
ORA-01013のエラーについて経験のある方お願いします。
Oracle
-
7
BLOBやCLOBのパフォーマンスを改善したい
Oracle
-
8
sqlplusのspoolで空白行出現
Oracle
-
9
oracle spool SJIS → UTF-8
Oracle
-
10
Chr(13)とChr(10)の違いは?
PowerPoint(パワーポイント)
-
11
CASE文のエラーについて
Oracle
-
12
OracleのSQL*PLUSで、データが折り返されて見づらいのですが。。。
その他(データベース)
-
13
sqlplusでヘッダーが付かない
Oracle
-
14
SQL Plusで項目名が最後まで表示されない?
Oracle
-
15
SELECT INTOで一度に複数の変数へ代入をするにはどのようにすれがよいでしょうか?
PostgreSQL
-
16
datapumpの実行方法について
Oracle
-
17
sqlplusで表示が変なので、出力を整形したい。
Oracle
-
18
1レコード全てを改行なしで表示させる方法
Oracle
-
19
データを削除しても表領域の使用率が減りません
Oracle
-
20
ORA-01858: 数値を指定する箇所に数値以外の文字が指定されています
Java
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Oracleでの文字列連結サイズの上限
-
OracleのSQL*PLUSで、デー...
-
select insertで複数テーブルか...
-
GROUP BYを行った後に結合した...
-
Accessで日付が変わると番号が...
-
ADO VBA 実行時エラー3021
-
固有レコード識別子の選択とは
-
SQL GROUPで件数の一番多いレコ...
-
レコードが選択されないときの...
-
GROUP BYを使ったSELECT文の総...
-
最新の日付とその金額をクエリ...
-
SQL文で右から1文字だけ削除す...
-
select句副問い合わせ 値の個...
-
Excelで、改行がある場合の条件...
-
レコードが存在しなかった場合
-
access 自動採番 年が変わる...
-
SELECTで1件のみ取得するには?
-
ACCESSの集計クエリで3件ある...
-
Line Inputで文字化け(助けて...
-
キーが同じを複数行を1行にま...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Oracleでの文字列連結サイズの上限
-
GROUP BYを行った後に結合した...
-
OracleのSQL*PLUSで、デー...
-
Accessで別テーブルの値をフォ...
-
ADO VBA 実行時エラー3021
-
実績累計の求め方と意味を教え...
-
最新の日付とその金額をクエリ...
-
何にかが違うから エラーなんで...
-
SELECTで1件のみ取得するには?
-
決定性有限オートマトン
-
select insertで複数テーブルか...
-
Excelで、改行がある場合の条件...
-
JSPのNULLレコード表示について...
-
select句副問い合わせ 値の個...
-
Excelでセルの書式設定を使用し...
-
ファイル書込みで一行もしくは...
-
ワードの差込印刷で教えて下さ...
-
レコードが存在しなかった場合
-
DataGridViewの、選択されてい...
-
SELECTの結果で同一行を複数回...
おすすめ情報