ハードディスクメンテナンス ブログ

投稿記事数8,000以上!PC,カメラ,オーディオ,ラジオ,航空,旧ゲームなど

csvファイルのMySQLへのインポート (LOAD DATA LOCAL INFILE,mysqlimport) さくらインターネット

   

>>高還元のクレジットカード比較 期間限定のキャッシュバックなど!<<


自鯖(自由度高)を使うことが多いが、さくらインターネットのユーザーから質問を受けたのでメモ。



WEBサーバー内にcsvファイルを置いて、それをDB(MySQL)にインポートする。

phpMyAdminのインポート機能を使えば可能だが、phpプログラムで実行したい。

となると、LOAD DATA LOCAL INFILEが考えられる。

LOAD DATA INFILE
インポート先のDBがあるサーバーにcsvファイルがある場合

LOAD DATA LOCAL INFILE
クライアントにあるcsvファイルをサーバーのDBへ

MySQL全機能バイブルの381ページ

この場合は①が使用可能と思えるが、csvファイルのあるサーバー(WEBサーバー)とMySQLのあるサーバー(DBサーバー)が別の場合(さくらインターネット等)は、この方法では不可能では?

ネットで調べると、成功したとかしなかったとか、mysqlimportで成功した等の情報があるが、同じレンタルサーバー業者でも、DBのバージョンや設定が異なるので、実際は自分で試してみないとならない。

また、情報の日付に注意。

以前は有効でも今は無効ということがあるからだ。

phpMyAdminでのインポートでは、最大サイズの制限がある(最長:16MiB)。

自己管理のローカルサーバー等、自由度のある場合は上限値を変更できるが、レンタルサーバーの場合は困難だろう。

そのような場合、FTPでcsvファイルを上げておいて、以下の方法でDBにインポートするとよいだろう。

phpでプログラムを書いておくと、コマンド打たなくてもいいしね。

以下、手順。

■csvファイルの準備

WEBサーバー上の /home/aaa/www/ に test.csv を置く。

aaaは、さくらインターネットでのアカウント名。

test.csvの中身は

1,first
2,second
3,third
4,forth
5,fifth

という、カンマ区切りの簡単なもの。

■DBの準備

mysql***.db.sakura.ne.jp – aaa_xxx – test

に、以下のようなテーブル(test)を作成しておく。

テーブル

・id int
・name text

***は、さくらインターネットから割り当てられたDBの番号。

aaa_xxxはDB名だが、必ずaaa_が付加されるのは、さくらインターネットの仕様。

テーブル名は、

■コマンドを記したphpファイルを作成、実行

WEBサーバーのtest.csvと同じディレクトリに

<?PHP

$import = “mysqlimport -h mysql***.db.sakura.ne.jp -u aaa -p(パスワード) -L –fields-terminated-by=’,’ aaa_xxx /home/aaa/www/test.csv” ;
system($import) ;

?>

というphpファイル(import.phpとする)を置き、これを実行。

・-h mysql***.db.sakura.ne.jp ホスト
・-u aaa DBアクセス用のユーザ名
・-p(パスワード) DBアクセス用のパスワード、-pに続けて(スペースなしに)書くこと
・-L ローカルファイルから読み込むオプション
・–fields-terminated-by=’,’ csvファイルの区切文字、今回は「,(半角カンマ)」
・aaa_xxx DB名
・/home/aaa/www/test.csv csvファイルの場所

スポンサーリンク

すると、

aaa_xxx.test: Records: 5 Deleted: 0 Skipped: 0 Warnings: 0

と表示され、以下のようにデータが格納される。

csvの内容が格納されている
csvの内容が格納されている

さて、上のmysqlimport~にて、DB名の指定はあるが、テーブル名の指定はないのか?

と疑問に思うが、test.csvの拡張子を取ったものが、テーブル名なのだ。

つまり、ファイルがtest.txtの場合も、testがテーブル名。

ファイル名とテーブル名が異なる場合は?

import.phpをリロードすると、データが「追記」されてしまう。

2回格納されている
2回格納されている

これを防ぐには、

