VB6.0とOracle9i、どちらも初心者です。
C:\直下にあるtest.csvファイルを読み込み、Oracleのテーブルと比較して存在しないものはinsert、存在するものはupdateする。
・test.csvファイル(百行)
"LOCATE", "COMPANY_CODE", "COMPANY_NAME", "COMPANY_KANA", "ZIPCODE", "ADDRESS",
"TEL_NO", "FAX_NO", "CATEGORY", "INDUSTRIES", "PERSONS"
・OracleのCustomerテーブル
COMPANY_CODE NUMBER
COMPANY_NAME VARCHAR2
COMPANY_KANA VARCHAR2
ZIPCODE CHAR
ADDRESS VARCHAR2
TEL_NO CHAR
TEL_NO_2 CHAR
FAX_NO CHAR
HP_URL VARCHAR2
NOTE VARCHAR2
CUST_VARCHAR_1 VARCHAR2
CUST_VARCHAR_2 VARCHAR2
CUST_VARCHAR_3 VARCHAR2
CUST_VARCHAR_4 VARCHAR2
・ロジック
1.oo4oでOracleに接続
2.csvファイルの読み込み
3.oracleのレコードとの比較
4.insertプログラム
5.updateプログラム
・コード
'** oo4o 接続
dbname = "****"
cnuser = "****/****"
Set OraSession = CreateObject("OracleInProcServer.XOraSession")
Set OraDatabase = OraSession.OpenDatabase(dbname, cnuser, ORADB_DEFAULT)
Open "c:\test.csv" For Input As #1 '
csvファイルをオープンして、1行ずつループで取り込んで、取り込んだcsvレコード(行)を元にキー項目(COMPANY_CODE)を条件に既にOracleテーブルにあればInsertクエリを, なければUpdateクエリを発行する、をファイルエンドまで繰り返します。
自分でなんとか書いて聞くのが礼儀だと思いますが、調べてもやっぱりどう書けばよいのか全くわかりません。懸念事項として、Oracleのテーブルの列とCSVの列の数や並び方が異なっていることがあります。よろしくお願いします。
No.1ベストアンサー
- 回答日時:
何が わからないのか ちょっとわかりません。
前提として、
ファイルから読み込み
SELECT
INSERT
UPDATE
DELETE
などのやり方は わかりますでしょうか?
とりあえず、それぞれが 単体で実行できることを確認してから それを
組み合わせていったらいいでしょう。
DELETEとあるのは、手順として
SELECTして ない → INSERT
ある→UPDATE
とするのと
無条件で
DELETE→INSERT
という手段もあるからです。
どちらがいいかは、レコード数によっても違うと思います。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- MySQL 何にかが違うから エラーなんでしょうね! 2 2022/09/18 05:28
- MySQL `picture` varchar(255) のコマンドで間違いないでしょうか? 1 2022/11/21 04:08
- PHP php テーブルが作成できない 1 2022/11/17 23:41
- Access(アクセス) access,vbaでフォルダ内のファイルをテーブルにインポート、ファイル名もフィールドに追加したい 1 2022/08/31 11:11
- MySQL php テーブルを作れない 2 2022/11/17 18:22
- MySQL PHPとMySQLを使った掲示板の作り方 1 2022/06/02 13:00
- MySQL エラー 1068 (42000): 複数の主キーが定義されていますエラー 2 2022/11/17 04:36
- MySQL テーブル作成です。どこかのスペルが間違っているか記号など スペースかな? 1 2022/10/01 05:08
- PHP php エラー 2 2022/10/23 16:43
- Excel(エクセル) エクセルのVBAについて とあるサイトのコードを参考に、CSVの文字化けを直すVBAを作成しているの 7 2022/11/04 14:15
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
カンマ区切りのCSVファイルから...
-
CSV形式での保存時に”文字列...
-
バッチでCSVを処理する時、空の...
-
複数のcsvファイルをExcelに一...
-
csvファイル 項目数取得
-
エクセル形式のファイルの読み込み
-
EXCEL|csvで保存→開くcsvを閉じる
-
CSV形式のファイルを読み込んで...
-
【Excel】csvファイル取込み VB...
-
ACCESS CSVファイルをインポ...
-
特定文字を入ってるCSVの特定の...
-
マクロから出力されるcsvのダブ...
-
csvファイルから列を選択しchar...
-
csvファイルのデータの一部を取...
-
データ解析ソフトRでのファイル...
-
【ExcelVBA】UTF-8の文字コード...
-
複数のCSVファイルのAccessテー...
-
VB6.0 CSVファイル読み込みに...
-
VBAでCSVファイルのデータを集...
-
VBSでソート&ファイル分割
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
カンマ区切りのCSVファイルから...
-
複数のcsvファイルをExcelに一...
-
CSV形式での保存時に”文字列...
-
csvファイル 項目数取得
-
csvファイルでの日付設定「yyyy...
-
マクロから出力されるcsvのダブ...
-
バッチでCSVを処理する時、空の...
-
csvファイルのデータの一部を取...
-
エクセルVBA 大容量CSVファイル...
-
csvファイルを列数ごとに分割す...
-
PHP.laravelについて
-
COBOLでCSVをインプットにして...
-
COBOL85でのCSVファ...
-
複数のCSVファイルのAccessテー...
-
データ解析ソフトRでのファイル...
-
【C#】パス名で無効な文字
-
VBAでcsvファイルを読み込んで...
-
特定文字を入ってるCSVの特定の...
-
CSVファイル作成
-
【エクセル マクロ】読み込ん...
おすすめ情報