ホームページ データベース mysql チュートリアル 对MySQL中字符集的相关设置操作的基本教程_MySQL

对MySQL中字符集的相关设置操作的基本教程_MySQL

May 27, 2016 pm 01:46 PM
mysql キャラクターセット チュートリアル

1、查看字符集相关变量

mysql> show variables like 'character%';

ログイン後にコピー

+————————–+——————————-+

| Variable_name      | Value             |

+————————–+——————————-+

| character_set_client   | latin1            |

| character_set_connection | latin1            |

| character_set_database  | latin1            |

| character_set_filesystem | binary            |

| character_set_results  | latin1            |

| character_set_server   | latin1            |

| character_set_system   | utf8             |

| character_sets_dir    | c:\wamp\mysql\share\charsets\ |

+————————–+——————————-+

ログイン後にコピー


2、字符集转换过程
客户端——–字符集转换器———–服务
gbk ————gbk-utf8-utf8———-utf8
gbk————-gbk-gbk-utf8———-utf8
客户端要告诉服务端使用的编码是什么,然后没有直接告诉服务器而告诉“转换器”
字符集转换器收到客户端信息后查看服务器是什么编码,然后将客户端传来的字符集转换成服务器设置的字符集
服务器向客户端发送信息时也是先告诉“转换器”

3、字符集变量解释

character_set_client
客户端字符集,连接mysql的客户端程序的字符集,该变量告诉转换器客户端发送的字符集。

character_set_connection
转换器转换要转换成的字符集

character_set_server
服务端使用的字符集,存入数据时使用的字符集

character_set_results
查询的结果是什么编码

推论:什么时候会出现乱码

1:client 什么与实际不符,微软命令提示符默认是gbk,如果设置成utf8就会出现乱码

2:results与客户端页面不符的时候

什么时候会丢失数据

connection和服务器的字符集比client小时,会丢失数据,比如客户端是utf8而转换器是gbk

当客户端是utf8 而服务端是 gbk时要设置

set character_set_client=utf8

set character_set_connection=gbk/utf8 这里设置什么都可以,因为最终转换器会根据服务器的类型进行转换

set character_set_results=utf8

4、设置字符集变量

set names utf8 进入mysql设置所用的字符集

在my.conf中添加

[client]
default-character-set=utf8
[mysqld]
default-character-set=utf8

ログイン後にコピー

5.修改mysql字符集
将latin1字符集的数据库修改成gbk字符集的数据库的过程
(1)、导出表结构

mysqldump -uroot -p –default-character-set=gbk -d DATABASE_NAME > createtable.sql
ログイン後にコピー

–default-character-set=gbk 表示以什么字符集连接
-d 表示只导出表结构,不导出数据
(2)、修改createtable.sql文件中的表结构定义的字符集为新字符集
(3)、导出所有记录

mysqldump -uroot -p –quick –no-create-info –extend-insert –default-character-set DATABASE_NAME > data.sql
ログイン後にコピー

–quick:改讯息用于转储大的表。它强制mysqldump从服务器一次一行的检索表中的行二不是检索所有行,并在输出钱将它缓存到内存中
–extended-insert:使用包括几个values列表的多行insert语法。这样转储文件更小,重载文件时可以加速插入
–no-create-info:不重新创建每个转储表的create table 语句
–default-character-set=latin1:安装原有的字符集导出所有数据,这样导出的文件中,所有中文都是可见的,不会保存成乱码
(4)、带宽data.sql,将set names latin1 修改成set names gabk
(5)、使用新的字符集创建新的数据库

create database DATABASE_NAME default charset gbk;
ログイン後にコピー

(6)、创建表,执行createtable.sql

mysql -uroot -p DATABASE_NAME < createtable.sql
ログイン後にコピー

(7)、导入数据,执行data.sql

mysql -uroot -p DATABASE_NAME < data.sql
ログイン後にコピー

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

PHP で MySQL クエリのパフォーマンスを最適化するにはどうすればよいですか? PHP で MySQL クエリのパフォーマンスを最適化するにはどうすればよいですか? Jun 03, 2024 pm 08:11 PM

MySQL クエリのパフォーマンスは、検索時間を線形の複雑さから対数の複雑さまで短縮するインデックスを構築することで最適化できます。 PreparedStatement を使用して SQL インジェクションを防止し、クエリのパフォーマンスを向上させます。クエリ結果を制限し、サーバーによって処理されるデータ量を削減します。適切な結合タイプの使用、インデックスの作成、サブクエリの使用の検討など、結合クエリを最適化します。クエリを分析してボトルネックを特定し、キャッシュを使用してデータベースの負荷を軽減し、オーバーヘッドを最小限に抑えます。

