字段中的字符集必须是utf8mb4, 如果你建表的时候默认字符集不是这个,那么字段就必须指明使用的是这个字符集;

COLLATE 随意,通常为了提供更好的排序性能一般会使用utf8mb4_general_ci;

连接时必须set names "utf8mb4";

这是一段PHP示例

<?php
//$emoji_1 = "?????2\x7a\xc3\x9f\xe6\xb0\xb4\xf0\x9f\x8d\x8c";
//$emoji_1 = "zß\u6c34\U0001f34c";
$emoji_1 = "\xf0\x9f\x8d\x8c";
$dbh = new PDO( 'mysql:host=localhost;dbname=test', 'root', '' );
$dbh->exec(' set names "utf8mb4" ');
$tablename = "test_9";

if($_GET['show'] == 1){
    $query = 'select * from `'.$tablename.'` where `id` = ?';

    $stm = $dbh->prepare($query);
    $stm->bindValue(1, $_GET['id'], PDO :: PARAM_INT );
    $stm->execute();
    while($row = $stm->fetch( PDO :: FETCH_ASSOC )){
        var_dump($row);
    }
}else{
    $query = 'insert into `'.$tablename.'` (`name`, `a`)values(?, ?)';
    var_dump(strlen($emoji_1));
    $stm = $dbh->prepare($query);
    $stm->bindParam(1, $emoji_1, PDO :: PARAM_STR,  strlen($emoji_1));
    $stm->bindValue(2, 3, PDO :: PARAM_INT );
    if(!$stm -> execute ()){
        var_dump($stm -> errorInfo ());
    }else{
        echo "okay.\n";
    }
}

附:

MySql中可以用UNHEX(FF...)插入HEX值;

虽然UNHEX的名字看起来很像是unicode hex的缩写,看上去很像是把unicode字符编码转换成字段的字符编码方式再写入,但实际上它不会对值做任何处理就直接写入内容。例如插入一个UTF8字符,输入的就是这个字符的UTF8编码,而不是unicode编码

INSERT INTO my_tbl (my_col) VALUES (UNHEX('F09F949F'));

 

相关文章:

  • 2021-10-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-07-04
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2022-01-13
  • 2021-12-03
  • 2022-12-23
  • 2021-11-28
  • 2021-06-04
相关资源
相似解决方案