12

Cookie は big5 セットを使用してエンコードされており、MySQL に挿入することはできません。この問題を解決するのを手伝ってくれませんか?

フィールド:username英語、date1日付、reason1漢字。

$reason1 = $_COOKIE["reason"];
$sql2="INSERT INTO 
    attendance_count(username,date,count_time,appendix) 
    VALUES ('$username','$date1','0','$reason1')";
mysql_query($sql2);
4

4 に答える 4

29

テーブルを作成するときはUTF-8を使用してください。

create table table_name () CHARACTER SET = utf8;

テーブルに挿入するときはUTF-8を使用してください

set username utf8; INSERT INTO table_name (ABC,VAL);

続きを読む

もっと

詳細コード

以下のコードはテスト済みのコードです。次の作業を行ってください。

すでにデータベースを作成している場合は、以下のコードのように ALTER してください。データベースを作成していない場合は、データベースを作成し、Collat​​ion を utf8_unicode_ci に設定します。

テーブルについても同様に、照合を「utf8_unicode_ci」として定義し、中国語の文字を格納するテーブルフィールドに使用します。

ALTER DATABASE `stackoverflow` DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci;

CREATE TABLE `stackoverflow`.`chines`
(
    `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
    `words` VARCHAR( 200 ) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL
) ENGINE = InnoDB;
<?php

    define('HOSTNAME', 'localhost');
    define('USERNAME', 'root');
    define('PASSWORD', '');
    define('DATABASE', 'stackoverflow');

    $dbLink = mysql_connect(HOSTNAME, USERNAME, PASSWORD)or die(mysql_error());
    mysql_query("SET character_set_results=utf8", $dbLink)or die(mysql_error());
    mb_language('uni'); 
    mb_internal_encoding('UTF-8');
    mysql_select_db(DATABASE, $dbLink)or die(mysql_error());
    mysql_query("set names 'utf8'",$dbLink)or die(mysql_error());

    if(isset($_POST['addWord']))
    {
        mysql_query("SET character_set_client=utf8", $dbLink)or die(mysql_error());
        mysql_query("SET character_set_connection=utf8", $dbLink)or die(mysql_error());

        $sql_query = "INSERT INTO chines(words) VALUES('".$_POST['words']."')";
        mysql_query($sql_query, $dbLink)or die(mysql_error());
    }

?>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html;charset=UTF-8" />
    <title></title>
</head>
<body>
    <?php
        mysql_query("SET character_set_results=utf8", $dbLink);
        $sql_query = "SELECT * FROM chines";
        $dbResult = mysql_query( $sql_query, $dbLink)or die(mysql_error());

    ?>

    <form action="" method="post">

        <p>Word : <input type="text" name="words" /></p>
        <p><input type="submit" name="addWord" /></p>

    </form>
    <?php
        while($row = mysql_fetch_assoc($dbResult))
        {
            echo $row['words']. '<br />';
        }
    ?>
</body>
</html>

以下のように、結果とステップのビジュアルを参照してください。

ここに画像の説明を入力

于 2013-01-22T10:28:41.263 に答える
4

utf8mb4中国語の場合、 ではなくが本当に必要ですutf8utf8これは、MySQLがサポートしていない4 バイト UTF8 文字を必要とする少数の中国語文字によるものです。

于 2016-07-24T02:02:29.153 に答える
0

本当の問題は、Cookie がエンコードされていることbig5です。クライアント内の残りのデータはとしてエンコードされていutf8ますか? 両方に「はい」の場合...

接続を に変更し、Cookie の/をbig5実行してから、utf8 (または、アップグレード後に utf8mb4 に変更することをお勧めします) に戻します。INSERTSELECT

使用している API の関数を実行SET NAMES big5または呼び出すことcharset('big5')は、前後に切り替えるための推奨される方法です。

(その間、インターフェイスから離れて、またはmysql_*に切り替えます。)mysqli_*PDO

クライアント内のすべてが である場合big5、前後に切り替える必要はありません。クライアントが big5 を使用していることを宣言するだけです。注: テーブル/列も big5 かどうかは問題ではありません。MySQL はそれらの間で変換します。

于 2016-12-07T19:25:53.687 に答える