目錄
关于php读mysql数据库时出现乱码的解决方法,mysql乱码
首頁 後端開發 php教程 关于php读mysql数据库时出现乱码的解决方法,mysql乱码_PHP教程

关于php读mysql数据库时出现乱码的解决方法,mysql乱码_PHP教程

Jul 12, 2016 am 09:08 AM
mysql資料庫

关于php读mysql数据库时出现乱码的解决方法,mysql乱码

关于php读mysql数据库时出现乱码的解决方法

php读mysql时,有以下几个地方涉及到了字符集。
1.建立数据库表时指定数据库表的字符集。例如

  • create table tablename
  • (
  • id int not null auto_increment,
  • title varchar(20) not null,
  • primary key ('id')
  • )DEFAULT CHARSET =UTF8;
    复制代码
    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都已经统一了编码,但是如果没有调用mysqli::set_charset()函数时,读出数据时仍然会出现乱码。这是为什么?)
      (另,set names utf8相当于下面三句
      SET character_set_client = utf8;
      SET character_set_results = utf8; 
      SET character_set_connection = utf8; 

      4. html页面使用的字符集。在meta标签中设置

    • 复制代码
      5. php文本文件所使用的字符集。
      在linux下可以用vim打开文件,输入
      :set encoding
      查看文件使用的字符集
      要保证不乱码,需要保证文件自身的编码,HTML里指定的编码,PHP告诉Mysql的编码(包括character_set_client和character_set_results)统一。同时使用mysqli:set_charset()函数或”SET NAMES”。
      针对“3”后面的问题,写了几个例子,测试链接数据库后,设置和不设置字符集时的结果。测试环境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教程选自零零H5

      www.bkjia.comtruehttp://www.bkjia.com/PHPjc/1057283.htmlTechArticle关于php读mysql数据库时出现乱码的解决方法,mysql乱码 关于php读mysql数据库时出现乱码的解决方法 php读mysql时,有以下几个地方涉及到了字符...
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

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整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1657
14
CakePHP 教程
1415
52
Laravel 教程
1309
25
PHP教程
1257
29
C# 教程
1229
24
PHP開發實務:使用PHPMailer傳送郵件到MySQL資料庫的用戶 PHP開發實務:使用PHPMailer傳送郵件到MySQL資料庫的用戶 Aug 05, 2023 pm 06:21 PM

PHP開發實務:使用PHPMailer發送郵件到MySQL資料庫中的使用者引言:在現代互聯網建設中,郵件是一種重要的溝通工具。無論是用戶註冊、密碼重置,還是電子商務中的訂單確認,發送電子郵件都是必不可少的功能。本文將介紹如何使用PHPMailer來傳送電子郵件,並將郵件資訊儲存到MySQL資料庫中的使用者資訊表中。一、安裝PHPMailer庫PHPMailer是

Go語言和MySQL資料庫:如何進行資料冷熱分離處理? Go語言和MySQL資料庫:如何進行資料冷熱分離處理? Jun 18, 2023 am 08:26 AM

隨著資料量的不斷增加,資料庫的效能成為了一個越來越重要的問題。資料冷熱分離處理是一種有效的解決方案,它可以將熱點資料和冷資料分離,從而提高系統的效能和效率。本文將介紹如何使用Go語言和MySQL資料庫進行資料冷熱分離處理。一、什麼是資料冷熱分離處理資料冷熱分離處理是一種將熱點資料和冷資料進行分類處理的方式。熱點數據是指存取頻率高、對效能要求高的數據,冷數

如何使用MySQL資料庫進行時間序列分析? 如何使用MySQL資料庫進行時間序列分析? Jul 12, 2023 am 08:39 AM

如何使用MySQL資料庫進行時間序列分析?時間序列資料是指依照時間順序排列的資料集合,它具有時間上的連續性和相關性。時間序列分析是一種重要的資料分析方法,可用於預測未來趨勢、發現週期性變化、檢測異常值等。在本文中,我們將介紹如何使用MySQL資料庫進行時間序列分析,並附上程式碼範例。建立資料表首先,我們需要建立一個資料表來儲存時間序列資料。假設我們要分析的數

如何使用MySQL資料庫進行影像處理? 如何使用MySQL資料庫進行影像處理? Jul 14, 2023 pm 12:21 PM

如何使用MySQL資料庫進行影像處理? MySQL是一種強大的關聯式資料庫管理系統,除了用於儲存和管理資料之外,它還可以用於映像處理。本文將介紹如何使用MySQL資料庫進行影像處理,並提供一些程式碼範例。在開始之前,請確保已經安裝了MySQL資料庫,並且已經熟悉了基本的SQL語句。建立資料庫表格首先,建立一個新的資料庫表格,用於儲存影像資料。表格的結構可以如下所

MySQL資料庫技能培養到什麼程度能夠成功就業? MySQL資料庫技能培養到什麼程度能夠成功就業? Sep 12, 2023 pm 06:42 PM

MySQL資料庫技能培養到什麼程度能夠成功就業?隨著資訊化時代的快速發展,資料庫管理系統成為各行各業不可或缺的重要組成部分。而MySQL作為一種常用的關係型資料庫管理系統,具有廣泛的應用領域和就業機會。那麼,MySQL資料庫技能需要培養到什麼程度,才能夠成功就業呢?首先,掌握MySQL的基本原理和基礎知識是最基本的要求。 MySQL是一款開源的關聯式資料庫管理

使用Go語言進行MySQL資料庫的資料增量備份的方法 使用Go語言進行MySQL資料庫的資料增量備份的方法 Jun 17, 2023 pm 02:28 PM

隨著資料量的增加,資料庫的備份變得越來越重要。而對於MySQL資料庫,我們可以藉助Go語言實現自動化的增量備份。本篇文章將簡單介紹如何使用Go語言進行MySQL資料庫的資料增量備份。一、安裝Go語言環境首先,我們需要在本地安裝Go語言環境。可前往官網下載對應的安裝包並進行安裝。二、安裝對應的函式庫Go語言提供了許多存取MySQL資料庫的第三方函式庫,其中較為常用的

如何使用Go語言進行可靠的MySQL資料庫連線? 如何使用Go語言進行可靠的MySQL資料庫連線? Jun 17, 2023 pm 07:18 PM

隨著大量的資料需要儲存和處理,MySQL已經成為了應用程式開發中最常用的關聯式資料庫之一。而Go語言由於其高效並發處理和簡潔的語法,也越來越受到開發者的歡迎。本文將帶領讀者透過Go語言實現可靠的MySQL資料庫連接,讓開發者更有效率地查詢並儲存資料。一、Go語言連接MySQL資料庫的幾種方式Go語言中連接MySQL資料庫通常有3種方式,分別是:1.第三方函式庫

如何為 MySQL 資料庫實現雙向 SSL 認證 如何為 MySQL 資料庫實現雙向 SSL 認證 Sep 09, 2023 pm 07:36 PM

如何為MySQL資料庫實現雙向SSL認證什麼是雙向SSL認證?雙向SSL(SecureSocketsLayer)認證是一種加密通訊方式,它要求服務端和客戶端之間互相驗證對方的身分。在資料庫中,雙向SSL認證可確保只有經過授權的使用者和應用程式可以連接和通信,提高資料安全性。準備工作在開始設定雙向SSL認證之前,請確保以下條件已滿足:已獲

See all articles