日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > php >内容正文

php

php 数据库查询乱码,怎么解决php数据库查询乱码问题

發布時間:2025/4/5 php 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 php 数据库查询乱码,怎么解决php数据库查询乱码问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

怎么解決php數據庫查詢亂碼問題,數據庫,字符集,亂碼,操作,簡體中文

怎么解決php數據庫查詢亂碼問題

易采站長站,站長之家為您整理了怎么解決php數據庫查詢亂碼問題的相關內容。

php數據庫查詢亂碼的解決辦法:首先在MySQL Command Line Client創建數據庫;然后指定數據庫的字符集,讓mysql同時支持多種編碼的數據庫;最后對創建好的數據庫進行操作即可。

亂碼解決方法

推薦:《PHP教程》

要解決亂碼問題,首先必須弄清楚自己數據庫用什么編碼。如果沒有指明,將是默認的latin1。

我們用得最多的應該是這3種字符集 gb2312,gbk,utf8。

那么我們如何去指定數據庫的字符集呢?下面也gbk為例

【在MySQL Command Line Client創建數據庫】mysql> CREATE TABLE `mysqlcode` ( -> `id` TINYINT( 255 ) UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY , -> `content` VARCHAR( 255 ) NOT NULL -> ) TYPE = MYISAM CHARACTER SET gbk COLLATE gbk_chinese_ci;Query OK, 0 rows affected, 1 warning (0.03 sec)mysql> desc mysqlcode;+---------+-----------------------+------+-----+---------+----------------+| Field | Type | Null | Key | Default | Extra |+---------+-----------------------+------+-----+---------+----------------+| id | tinyint(255) unsigned | NO | PRI | | auto_increment || content | varchar(255) | NO | | | |+---------+-----------------------+------+-----+---------+----------------+2 rows in set (0.02 sec)

其中后面的TYPE = MYISAM CHARACTER SET gbk COLLATE gbk_chinese_ci;

就是指定數據庫的字符集,COLLATE (校勘),讓mysql同時支持多種編碼的數據庫。

當然我們也可以通過如下指令修改數據庫的字符集alter database da_name default character set 'charset'.

客戶端以 gbk格式發送 ,可以采用下述配置:SET character_set_client='gbk'SET character_set_connection='gbk'SET character_set_results='gbk'

這個配置就等價于 SET NAMES 'gbk'。

現在對剛才創建的數據庫操作mysql> use test;Database changedmysql> insert into mysqlcode values(null,'php愛好者');ERROR 1406 (22001): Data too long for column 'content' at row 1

沒有指定字符集為gbk,插入時出錯mysql> set names 'gbk';Query OK, 0 rows affected (0.02 sec)

指定字符集為 gbkmysql> insert into mysqlcode values(null,'php愛好者');Query OK, 1 row affected (0.00 sec)

插入成功mysql> select * from mysqlcode;+----+-----------+| id | content |+----+-----------+| 1 | php愛好著 |+----+-----------+1 row in set (0.00 sec)

在沒有指定字符集gbk時讀取也會出現亂碼,如下mysql> select * from mysqlcode;+----+---------+| id | content |+----+---------+| 1 | php??? |+----+---------+1 row in set (0.00 sec)

【在phpmyadmin創建數據庫,并指定字符集】

表類型根據自己需要選,這里選MyISAM(支持全文檢索);

整理選擇 gbk_chinese_ci 也就是gbk字符集

gbk_bin 簡體中文, 二進制。gbk_chinese_ci 簡體中文, 不區分大小寫。

在剛才創建的數據庫插入數據庫

再瀏覽時發現是亂碼

為什么呢?是因為數據庫為gbk字符集,而我們操作時沒有指定為gbk

回到數據庫首頁

可以看到 mysql 連接校對默認的latin1_bin。我們將其改為gbk_chinese_ci

再插入一條數據。看,這條已經正常了

【解決php讀取數據庫亂碼】

仍以數據庫mysqlcode為例<?php $conn = mysql_connect("localhost","root","89973645"); mysql_query("set names 'gbk'");//這就是指定數據庫字符集,一般放在連接數據庫后面就系了 mysql_select_db("test"); $sql = "select * from mysqlcode"; $result = mysql_query($sql,$conn); ?>

mysql 字符編碼
id內容
".$row['id']."".$row['content']."

總結

以上是生活随笔為你收集整理的php 数据库查询乱码,怎么解决php数据库查询乱码问题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。