PHP,MySQL初心者です。
下記PHPファイルを実行し、インサートする度に
AUTO_INCREMENTでid(INT,AUTO_INCREMENT)を1づつ増やしテーブル内にレコードを
増やしていきたいのですが、一回実行すると「2147483647」がidカラムに入ってしまい、
2回目以降は、
SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry '2147483647' for key 'ID'のエラーが出てしまう状況です。
PHPファイル内容:
<?php
if($_POST['singnup_btn']){
$name = $_POST["name"];
$mail = $_POST["mail"];
$password = $_POST["password"];
//出力確認
echo $name;
echo $mail;
echo $password;
try {
// DB情報取得
include('./DBSighIn.php');
$pdo = new PDO($dsn,$user,$password,
[
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
]
);
//Insert
$stmt = $pdo -> prepare("INSERT INTO USER(NAME, EMAIL, PASSWORD) VALUES ('$name', '$mail', '$password')");
$stmt->execute();
} catch (PDOException $e) {
// エラーが発生した場合は「500 Internal Server Error」でテキストとして表示して終了する
header('Content-Type: text/plain; charset=UTF-8', true, 500);
exit($e->getMessage());
}
}
?>
MySQLテーブルの構造は以下の通り作成しております。
フィールド,種別,照合順序,属性,ヌル(NULL),デフォルト値,その他
ID,int(20),,,いいえ,None,AUTO_INCREMENT
NAME,varchar(30),utf8_general_ci,,いいえ,None,
EMAIL,varchar(100),utf8_general_ci,,いいえ,None,
PASSWORD,varchar(12),utf8_general_ci,,いいえ,None,
ご教示頂けると幸いです。
-
気になる質問をクリップする
クリップした質問は、後からいつでもマイページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
クリップを取り消します
-
良い質問の評価を上げる
以下のような質問は評価を上げましょう
- 質問内容が明確
- 自分も答えを知りたい
- 質問者以外のユーザにも役立つ
評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。
質問の評価を上げたことを取り消します
-
評価を下げられる数の上限に達しました
評価を下げることができません
- 1日5回まで評価を下げられます
- 1日に1ユーザに対して2回まで評価を下げられます
質問の評価を下げる
teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。
- プログラミングに関係のない質問
- やってほしいことだけを記載した丸投げの質問
- 問題・課題が含まれていない質問
- 意図的に内容が抹消された質問
- 過去に投稿した質問と同じ内容の質問
- 広告と受け取られるような投稿
評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。
質問の評価を下げたことを取り消します
この機能は開放されていません
評価を下げる条件を満たしてません
質問の評価を下げる機能の利用条件
この機能を利用するためには、以下の事項を行う必要があります。
- 質問回答など一定の行動
-
メールアドレスの認証
メールアドレスの認証
-
質問評価に関するヘルプページの閲覧
質問評価に関するヘルプページの閲覧
checkベストアンサー
+1
とりあえずprepareの使い方がおかしいのでそれも含めて。
/*どうしてもインフィニになるならauto_incrementの初期化*/
$stmt = $pdo -> query("alter table user auto_increment = 1");
$stmt = $pdo -> prepare("INSERT INTO USER(NAME, EMAIL, PASSWORD) VALUES (?,?,?)");
$data=[$name,$mail,$password];/*typo修正*/
$stmt->execute($data);
投稿
-
回答の評価を上げる
以下のような回答は評価を上げましょう
- 正しい回答
- わかりやすい回答
- ためになる回答
評価が高い回答ほどページの上位に表示されます。
-
回答の評価を下げる
下記のような回答は推奨されていません。
- 間違っている回答
- 質問の回答になっていない投稿
- スパムや攻撃的な表現を用いた投稿
評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。
15分調べてもわからないことは、teratailで質問しよう!
- ただいまの回答率 88.22%
- 質問をまとめることで、思考を整理して素早く解決
- テンプレート機能で、簡単に質問をまとめられる
質問への追記・修正、ベストアンサー選択の依頼
CHERRY
2017/12/20 11:08
MySQL のテーブルは、どのように作成されたのでしょうか?
qa_
2017/12/20 11:16 編集
早速のご質問ありがとうございます。下記構造にて作成しました。
フィールド,種別,照合順序,属性,ヌル(NULL),デフォルト値,その他
ID,int(20),,,いいえ,None,AUTO_INCREMENT
NAME,varchar(30),utf8_general_ci,,いいえ,None,
EMAIL,varchar(100),utf8_general_ci,,いいえ,None,
PASSWORD,varchar(12),utf8_general_ci,,いいえ,None,
Orlofsky
2017/12/20 11:35
質問の場所にCREATE TABLEを載せましょう。
ttyp03
2017/12/20 11:39
drop tableしてからcreate tableしてもそうなるのでしょうか?
CHERRY
2017/12/20 13:00 編集
うーん。 auto_increment_increment や auto_increment_offset に間違った数字が入っていたりするのかなぁ... 「 show variables like '%auto_inc%'; 」の SQL を実行したらどのような数字が表示されますか?
qa_
2017/12/20 13:17
show variables like '%auto_inc%';の実行で共に「1」が返ってきます。