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

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スクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

4回答

24804閲覧

DB登録処理のページでFatal errorが出てしまいます...

earnest_gay

総合スコア615

SQL

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

PHP

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

1グッド

2クリップ

投稿2016/06/20 03:42

DB登録処理のページへ遷移した時に下記errorがでます。

Fatal error: Call to a member function prepare() on null in C:\xampp\htdocs\XXX\register_human_thanks.php on line 10

これはなんなのでしょうか?

一応ソースも載せておきます。

<?php session_start(); $dsn = 'mysql:dbname=test;host=localhost;charset=utf8'; $user = 'root'; $password = ''; $option = array(PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION); $dbh = new PDO($dsn, $user, $password, $option); $stmt = $pdo->prepare("INSERT INTO user_data() VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)");//基本項目22個 $stmt->execute([ $_SEESION['join1']['email'], password_hash($_SEESION['join1']['pw']), $_SEESION['join1']['name1'], $_SEESION['join1']['name2'], $_SEESION['join1']['name3'], $_SEESION['join1']['name4'], $_SEESION['join1']['name5'], $_SEESION['join1']['name6'], $_SEESION['join1']['name7'], $_SEESION['join1']['year'], $_SEESION['join1']['month'], $_SEESION['join1']['day'], $_SEESION['join1']['gender'], $_SEESION['join1']['first_post'], $_SEESION['join1']['last_post'], $_SEESION['join1']['pref'], $_SEESION['join1']['city'], $_SEESION['join1']['town'], $_SEESION['join1']['building'], $_SEESION['join1']['tel1'], $_SEESION['join1']['tel2'], $_SEESION['join1']['tel3'] ]); $stmt = $pdo->prepare("INSERT INTO user_skill() VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)");//スキル年数MAX10セット*2=20セット(40個) $stmt->execute([ $_SEESION['jion2']['programs1_1'], $_SEESION['jion2']['programs_year1_1'], $_SEESION['jion2']['programs1_2'], $_SEESION['jion2']['programs_year1_2'], $_SEESION['jion2']['programs1_3'], $_SEESION['jion2']['programs_year1_3'], $_SEESION['jion2']['programs1_4'], $_SEESION['jion2']['programs_year1_4'], $_SEESION['jion2']['programs1_5'], $_SEESION['jion2']['programs_year1_5'], $_SEESION['jion2']['programs1_6'], $_SEESION['jion2']['programs_year1_6'], $_SEESION['jion2']['programs1_7'], $_SEESION['jion2']['programs_year1_7'], $_SEESION['jion2']['programs1_8'], $_SEESION['jion2']['programs_year1_8'], $_SEESION['jion2']['programs1_9'], $_SEESION['jion2']['programs_year1_9'], $_SEESION['jion2']['programs1_10'], $_SEESION['jion2']['programs_year1_10'], $_SEESION['jion2']['programs2_1'], $_SEESION['jion2']['programs_year2_1'], $_SEESION['jion2']['programs2_2'], $_SEESION['jion2']['programs_year2_2'], $_SEESION['jion2']['programs2_3'], $_SEESION['jion2']['programs_year2_3'], $_SEESION['jion2']['programs2_4'], $_SEESION['jion2']['programs_year2_4'], $_SEESION['jion2']['programs2_5'], $_SEESION['jion2']['programs_year2_5'], $_SEESION['jion2']['programs2_6'], $_SEESION['jion2']['programs_year2_6'], $_SEESION['jion2']['programs2_7'], $_SEESION['jion2']['programs_year2_7'], $_SEESION['jion2']['programs2_8'], $_SEESION['jion2']['programs_year2_8'], $_SEESION['jion2']['programs2_9'], $_SEESION['jion2']['programs_year2_9'], $_SEESION['jion2']['programs2_10'], $_SEESION['jion2']['programs_year2_10'] ]); $stmt = $pdo->prepare("INSERT INTO user_qualification() VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)");//資格年数MAX10セット(30個) $stmt->execute([ $_SEESION['jion2']['certificate1'], $_SEESION['jion2']['certificate_year1'], $_SEESION['jion2']['certificate_day1'], $_SEESION['jion2']['certificate2'], $_SEESION['jion2']['certificate_year2'], $_SEESION['jion2']['certificate_day2'], $_SEESION['jion2']['certificate3'], $_SEESION['jion2']['certificate_year3'], $_SEESION['jion2']['certificate_day3'], $_SEESION['jion2']['certificate4'], $_SEESION['jion2']['certificate_year4'], $_SEESION['jion2']['certificate_day4'], $_SEESION['jion2']['certificate5'], $_SEESION['jion2']['certificate_year5'], $_SEESION['jion2']['certificate_day5'], $_SEESION['jion2']['certificate6'], $_SEESION['jion2']['certificate_year6'], $_SEESION['jion2']['certificate_day6'], $_SEESION['jion2']['certificate7'], $_SEESION['jion2']['certificate_year7'], $_SEESION['jion2']['certificate_day7'], $_SEESION['jion2']['certificate8'], $_SEESION['jion2']['certificate_year8'], $_SEESION['jion2']['certificate_day8'], $_SEESION['jion2']['certificate9'], $_SEESION['jion2']['certificate_year9'], $_SEESION['jion2']['certificate_day9'], $_SEESION['jion2']['certificate10'], $_SEESION['jion2']['certificate_year10'], $_SEESION['jion2']['certificate_day10'] ]); $stmt = $pdo->prepare("INSERT INTO user_pr() VALUES (?, ?, ?, ?)");//その他自己PR $stmt->execute([ $_SEESION['join2']['major_cat'], $_SEESION['join2']['major_skill'], $_SEESION['join2']['agreement'], $_SEESION['join2']['pr'] ]); session_destroy(); ?>
DrqYuto👍を押しています

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

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

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

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

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

