質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Perl

Perlは多目的に使用される実用性が高い動的プログラミング言語のひとつです。

Q&A

解決済

1回答

2238閲覧

CSVファイルをテーブルにinsertできない。

fff.claypool

総合スコア12

Perl

Perlは多目的に使用される実用性が高い動的プログラミング言語のひとつです。

0グッド

0クリップ

投稿2018/04/29 07:46

【Perl】
次のような条件が与えられている課題に取り組んでおります。
・CSVファイルを読み込み、データをテーブルにINSERTする。
・CSVファイルのパスはコマンドライン引数で与える。

下記のようなコードを書いたところ、CSVファイルがテーブルに正常にINSERTされませんでした。


use strict;
use warnings;
use DBI;

my $dsn = 'DBI:mysql:kensyu';
my $user = 'root';
my $dbh = DBI->connect($dsn, $user, ,);

my $csvfile_pass = $ARGV[0];

my $sql = sprintf("BULK INSERT kensyu_kadai3 FROM '%s'",$csvfile_pass);

my $sth = $dbh->prepare($sql);
$sth->execute;
while(my $row = $sth->fetchrow_hashref) {
print "$row->{id}\n","$row->{'Public Organization Code'}\n","$row->{'Postal Code'}\n",
"$row->{'Name of Prefectures.1'}\n","$row->{'City Name.1'}\n","$row->{'Machijo Name.1'}\n",
"$row->{'Name of Prefectures.2'}\n","$row->{'City Name.2'}\n","$row->{'Machijo Name.2'}\n";
}

CSVファイルをテーブルに正常にINSERTするための方法をご教示いただけますと幸いです。
何卒よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

Perl

1my $dsn = 'DBI:mysql:kensyu';

ですから、使っている RDBMS は MySQL だと解釈します。

MySQL の SQL には、bulk insert なんて構文はありません。
従って $sth->execute() がエラーを返しているはずです。

やりたいことは MySQL では、load data infile 構文を使います。
参照: MySQL リファレンスマニュアル

投稿2018/04/30 08:15

編集2018/04/30 08:17
tacsheaven

総合スコア13703

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問