国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁 后端開發(fā) PHP問題 總結mysql php亂碼問題

總結mysql php亂碼問題

Jul 06, 2020 am 09:21 AM
mysql php

解決mysql php亂碼問題:1、建立數據庫表時指定數據庫表的字符集;2、設置mysql的字符集;3、連接數據庫后,設置數據庫間傳輸字符時所用的默認字符編碼;4、設置html頁面使用的字符集。

總結mysql php亂碼問題

php讀mysql時,有以下幾個地方涉及到了字符集。

1.?建立數據庫表時指定數據庫表的字符集。例如

 create table tablename 
 ( 
 id int not null auto_increment, 
 title varchar(20) not null,  
 primary key ('id') 
 )DEFAULT CHARSET =UTF8;

如果在創(chuàng)建表時沒有指定表的字符集,則使用表所屬的數據庫的默認字符集。該字符集由character_set_database指定。
查看數據庫表所使用的字符集的方法是:

show create table mytable;

(PS:建立數據庫/表和進行數據庫操作時盡量顯式指出使用的字符集,而不是依賴于MySQL的默認設置,否則MySQL升級時可能帶來很大困擾[1])

2. mysql的字符集
mysql中有三個重要的變量,character_set_client,character_set_results,character_set_connection。
通過設置character_set_client,告訴Mysql,PHP存進數據庫的是什么編碼方式。
通過設置character_set_results,告訴Mysql,PHP需要取什么樣編碼的數據。
通過設置character_set_connection,告訴Mysql,PHP查詢中的文本,使用什么編碼。

3. 連接數據庫后,設置數據庫間傳輸字符時所用的默認字符編碼。
使用mysqli::set_charset()或mysqli::query('set names utf8'),進行設置。
盡量使用mysqli::set_charset(mysqli:set_charset)而不是”SET NAMES”(參考這篇文章)

$db = new mysqli('localhost','user','passwd','database_name');$db->set_charset('utf8');