guest

回答4

0

ここでPDO の変数 $dbhなのに

$dbh = new PDO($dsn, $user, $password, $option);

$pdo になってる。

$stmt = $pdo->prepare("INSERT INTO user_data() VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)");//基本項目22個

名ともなエディタ使えばこんなミスしないのに…

投稿2016/06/20 03:47

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

earnest_gay

2016/06/20 03:53

すいません。 ありがとうございます!
guest

0

Fatal error: Call to a member function prepare() on null in C:\xampp\htdocs\XXX\register_human_thanks.php on line 10
prepare()メソッドを実行させようとしているものがインスタンスではなくnullであることが原因です。

php

1$dbh = new PDO($dsn, $user, $password, $option); 2 3$stmt = $pdo->prepare("INSERT INTO user_data() VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)");//基本項目22個

$pdoではなく、$dbhでは?

投稿2016/06/20 03:46

attakei

総合スコア2738

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

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

earnest_gay

2016/06/20 03:54

ありがとうございます!
guest

0

明らかに変数名が違います… $dbh $pdo

php

1$dbh = new PDO($dsn, $user, $password, $option); 2$stmt = $pdo->prepare("INSERT INTO user_data() VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)");//基本項目22個

Noticeレベルのエラーも表示するようにすべきですね.php.iniの設定を変えてください.

php

1error_reporting = E_ALL

こうしておくことで, Notice: Undefined variable: pdo というエラーも見えるようになります.

投稿2016/06/20 03:46

編集2016/06/20 03:47
mpyw

総合スコア5223

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

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

earnest_gay

2016/06/20 03:53

ありがとうございます!
guest

0

ベストアンサー

PHP

1$dbh = new PDO($dsn, $user, $password, $option);

$pdoじゃなくて$dbhに入ってますよ。

エラーの意味は
Call to a member function prepare() on null
prepareというメンバ関数をnullから呼びだそうとしています

で、原因となる行でprepareを呼び出しているオブジェクトは$pdoです。
そして、遡ってみると$pdoは存在せず、おそらくやりたいことであろうPDOのインスタンスは$dbhという変数に入っています。

投稿2016/06/20 03:45

編集2016/06/20 03:48
masaya_ohashi

総合スコア9206

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

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

earnest_gay

2016/06/20 03:52

すいません! ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問