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

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

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

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Amazon EC2

Amazon EC2は“Amazon Elastic Compute Cloud”の略称です。Amazon Web Services(AWS)の一部であり、仮想化されたWebサーバーのコンピュータリソースをレンタルできるサービスです。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

Q&A

解決済

1回答

1565閲覧

PHP・bindvalueに関するエラーを解決したいです。

amaturePy

総合スコア131

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Amazon EC2

Amazon EC2は“Amazon Elastic Compute Cloud”の略称です。Amazon Web Services(AWS)の一部であり、仮想化されたWebサーバーのコンピュータリソースをレンタルできるサービスです。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

0グッド

0クリップ

投稿2019/12/03 08:13

編集2019/12/03 12:31

EC2内のPHPファイルでCSVのデータをRDSに挿入するコードを書いてます。
CSVの読み取りとDBへの接続は完了済み。
ですが、いざクエリを実行すると以下のエラーが出ます
調べるとbindvalueの使い方に問題があると思うのですが、
修正箇所を見つけられないでいます。
もしエラーの原因箇所が分かる方がいらっしゃれば教えて頂きたいです。

エラー文 PHP Fatal error: Uncaught PDOException: SQLSTATE[HY093]: Invalid parameter number: parameter was not defined in /home/ec2-user/index.php:35 Stack trace: #0 /home/ec2-user/index.php(35): PDOStatement->execute() #1 {main} thrown in /home/ec2-user/index.php on line 35
CSVファイル&テーブル情報 【CSVファイル】(lineidは英数字の混合なのでbindvalueの引数にはintではなくstrを置いてます) ------------------- lineid | username | ------------------- 2222aaaa | tarou tanaka DB(usersテーブル) ------------------- id | line_id | name | -------------------
実行コード <?php try{ $pdo = new PDO( 'mysql**********', '******', '********', [ PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, ] ); } catch(PDOException $e) { header('Content-Type: text/plain; charset=UTF-8', true, 500); exit($e->getMessage()); } header('Content-Type: text/html; charset=utf-8'); $file = new SplFileObject('/tmp/winneyuser.csv'); $file->setFlags(SplFileObject::READ_CSV); $insert_array = []; foreach ($file as $line) { $insert_array[] = [ 'line_id' => $line[0], 'username' => $line[1], ]; } $stmt = $pdo->prepare("INSERT INTO users (line_id, name) VALUES (:lineid, :username)"); $stmt->bindValue(':lineid', $line_id, PDO::PARAM_STR); $stmt->bindValue(':username', $username, PDO::PARAM_STR); foreach($insert_array as $insert_data) { $stmt->execute(); } $pdo->commit(); ?>

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

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

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

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

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

Takumiboo

2019/12/03 08:30

DBサーバのホスト名、ユーザ名、パスワードなどが記載されていますが大丈夫ですか?
amaturePy

2019/12/03 08:44

ありがとうございます!!!!!!! うっかりしてました!
Takumiboo

2019/12/03 08:47

ちなみに編集履歴は見えてしまうので、パスワードなど変更されることをおすすめいたします。
amaturePy

2019/12/03 08:52

承知いたしました。 ありがとうございます。
guest

回答1

0

ベストアンサー

php

1 $stmt = $pdo->prepare("INSERT INTO users (line_id, name) VALUES (:lineid, :username)"); 2 3 $stmt->bindValue(':line_id', $line_id, PDO::PARAM_STR);

:lineid:line_idで名前が一致していません。

投稿2019/12/03 08:16

maisumakun

総合スコア145183

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

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

amaturePy

2019/12/03 08:21

ありがとうございます。 修正して実行したのですが、同じエラーのままです。 他にもタイポがないか確認してみます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問