PHP で MySQL のバックアップと復元を使用するにはどうすればよいですか? PHP で MySQL のバックアップと復元を使用するにはどうすればよいですか? Jun 03, 2024 pm 12:19 PM

PHP で MySQL データベースをバックアップおよび復元するには、次の手順を実行します。 データベースをバックアップします。 mysqldump コマンドを使用して、データベースを SQL ファイルにダンプします。データベースの復元: mysql コマンドを使用して、SQL ファイルからデータベースを復元します。

PHP を使用して MySQL テーブルにデータを挿入するにはどうすればよいですか? PHP を使用して MySQL テーブルにデータを挿入するにはどうすればよいですか? Jun 02, 2024 pm 02:26 PM

MySQLテーブルにデータを挿入するにはどうすればよいですか?データベースに接続する: mysqli を使用してデータベースへの接続を確立します。 SQL クエリを準備します。挿入する列と値を指定する INSERT ステートメントを作成します。クエリの実行: query() メソッドを使用して挿入クエリを実行します。成功すると、確認メッセージが出力されます。

夏はぜひ虹を撮ってみてください 夏はぜひ虹を撮ってみてください Jul 21, 2024 pm 05:16 PM

夏の雨の後には、美しく魔法のような特別な天気の風景、虹がよく見られます。これも写真撮影ではなかなか出会えない光景で、とてもフォトジェニックです。虹が現れるにはいくつかの条件があります。まず、空気中に十分な水滴があること、そして、低い角度から太陽が当たることです。そのため、雨が上がった午後が最も虹が見えやすいのです。ただし、虹の発生は天候や光などの条件に大きく左右されるため、一般に虹の持続時間は短く、見頃や撮影に最適な時間はさらに短くなります。では、虹に遭遇したとき、どうすれば虹を適切に記録し、高品質の写真を撮ることができるでしょうか? 1. 虹を探す 上記の条件に加えて、虹は通常、太陽光の方向に現れます。つまり、太陽が西から東に輝いている場合、虹は東に現れやすくなります。

MySQL 8.4 で mysql_native_password がロードされていないエラーを修正する方法 MySQL 8.4 で mysql_native_password がロードされていないエラーを修正する方法 Dec 09, 2024 am 11:42 AM

MySQL 8.4 (2024 年時点の最新の LTS リリース) で導入された主な変更の 1 つは、「MySQL Native Password」プラグインがデフォルトで有効ではなくなったことです。さらに、MySQL 9.0 ではこのプラグインが完全に削除されています。 この変更は PHP および他のアプリに影響します

PHP で MySQL ストアド プロシージャを使用するにはどうすればよいですか? PHP で MySQL ストアド プロシージャを使用するにはどうすればよいですか? Jun 02, 2024 pm 02:13 PM

PHP で MySQL ストアド プロシージャを使用するには: PDO または MySQLi 拡張機能を使用して、MySQL データベースに接続します。ストアド プロシージャを呼び出すステートメントを準備します。ストアド プロシージャを実行します。結果セットを処理します (ストアド プロシージャが結果を返す場合)。データベース接続を閉じます。

PHP を使用して MySQL テーブルを作成するにはどうすればよいですか? PHP を使用して MySQL テーブルを作成するにはどうすればよいですか? Jun 04, 2024 pm 01:57 PM

PHP を使用して MySQL テーブルを作成するには、次の手順が必要です。 データベースに接続します。データベースが存在しない場合は作成します。データベースを選択します。テーブルを作成します。クエリを実行します。接続を閉じます。

間違った仮想通貨チェーンを取り戻すには?間違った仮想通貨送金チェーンを取得するためのチュートリアル 間違った仮想通貨チェーンを取り戻すには?間違った仮想通貨送金チェーンを取得するためのチュートリアル Jul 16, 2024 pm 09:02 PM

仮想市場の拡大は仮想通貨の流通と不可分であり、当然仮想通貨の送金問題とも不可分である。一般的な転送エラーはアドレス コピー エラーで、もう 1 つのエラーはチェーン選択エラーです。仮想通貨を間違ったチェーンに転送することは依然として厄介な問題ですが、初心者は転送操作の経験が浅いため、間違ったチェーンを転送してしまうことがよくあります。間違ったリンクはサードパーティのプラットフォームを通じて取得できますが、成功しない可能性があります。次に、編集者が仮想資産をより適切に管理するために役立つ詳細を説明します。間違った仮想通貨チェーンを取り戻すには?間違ったチェーンに転送された仮想通貨を取得するプロセスは複雑で困難な場合がありますが、転送詳細を確認し、取引所またはウォレットプロバイダーに連絡し、互換性のあるウォレットに秘密キーをインポートし、クロスチェーンブリッジツールを使用することで、

See all articles