溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

在MAC下配置mysql數(shù)據(jù)庫(kù)出現(xiàn)亂碼怎么解決

發(fā)布時(shí)間:2021-08-24 18:41:38 來(lái)源:億速云 閱讀:123 作者:chen 欄目:數(shù)據(jù)庫(kù)

本篇內(nèi)容主要講解“在MAC下配置mysql數(shù)據(jù)庫(kù)出現(xiàn)亂碼怎么解決”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“在MAC下配置mysql數(shù)據(jù)庫(kù)出現(xiàn)亂碼怎么解決”吧!

最近安裝了mac osx lion系統(tǒng),然后安裝了mysql5.5.16版本的進(jìn)行開(kāi)發(fā),但是大家都知道,的默認(rèn)編碼是latin1,如果存儲(chǔ)中文的話就會(huì)出現(xiàn)亂碼,然后就狂google這個(gè)問(wèn)題,但是一直都沒(méi)有解決,網(wǎng)上大部分的回答都是如下:

       1.拷貝/usr/local/mysql/support-files下的任意一個(gè)*.cnf文件到/etc/my.cnf;

       2.在my.cnf文件的[mysqld]和[client]后面添加一句default-character-set=utf8(或者是default_character_set=utf8);

       3.保存退出;

       4.重新啟動(dòng)mysql服務(wù)器就可以。

       可是我試過(guò)好多次,這樣修改之后,mysql服務(wù)根本就啟動(dòng)不了。

偶然的機(jī)會(huì),我發(fā)現(xiàn)了一個(gè)關(guān)于在linux下配置mysql的編碼問(wèn)題的方法,抱著試試看的態(tài)度,我進(jìn)行了修改,發(fā)現(xiàn)真的可以用,因此發(fā)這篇博文希望裝mac的朋友不用再走彎路了。配置方法如下:

       1.拷貝/usr/local/mysql/support-files下的任意一個(gè)*.cnf文件到/etc/my.cnf;

       2.在my.cnf文件的[client]后面添加一句default-character-set=utf8( 不是default_character_set=utf8[i][/i],這個(gè)配置我沒(méi)有試過(guò),不知道能不能成功),關(guān)鍵在這里的配置,在[mysqld]后面添加如下三句:

default-storage-engine=INNODB

character-set-server=utf8

collation-server=utf8_general_ci;

        3.保存退出;

        4.重新啟動(dòng)mysql服務(wù)器就可以。

然后再就入mysql數(shù)據(jù)庫(kù)查看編碼發(fā)現(xiàn)改成了utf8了。

下面是我重啟mysql服務(wù)器進(jìn)入mysql數(shù)據(jù)庫(kù)查出來(lái)的結(jié)果:

Java代碼 

Welcome to the MySQL monitor.  Commands end with ; or \g.  

Your MySQL connection id is 520 

Server version: 5.5.16 MySQL Community Server (GPL)  

Copyright (c) 2000, 2011,  and/or its affiliates. All rights reserved.  

Oracle is a registered trademark of Oracle Corporation and/or its  

affiliates. Other names may be trademarks of their respective  

owners.  

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.  

mysql> show variables like '%char%';  

+--------------------------+--------------------------------------------------------+  

| Variable_name            | Value                                                  |  

+--------------------------+--------------------------------------------------------+  

| character_set_client     | utf8                                                   |  

| character_set_connection | utf8                                                   |  

| character_set_database   | utf8                                                   |  

| character_set_filesystem | binary                                                 |  

| character_set_results    | utf8                                                   |  

| character_set_server     | utf8                                                   |  

| character_set_system     | utf8                                                   |  

| character_sets_dir       | /usr/local/mysql-5.5.16-osx10.6-x86_64/share/charsets/ |  

+--------------------------+--------------------------------------------------------+  

8 rows in set (0.00 sec) 

Welcome to the MySQL monitor.  Commands end with ; or \g.

Your MySQL connection id is 520

Server version: 5.5.16 MySQL Community Server (GPL)

Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its

affiliates. Other names may be trademarks of their respective

owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> show variables like '%char%';

+--------------------------+--------------------------------------------------------+

| Variable_name            | Value                                                  |

