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

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

ただいまの
回答率

90.34%

  • MySQL

    7420questions

    MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

データベースに接続したい

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 535

seep0619

score 23

質問内容:
管理情報を
データベースに接続したい

エラーメッセージ:
$stmt=$dbh->prepare($sql);
の$dbh がnull表示になっている状態で
恐らくデータが飛んでないとか思います。

mysql:
設定できておりname間違いもないかと思われます。

*接続できない理由が不明確なため、
投稿させていだきました。よろしくお願いいたします。

1P******************************

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>顧客管理情報ツール</title>
</head>
<body>
<form action="DB_contol.php" name="form1" method="post">
<center>顧客管理情報ツール</center>
<br />
<br />
名 前<input type="text" name="name">
<br />
住 所<input type="text" name="adress">
<br />
電話番号<input type="text" name="tell">
<br />
e-mail<input type="text" name="email">
<br />
紹介人数<input type="text" name="Introduction">
<br />
当月売上金額<input type="text" name="Sales_proceeds">
<br />
総売上金額<input type="text" name="total_amount">
<br />
<br />
<input type="submit" value="顧客管理" name="button1">
<br />
<br />
<input type="submit" value="入金確認" name="button2">
<br />
<br />
<input type="submit" value="一覧登録" name="button3">

</body>
</html>

2P******************************
<?php
session_start();
$_SESSION["name"];
$_SESSION["adress"];
$_SESSION["adress"];
$_SESSION["tell"];
$_SESSION["email"];
$_SESSION["Introduction"];
$_SESSION["Sales_proceeds"];
$_SESSION["total_amount"];
?>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>顧客管理情報ツール</title>
</head>
<body>
<?php
$name = $_SESSION['name'];
$tell = $_SESSION['tell'];

$dsn = 'mysql:host=localhost;dbname=customer;charset=utf8';
$user = 'root';
$password = '';
$sql= 'INSERT INTO customer_management(name,email,tell) VALUES (?,?,?)';
$stmt=$dbh->prepare($sql);
$data=array();
$data[]=0;
$data[]=$name;
$data[]=$email;
$data[]=$tell;
$data[]=$adress;
$stmt->execute($data);

$sql='SELECT LAST_INSERT_ID()';
$stmt=$dbh->prepare($sql);
$stmt->execute();
$rec=$stmt->fetch(PDO::FETCH_ASSOC);
$lastcode=$rec['LAST_INSERT_ID()'];

$sql='UNLOCK TABLES';
$stmt=$dbh->prepare($sql);
$stmt->execute();

$dbh=null;

?>
<form action="DB_main.php" method="post">
<center>顧客管理情報ツール(検索)</center>
<br />
<br />
[名 前]<?php echo $_SESSION["name"]?>
<br />
<br />
[住 所]<?php echo $rec["adress"]?>
<br />
<br />
[電話番号]<?php echo $_SESSION["tell"]?>
<br />
<br />
[e-mail]<?php echo $_SESSION["e-mail"]?>
<br />
<br />
[紹介人数]<?php echo $_SESSION["Introduction"]?>
<br />
<br />
[当月売上金額]<?php echo $_SESSION["Sales_proceeds"]?>
<br />
<br />
[トータル売上金額]<?php echo $_SESSION["total_amount"]?>
<br />
<br />
<input type="submit" value=一覧画面 name="DB_list.php">
<br />
<br />
<input type="submit" value=戻る name="DB_main.php">

</body>
</html>

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

checkベストアンサー

0

以下で$dsnを定義していますが、

$dsn = 'mysql:host=localhost;dbname=customer;charset=utf8';

これを利用してDBに接続するコードがありません。
当然、上記に定義した文字列型からメソッドを呼ぼうとしており、そんなメソッドはないということになります。

$stmt=$dbh->prepare($sql);

