INSERT文で何万件ものデータをテーブルに挿入したいのですが、
SUBSTRBまたはSUBSTR関数で何バイト分あるいは何文字分抽出して
その部分の値をインクリメントさせる記述のしかたがわかりません。
INSERT INTO aaa (ID,YEAR,CLS,NO,THING,CD,LAND,USER,GROUP) VALUES ('30000003000','2000','2','85000','001','55555','10','test','1');
INSERT INTO aaa (ID,YEAR,CLS,NO,THING,CD,LAND,USER,GROUP) VALUES ('30000003001','2000','2','85001','001','55555','10','test','1');
INSERT INTO aaa (ID,YEAR,CLS,NO,THING,CD,LAND,USER,GROUP) VALUES ('30000003002','2000','2','85002','001','55555','10','test','1');
INSERT INTO aaa (ID,YEAR,CLS,NO,THING,CD,LAND,USER,GROUP) VALUES ('30000003003','2000','2','85003','001','55555','10','test','1');
・
・
・
と、いう感じで、IDとNOのみ、値をインクリメントさせて大量のデータを
挿入したいのですが、SUBSTRB関数やループなどを使って効率的に行うやり方がわかりません。どなたか、ご教授ください。
A 回答 (4件)
- 最新から表示
- 回答順に表示
No.4
- 回答日時:
下記ツールを使えば、ExcelからデータをOracleへ投入できます。
http://www.superdbtool.com
ExcelDBTool
投入する際に使ったInsert文は全部ログとして残っていますので、
数十万件の投入でも可能です。
ExcelDBToolで1つのテーブルが出来ましたら、同じ列名のほかのテーブルにコピーできます。
また、Excelに線を引いて、引いた線でデータの作成もできます。
下記のダミーデータ作成もできます。
日付, 時間, タイムスタンプ, 都道府県, E-Mail, URL, 郵便番号, 携帯, 苗字のみ, 氏名, ふりがな, 性別, 年齢, 血液型, 固定電話, 婚姻, 固定値, 国籍, 国籍英語, 国籍英語略, 企業名, 住所, 住所ふりがな, 半角英字, 市区, 町村, 最寄駅, 最寄駅ふりがな, 路線, 銀行コード, 銀行名, 銀行カタカナ, 支店コード, 支店名, 支店カタカナ, 大学名, 業種大分類, 業種大分類名称,
業種中分類, 業種中分類名称, 業種小分類, 業種小分類名称, 職種大分類, 職種大分類名称, 職種中分類, 職種中分類名称, 職種小分類, 職種小分類名称, 数値連番, 整数・小数点数, 英数混在, 文字列+連番, 文字列+全角連番, 全角漢字, ひらがな, 全角カタカナ, 半角カタカナ, 全角英数, 全角数値, 全角英字, 全半混在, 特殊文字
ご参考まで。
No.3
- 回答日時:
サーバー側で、PL/SQLを使ってやるとか:
DECLARE
v_id NUMBER := 30000003000;
v_no NUMBER := 85000;
v_cnt PLS_INTEGER;
BEGIN
FOR v_cnt IN 1 .. 10000 LOOP
INSERT INTO aaa (
ID,YEAR,CLS,NO,THING,CD,LAND,USER,GROUP
) VALUES (
TO_CHAR( v_id, '99999999999' ),
'2000','2',
TO_CHAR( v_no, '99999' ),
'001','55555','10','test','1'
);
v_id := v_id + 1;
v_no := v_no + 1;
END LOOP;
COMMIT;
END;
/
実際試してないので、間違っているかもしれませんが。
No.2
- 回答日時:
Oracleなら連番を振るときはシーケンスを使います。
Create文は以下の通り。
CREATE SEQUENCE seqID
INCREMENT BY 1
START WITH 1
MAXVALUE 100000
NOMINVALUE
CYCLE
NOORDER
CACHE 20
/
で、取得するときはNextValを使用します。
SELECT seqID.NEXTVAL FROM DUAL
これを副問合せでInsert文に埋め込んではいかがでしょうか。
No.1
- 回答日時:
ORACLE使ったことなくて、自信がないのですが・・・
ExcelとかでCSVファイルを作って読み込んではダメですかね?
やりたいことの主旨と違ってしまったらごめんなさい。
SQLServerの時テストデータをそんな風に作って読み込みをしました。
(フィルで連続データの作成)
あいまいな回答で申し訳ありません
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- MySQL 次の時間帯の勝率の合計を求めるSQL文 1 2023/07/04 17:12
- PHP php エラー 2 2022/10/23 16:43
- PHP プログラムコードを入力する場合改行してもいいですか? 2 2022/10/02 16:05
- PHP ここでの ②if($su_d<>"")の比較演算子 を使う理由は 1 2022/03/26 02:33
- Access(アクセス) access,vbaでフォルダ内のファイルをテーブルにインポート、ファイル名もフィールドに追加したい 1 2022/08/31 11:11
- PHP PHP MySQLに画像を直接保存 2 2022/06/05 11:50
- PHP ここで言う「アロー演算子」の役割を教えてください。 1 2022/03/26 02:38
- PHP php エラー 3 2022/11/18 23:32
- Access(アクセス) アクセス where句を使用して複数条件抽出をするには 2 2022/08/29 13:24
- Visual Basic(VBA) Excel VBA でデータ転記について 1 2023/03/07 19:11
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
SQL Left Join で重複を排除す...
-
SQLサーバから、項目の属性(型...
-
MySQLのint型で001と表示する方...
-
SQLにて特定の文字を除いた検索...
-
[SQLServer] テーブル名からカ...
-
副問合せの書き方について
-
Unionした最後にGROUP BYを追加...
-
VIEWの元のテーブルのindexって...
-
updateを1行ずつ実行したい。
-
select文のwhere句に配列を入れ...
-
ギターのコードが分からない
-
複数テーブルのGROUP BY の使い...
-
エクセルの関数について教えて...
-
[MySQL] UNIQUE制約の値を更新...
-
上位3位を求めるSQL文は?
-
OracleでINSERT文のループ
-
マイクラPC版のコマンドで効率...
-
ストアドのエラーについて
-
[MySQL] 3つのテーブルの結合で...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
SQL Left Join で重複を排除す...
-
副問合せの書き方について
-
SQLサーバから、項目の属性(型...
-
VIEWの元のテーブルのindexって...
-
select文のwhere句に配列を入れ...
-
selectした大量データをinsert...
-
センノシド異性体構造式
-
Unionした最後にGROUP BYを追加...
-
insertを高速化させたい
-
SQLにて特定の文字を除いた検索...
-
マイクラPC版のコマンドで効率...
-
ある条件の最大値+1を初番する...
-
inner joinをすると数がおかし...
-
sqlで、600行あるテーブルを100...
-
エクセルの関数について教えて...
-
Access パラメータクエリをcsv...
-
URL と行番号の指定
-
複数テーブルのGROUP BY の使い...
-
PL/SQLの変数について
おすすめ情報