注意是utf8,不是utf-8
(這里有個問題就是,數據庫和php都已經統(tǒng)一了編碼,但是如果沒有調用mysqli::set_charset()函數時,讀出數據時仍然會出現亂碼。這是為什么?)
(另,set names utf8相當于下面三句
SET character_set_client = utf8;
SET character_set_results = utf8;
SET character_set_connection = utf8;


4. html頁面使用的字符集。在meta標簽中設置

<meta http-equiv="content-type" content="text/html; charset=utf-8">

5. php文本文件所使用的字符集。
在linux下可以用vim打開文件,輸入
:set encoding
查看文件使用的字符集

要保證不亂碼,需要保證文件自身的編碼,HTML里指定的編碼,PHP告訴Mysql的編碼(包括character_set_client和character_set_results)統(tǒng)一。同時使用mysqli:set_charset()函數或”SET NAMES”。

針對“3”后面的問題,寫了幾個例子,測試鏈接數據庫后,設置和不設置字符集時的結果。測試環(huán)境Ubuntu 12.04,MySQL 5.5,php 5.5.7。
結果如下:
(1) 數據庫表字符集是utf8,不使用set names utf8
能正常插入、讀出中文,但是在mysql中顯示亂碼

(2) 數據庫表字符集是utf8,使用set names utf8
能正常插入、讀出中文,mysql中顯示正確

(3) 數據庫表字符集不是utf8,使用set names utf8
mysql中顯示,讀出都是問號。

很多相關知識,請訪問PHP中文網!

以上是總結mysql php亂碼問題的詳細內容。更多信息請關注PHP中文網其他相關文章!

本站聲明
本文內容由網友自發(fā)貢獻,版權歸原作者所有,本站不承擔相應法律責任。如您發(fā)現有涉嫌抄襲侵權的內容,請聯系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅動的應用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機

Video Face Swap

Video Face Swap

使用我們完全免費的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級代碼編輯軟件(SublimeText3)

為什么我們評論:PHP指南 為什么我們評論:PHP指南 Jul 15, 2025 am 02:48 AM

PHPhasthreecommentstyles://,#forsingle-lineand/.../formulti-line.Usecommentstoexplainwhycodeexists,notwhatitdoes.MarkTODO/FIXMEitemsanddisablecodetemporarilyduringdebugging.Avoidover-commentingsimplelogic.Writeconcise,grammaticallycorrectcommentsandu

如何在Windows上安裝PHP 如何在Windows上安裝PHP Jul 15, 2025 am 02:46 AM

安裝PHP在Windows上的關鍵步驟包括:1.下載合適的PHP版本并解壓,推薦使用ThreadSafe版本配合Apache或NonThreadSafe版本配合Nginx;2.配置php.ini文件,將php.ini-development或php.ini-production重命名為php.ini;3.將PHP路徑添加到系統(tǒng)環(huán)境變量Path中以便命令行使用;4.測試PHP是否安裝成功,通過命令行執(zhí)行php-v和運行內置服務器測試解析能力;5.若使用Apache,需在httpd.conf中配置P

PHP語法:基礎知識 PHP語法:基礎知識 Jul 15, 2025 am 02:46 AM

PHP的基礎語法包括四個關鍵點:1.PHP標簽必須使用結束,推薦使用完整標簽;2.輸出內容常用echo和print,其中echo支持多參數且效率更高;3.注釋方式有//、#和//,用于提升代碼可讀性;4.每條語句必須以分號結尾,空格和換行不影響執(zhí)行但影響可讀性。掌握這些基本規(guī)則有助于寫出清晰穩(wěn)定的PHP代碼。

什么是PHP,它是用什么? 什么是PHP,它是用什么? Jul 16, 2025 am 03:45 AM

PHPisaserver-sidescriptinglanguageusedforwebdevelopment,especiallyfordynamicwebsitesandCMSplatformslikeWordPress.Itrunsontheserver,processesdata,interactswithdatabases,andsendsHTMLtobrowsers.Commonusesincludeuserauthentication,e-commerceplatforms,for

PHP 8安裝指南 PHP 8安裝指南 Jul 16, 2025 am 03:41 AM

在Ubuntu上安裝PHP8的步驟為:1.更新軟件包列表;2.安裝PHP8及基礎組件;3.檢查版本確認安裝成功;4.按需安裝額外模塊。Windows用戶可下載ZIP包并解壓,隨后修改配置文件、啟用擴展并將路徑加入環(huán)境變量。macOS用戶推薦使用Homebrew安裝,依次執(zhí)行添加tap、安裝PHP8、設置默認版本及驗證版本等步驟。不同系統(tǒng)下安裝方式雖有差異,但流程清晰,根據用途選對方法即可。

您的第一個PHP腳本:實用介紹 您的第一個PHP腳本:實用介紹 Jul 16, 2025 am 03:42 AM

如何開始編寫第一個PHP腳本?首先設置本地開發(fā)環(huán)境,安裝XAMPP/MAMP/LAMP,使用文本編輯器,了解服務器運行原理。其次,創(chuàng)建一個名為hello.php的文件,輸入基本代碼并運行測試。第三,學習混合使用PHP與HTML以實現動態(tài)內容輸出。最后,注意常見錯誤如缺少分號、引用問題及文件擴展名錯誤,并開啟錯誤報告以便調試。

您如何處理PHP中的文件操作(閱讀/寫作)? 您如何處理PHP中的文件操作(閱讀/寫作)? Jul 16, 2025 am 03:48 AM

tohandlefileoperationsinphp,useApprepreprunctions andModes.1.toreadafile,usefile_get_contents()forsmallfilesorfgets()inaloopforline by line-line-processing.2.towriteToafile,usefile_put_cte_contents(usefile_contents)(

python如果還有示例 python如果還有示例 Jul 15, 2025 am 02:55 AM

寫Python的ifelse語句關鍵在于理解邏輯結構與細節(jié)。1.基礎結構是if條件成立執(zhí)行一段代碼,否則執(zhí)行else部分,else可選;2.多條件判斷用elif實現,順序執(zhí)行且一旦滿足即停止;3.嵌套if用于進一步細分判斷,建議不超過兩層;4.簡潔場景可用三元表達式替代簡單ifelse。注意縮進、條件順序及邏輯完整性,才能寫出清晰穩(wěn)定的判斷代碼。

See all articles