以下のように、まずはDB接続オブジェクトを生成する処理が必要ですね。
http://php.net/manual/ja/pdo.connections.php

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/10/08 22:09

    ご教授ありがとうございます。
    早速転記したのですが次は

    13行目
    $stmt->execute($data);が
    Warning: PDOStatement::execute(): SQLSTATE[HY093]: Invalid parameter number: number of bound variables does not match number of tokens in /Applications/XAMPP/xamppfiles/htdocs/phpkiso/DB/DB_Customer management.php on line 35

    エラー分が発生しており、””送られてる値が違う””と
    言うところまでは把握できているのですが、
    どのように改善したらいいのかわかりません。
    教えていただけると幸いです。
    お願い致します。

    (データベース箇所抜粋)



    1 $dsn = 'mysql:host=localhost;dbname=customer;charset=utf8';
    $user = 'root';
    $password = '';
    $dbh = new PDO($dsn, $user, $password);
    5  $sql= 'INSERT INTO customer_management(name,email,tell) VALUES (?,?,?)';
    $stmt=$dbh->prepare($sql);
    $data=array();
    $data[]=0;
    $data[]=$name;
    10 $data[]=$email;
    $data[]=$tell;
    $data[]=$adress;
    13 $stmt->execute($data);
    $sql='SELECT LAST_INSERT_ID()';
    15 $stmt=$dbh->prepare($sql);
    $stmt->execute();
    $rec=$stmt->fetch(PDO::FETCH_ASSOC);
    $lastcode=$rec['LAST_INSERT_ID()'];

    $sql='UNLOCK TABLES';
    $stmt=$dbh->prepare($sql);
    $stmt->execute();

    $dbh=null;


    ?>


    キャンセル

  • 2016/10/09 02:17

    takasima20さんも指摘されていますが、INSERT文で記載したパラメータ数と実際に設定している数パラメータ数が異なっていますね。

    キャンセル

  • 2016/10/18 07:31

    解決致しました!ご回答ありがとうございます!
    またよろしくお願いいたします。

    キャンセル

0

$dbh を設定してるとこがないですね。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/10/08 22:09

    ご教授ありがとうございます。
    早速転記したのですが次は

    13行目
    $stmt->execute($data);が
    Warning: PDOStatement::execute(): SQLSTATE[HY093]: Invalid parameter number: number of bound variables does not match number of tokens in /Applications/XAMPP/xamppfiles/htdocs/phpkiso/DB/DB_Customer management.php on line 35

    エラー分が発生しており、””送られてる値が違う””と
    言うところまでは把握できているのですが、
    どのように改善したらいいのかわかりません。
    教えていただけると幸いです。
    お願い致します。

    (データベース箇所抜粋)



    1 $dsn = 'mysql:host=localhost;dbname=customer;charset=utf8';
    $user = 'root';
    $password = '';
    $dbh = new PDO($dsn, $user, $password);
    5  $sql= 'INSERT INTO customer_management(name,email,tell) VALUES (?,?,?)';
    $stmt=$dbh->prepare($sql);
    $data=array();
    $data[]=0;
    $data[]=$name;
    10 $data[]=$email;
    $data[]=$tell;
    $data[]=$adress;
    13 $stmt->execute($data);
    $sql='SELECT LAST_INSERT_ID()';
    15 $stmt=$dbh->prepare($sql);
    $stmt->execute();
    $rec=$stmt->fetch(PDO::FETCH_ASSOC);
    $lastcode=$rec['LAST_INSERT_ID()'];

    $sql='UNLOCK TABLES';
    $stmt=$dbh->prepare($sql);
    $stmt->execute();

    $dbh=null;


    ?>

    キャンセル

  • 2016/10/08 23:32

    insert文では3つのvalueを設定するようになっているようですが、
    executeでは5つのものを設定しているように見えます。

    キャンセル

  • 2016/10/18 07:31

    解決致しました!ご回答ありがとうございます!
    またよろしくお願いいたします。

    キャンセル

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

  • ただいまの回答率 90.34%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る

  • MySQL

    7420questions

    MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。