+--------------------------+--------------------------------------------------------+

| character_set_client     | utf8                                                   |

| character_set_connection | utf8                                                   |

| character_set_database   | utf8                                                   |

| character_set_filesystem | binary                                                 |

| character_set_results    | utf8                                                   |

| character_set_server     | utf8                                                   |

| character_set_system     | utf8                                                   |

| character_sets_dir       | /usr/local/mysql-5.5.16-osx10.6-x86_64/share/charsets/ |

+--------------------------+--------------------------------------------------------+

8 rows in set (0.00 sec)

       至此,這個(gè)困擾多日的問(wèn)題終于解決了。

       附修改好的my.cnf文件內(nèi)容,不知道為什么附件我上傳不了,就把代碼貼出來(lái)吧:

Java代碼 

# Example MySQL config file for small systems.  

#  

# This is for a system with little memory (<= 64M) where MySQL is only used  

# from time to time and it's important that the mysqld daemon  

# doesn't use much resources.  

#  

# MySQL programs look for option files in a set of  

# locations which depend on the deployment platform.  

# You can copy this option file to one of those  

# locations. For information about these locations, see:  

# http://dev.mysql.com/doc/mysql/en/option-files.html  

#  

# In this file, you can use all long options that a program supports.  

# If you want to know which options a program supports, run the program  

# with the "--help" option.  

# The following options will be passed to all MySQL clients  

[client]  

default-character-set=utf8  

#password   = your_password  

port        = 3306 

socket      = /tmp/mysql.sock  

# Here follows entries for some specific programs  

# The MySQL server   

[mysqld]  

default-storage-engine=INNODB  

character-set-server=utf8  

collation-server=utf8_general_ci  

port        = 3306 

socket      = /tmp/mysql.sock  

skip-external-locking  

key_buffer_size = 16K  

max_allowed_packet = 1M  

table_open_cache = 4 

sort_buffer_size = 64K  

read_buffer_size = 256K  

read_rnd_buffer_size = 256K  

net_buffer_length = 2K  

thread_stack = 128K  

# Don't listen on a TCP/IP port at all. This can be a security enhancement,  

# if all processes that need to connect to mysqld run on the same host.  

# All interaction with mysqld must be made via Unix sockets or named pipes.  

# Note that using this option without enabling named pipes on Windows  

# (using the "enable-named-pipe" option) will render mysqld useless!  

#   

#skip-networking  

server-id   = 1 

# Uncomment the following if you want to log updates  

#log-bin=mysql-bin  

# binary logging format - mixed recommended  

#binlog_format=mixed  

# Causes updates to non-transactional engines using statement format to be  

# written directly to binary log. Before using this option make sure that  

# there are no dependencies between transactional and non-transactional  

# tables such as in the statement INSERT INTO t_myisam SELECT * FROM  

# t_innodb; otherwise, slaves may diverge from the master.  

#binlog_direct_non_transactional_updates=TRUE  

# Uncomment the following if you are using InnoDB tables  

#innodb_data_home_dir = /usr/local/mysql/data  

#innodb_data_file_path = ibdata1:10M:autoextend  

#innodb_log_group_home_dir = /usr/local/mysql/data  

# You can set .._buffer_pool_size up to 50 - 80 %  

# of RAM but beware of setting memory usage too high  

#innodb_buffer_pool_size = 16M  

#innodb_additional_mem_pool_size = 2M  

# Set .._log_file_size to 25 % of buffer pool size  

#innodb_log_file_size = 5M  

#innodb_log_buffer_size = 8M  

#innodb_flush_log_at_trx_commit = 1 

#innodb_lock_wait_timeout = 50 

[mysqldump]  

quick  

max_allowed_packet = 16M  

[mysql]  

no-auto-rehash  

# Remove the next comment character if you are not familiar with SQL  

#safe-updates  

[myisamchk]  

key_buffer_size = 8M  

sort_buffer_size = 8M  

[mysqlhotcopy]  

interactive-timeout 

到此,相信大家對(duì)“在MAC下配置mysql數(shù)據(jù)庫(kù)出現(xiàn)亂碼怎么解決”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢(xún),關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI