MySQLのINSERTがうまくいかないときにやったこと+その他色々。


概要

管理ユーザー新規登録機能の実装をする段階で、クライアントからの入力情報がMySQLに登録されない(INSERTがうまくいかない)問題が発生。
解決のため小一時間ほど調査を試みた。不注意というか盲点というかツールに頼りすぎるなと教えられたというかまあそんな感じだが、 とにかく同じミスをしないのが大事()

前提

今回はPHP7系でPDOを用いたDB接続を採用。接続自体は成功しており、それに関する不具合は見受けられなかった。参考までに以下テーブルの中身やらソースやら。

【カラム情報】
・id:お約束のやつ。
・username:「name」が予約語というのを知らなかったのでusernameに。
・password1:パスワード入力用。
・password2:パスワード(確認)入力用。

SignUp.php
<?php
    //ユーザー新規登録
    if(isset($_POST['signin'])){
        $username = $_POST['username'];
        $password1 = $_POST['password1'];
        $password2 = $_POST['password2'];
        try{
            $db = new PDO('mysql:host=localhost;dbname=ACCOUNT','root','root');
            $sql = 'INSERT INTO USERS(username, password1, password2) VALUES(?, ?, ?)';
            $stmt = $db->prepare($sql);
            $stmt->execute(array($username, $password1, $password2));
            $stmt = null;
            $db = null;
        }catch(PDOException $e){
            echo $e->getMessage();
            exit;
        }
    }
?>

※password1とpassword2は後から追加実装する予定なので今回は割愛。

とりあえずクエリログを見る

DBはあんまり積極的にエラー吐いてくれないから、とりあえずログを確認してご機嫌をうかがう。

mysql> show full processlist\G;
*************************** 1. row ***************************
     Id: 147
   User: root
   Host: localhost
     db: ACCOUNT
Command: Query
   Time: 0
  State: starting
   Info: show full processlist
1 row in set (0.00 sec)

ERROR:
No query specified

ふむ。バッチリだめです、と。
今度はphpMyAdminの方を少しばかり覗いてみることに。

やっぱり。。。


テーブル編集で一つ一つ確認してみたところ案の定ですわ。

idにauto_increment指定がされてない、、、

実にけしからん。

その他:文字コードもついでに編集

その後、入力画面からデータの登録までうまくいったのですが、文字コードも統一されてなかったようでして。
この際なのできちんと整備しておきました。あとで作業するとき、とんでもなく面倒になったりするとかいう話も聞いたので丁寧に丁寧に。

mysql> show variables like "chara%";
+--------------------------+----------------------------+
| Variable_name            | Value                      |
+--------------------------+----------------------------+
| character_set_client     | utf8                       |
| character_set_connection | utf8                       |
| character_set_database   | latin1                     |
| character_set_filesystem | binary                     |
| character_set_results    | utf8                       |
| character_set_server     | latin1                     |
| character_set_system     | utf8                       |
| character_sets_dir       | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
8 rows in set (0.00 sec)

こいつを、

mysql> show variables like "chara%";
+--------------------------+----------------------------+
| Variable_name            | Value                      |
+--------------------------+----------------------------+
| character_set_client     | utf8                       |
| character_set_connection | utf8                       |
| character_set_database   | utf8                       |
| character_set_filesystem | binary                     |
| character_set_results    | utf8                       |
| character_set_server     | utf8                       |
| character_set_system     | utf8                       |
| character_sets_dir       | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
8 rows in set (0.01 sec)

こうします。latin1になっていた文字コードをutf8に変更しました。
ここら辺の設定が済んだらテーブルを再構築していきます。本当にめんどくさかったから今後はこのあたりの設定も最初に確認しておくべきだと思いました。

ユーザー名:テスト
パス1:user1
パス2(確認用):user1

で登録してみると、

mysql> select*from USERS;
+----+-----------+-----------+-----------+
| id | username  | password1 | password2 |
+----+-----------+-----------+-----------+
|  1 | テスト    | user1     | user1     |
+----+-----------+-----------+-----------+
1 row in set (0.00 sec)

やったぜ。

参照した先人たちの知恵は下記URLにてご参照をよろしくお願いします。全部わかりやすかった…涙

先人たちの知恵

・phpからmysqlのテーブルにINSERTできない
https://teratail.com/questions/12280

・文字コードの確認と変更
https://proengineer.internous.co.jp/content/columnfeature/6653

・MySQLの起動に関するもの(覚えられなくて度々お世話になってます)
https://qiita.com/macer_fkm/items/7013655da212b0efae6f

・コンソールで文字コード設定を変更
https://qiita.com/user0/items/a9116acc7bd7b70ecfb0

まとめ

・テーブルをつくる時はできるだけ漏れなく丁寧に設計。
・文字化け→文字コード設定を変える。時にはコンソール側の設定も修正してみる。

基本的な機能の実装してると同時に周辺知識もどんどんついてくるなと思った(小並感)。