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

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

ただいまの
回答率

90.49%

  • PHP

    20745questions

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

  • MySQL

    5985questions

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

Mysqlを使ったPHPのフォームでErrorSQLSTATE[23000]: Integrity constraint violation

解決済

回答 3

投稿

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

panyayan

score 9

Mysqlを使ったPHPのフォームで下記のエラーが出ます。

ErrorSQLSTATE[23000]: Integrity constraint violation: 1048 Column 'name' cannot be null

値が無いとインサートできないという内容だと思うのですが、値はしっかりあるように思います。
typoを確認したりしたのですがどうもうまくインサートできません
どうかご教授いただけると嬉しいです。

<?php

require_once 'lib/h.php';

$max_size = 4 * 1024 *1024; //limit is 4MB

$file_uploaded = false;

if(!empty($_POST['name'])){
    $errors['name'] = 'Sorry you have to enter name';
}else{
    $name = htmlspecialchars($_POST['name'],ENT_QUOTES);
}

if(!empty($_POST['name_kana'])) {
    $errors['name_kana'] = 'Sorry you have to enter name';
}else{
    $name_kana = htmlspecialchars($_POST['name_kana'], ENT_QUOTES);
}

if(!empty($_POST['location'])) {
    $errors['location'] = 'Sorry you have to enter location';
}else{
    $location = htmlspecialchars($_POST['location'], ENT_QUOTES);
}

if(!empty($_POST['tellnumber'])) {
    $errors['tellnumber'] = 'Sorry you have to enter tell number';
}else{
    $tellnumber = htmlspecialchars($_POST['tellnumber'], ENT_QUOTES);
}

if(!empty($_POST['sex'])) {
    $errors['sex'] = 'Sorry. you have to select your sex';
}else{
    $sex = htmlspecialchars($_POST['sex'], ENT_QUOTES);
}

if(isset($_FILES['image'])) {
    if (! check_image()){
        echo 'Sorry this is not Jpeg image file or We cant function image file.';
    }elseif ($_FILES['image']['size']>$max_size){
        echo 'Sorry You have to upload file is under 4MB';
    }elseif (! $file = fopen($_FILES['image']['tmp_name'], 'rb')){
        echo 'Cant open file';
    }else{
        $image = fread($file, $_FILES['image']['size']);
        fclose($file);
        if(!$image){
            echo 'cant load image';
        }else{
            $file_uploaded = true;
        }
    }
}

if (!empty($_POST['submit'])){
    require_once 'config/database.php';

    try {
        $db = new PDO($dsn,$user,$pass);
        $db->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
        $db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

        $sql = 'INSERT INTO apply_list(`id`, `name_kana`, `location`, `tellnumber`, `sex`, `image`) VALUES(NULL, :name, :name_kana, :location, :tellnumber, :sex, :image)';

        $prepare = $db->prepare($sql);

        $prepare->bindParam(':name', $name, PDO::PARAM_STR);
        $prepare->bindParam(':name_kana', $name_kana, PDO::PARAM_STR);
        $prepare->bindParam(':location', $location, PDO::PARAM_STR);
        $prepare->bindParam(':tellnumber', $tellnumber, PDO::PARAM_STR);
        $prepare->bindParam(':sex', $sex, PDO::PARAM_STR);
        $prepare->bindParam(':image', $image, PDO::PARAM_LOB);

        $prepare->execute();
    }catch (PDOException $e){
        echo 'Error'. h($e->getMessage());
    }
}

function check_image(){
    $tmp_name = $_FILES['image']['tmp_name'];

    if(! is_uploaded_file($tmp_name)){
        return false;
    }

    $finfo = new finfo(FILEINFO_MIME_TYPE);
    $type = $finfo->file($tmp_name);
    if ($type !== 'image/jpeg') {
        return false;
    }

    return true;

}

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Form</title>
</head>
<body>

<form method="post" action="">
    <label>name: </label>
    <input type="text" name="name" placeholder="Enter your name">
    <br>
    <label>kana: </label>
    <input type="text" name="name_kana" placeholder="Enter your kana name">
    <br>
    <label>location</label>
    <input type="text" name="location" placeholder="Enter your location">
    <br>
    <label>tell number: </label>
    <input type="text" name="tellnumber" placeholder="Enter your tell number">
    <br>
    <label>sex: </label>
    <input type="radio" name="sex" value="0">
    <label>men: </label>
    <input type="radio" name="sex" value="1">
    <label>women: </label>
    <br>
    <label>Select your image</label>
    <input type="file" name="image" value="">
    <br>

    <input type="submit" name="submit">
</form>

</body>
</html>
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 3

+2

項目の数が違ってる、なんて話ではないですか?

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/04/15 17:27

    項目というのはSQLのinsertの項目でしょうか?そうであれば、間違っていませんでした

    キャンセル

  • 2018/04/15 22:14

    apply_list(`id`, `name_kana`, `location`, `tellnumber`, `sex`, `image`) <-6個
    VALUES(NULL, :name, :name_kana, :location, :tellnumber, :sex, :image) <-7個

    キャンセル

checkベストアンサー

+1

 $sql = 'INSERT INTO apply_list(`id`, `name_kana`, `location`, `tellnumber`, `sex`, `image`) 以下略

カラムの指定にnameが無いのでnameにはNULLが入りますがNULL制約でエラーになっています。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

+1

INSERT文で name が抜けているためではないでしょうか。

以下が正しいかと思います。

INSERT INTO apply_list(`id`, `name`, `name_kana`, `location`, `tellnumber`, `sex`, `image`) ...

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

関連した質問

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

  • PHP

    20745questions

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

  • MySQL

    5985questions

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