–delete インポートする前にテーブルを空にする

のオプションを追加する。

これで、格納前に空にしてくれるので、追記は回避できる。

なお、原因は不明だが -D ではエラーとなる(エラー表示はないが格納されない)。

–delete なら問題なし。

–オプションに対し、-省略形、つまり、

–delete と -D は同意という理解は間違っているのか?

関連:mysqlimport –helpの内容

このphpファイルを定期的に実行するには、cronに登録すればよい。

cd /home/aaa/www ; /usr/local/bin/php test.php > /dev/null

test.phpのあるディレクトリ ; PHPのコマンドパス プログラムを記したphpファイル メール設定

最後の >/dev/null は postmaster@aaa.sakura.ne.jp へメールを送らない場合に書く。

そして、cronが実行できるように、test.phpのパーミッションを755に設定。

設定後は、指定した間隔や時間に、問題なくDBに格納されるかを確認する。

メールを送る設定であれば Permission denied 等のエラーが postmaster@aaa.sakura.ne.jp に送られるので、確実に動くことを確認するまでは >/dev/null を付けない方がいい。

cronは5個までしか設定できないようだが、コントロールパネルからではなく、サーバーに接続しコマンドでやれば、5個以上可能?

関連:さくらインターネットのCRONの設定画面(1.CRONの設定)

関連:さくらインターネットのCRONの設定画面(2.CRONスケジュール設定)

MySQL全機能バイブル ~現場で役立つAtoZ~
鈴木 啓修
技術評論社
売り上げランキング: 170,416



sha-bc@336×280

sha-bc@336×280


sha-bc@336×280

sha-bc@336×280

  関連記事

B00ITGD31A
AVerMediaの HDMIビデオキャプチャー(CV710) がタイムセールで18,500円!

AVerMedia USB3.0対応HDMIキャプチャー CV710 日本正規代 …

B00VX82P38
Transcendの SSD 256GB SATA3 6Gb/s TS256GSSD370S 3年保証 がタイムセールで9,280円!

Transcend SSD 256GB 2.5インチ SATA3 6Gb/s M …

B00VX82KBK
Transcend(トランセンド)の SSD 1TB SATA3 6Gb/s TS1TSSD370S 3年保証 がタイムセールで33,000円!

Transcend SSD 1TB 2.5インチ SATA3 6Gb/s MLC …

M-XGM20DLBK_75.6g
M-XGM20DLBKの購入とレビュー②(エレコム,EX-G,握りの極み,無線マウス)

M-XGM20DLBKを入手したというハナシを以前書いた。 関連:M-XGM20 …

B00WMK89S6
シリコンパワーの SSD 120GB SATA3 6Gb/s SP120GBSS3S55S25FR がタイムセールで4,491円!

サブ機用に! SP シリコンパワー SSD 120GB SATA3 6Gb/s …

GH-AMCA03
GH-AMCA03(液晶モニターアーム,2アーム,4軸モデル,グリーンハウス)を入手 レビュー

ヴツが届いた。 2アームなのでDualモニター用であり、4軸モデルなので細かいウ …

B00WMLN0SE
シリコンパワーの SSD 60GB SATA3 6Gb/s SP060GBSS3S55S25FR がタイムセールで3,603円!

サブ機用に! SP シリコンパワー SSD 60GB SATA3 6Gb/s 3 …

B016CWSKYC
TOSHIBA(東芝)の 3TB ハードディスク DT01ABA300V/AFP がタイムセールで9,940円!

【Amazon.co.jp限定】 TOSHIBA 3TB 3.5inch/SAT …

B00QIH3RM2
Samsung(サムスン)の SSD 850 EVO 1TB MZ-75E1T0B/IT がタイムセールで35,473円!

Samsung SSD 1TB 850 EVO ベーシックキット 2.5インチ …

B008CVHLT2
Transcendの SDHCカード 32GB Class10 UHS-I対応(最大転送速度90MB/s) TS32GSDHC10U1E がタイムセールで1,780円!

ワシも持ってる。 関連:TS32GSDHC10U1(SDHCカード,32GB,ト …