Solved

MySQL Converting from latin1 to utf8

Posted on 2010-11-13
3
1,433 Views
Last Modified: 2012-05-10
I'm a little confused as to how to proceed. I have a number of tables that now need to be able to store their Text and VarChar fields as UTF8 so as to support the Japanese AND English character set.

I'm new to using MySQL Workbench but from what I can tell, my tables are stored with the latin1 collation and all of the Text and VarChar fields use their table's default collation.

I have been able to place Japanese characters into a field from a command line session (SSH in to the box and then ran mysql from the command prompt) using an update command:

Update Products Set ProductName = "This is ¿¿¿¿¿ test" Where ProductNo = 1011

When I issue a "Select ProductName From Products Where ProductNo = 1011", MySQL shows me the correct characters. My Putty session is using utf8 and seems to display Japanese characters with ease.

The problem is that if I look at the data using Workbench, the Japanese characters are replaced with accented European characters. I suspect that this is because the default collation is latin1 and Putty or MySQL is translating things so they seem to work.

Q: Can I use the Alter Table command (or the Workbench Alter table dialog) to change the collation on each table to "utf8 - default collation" resulting in the current English text remaining intact (since it is compatible with the first 256 characters of utf8) and then I'll be able to populate and retrieve data from now on in utf8 without having any weird conversion issues?





I'm using MySQL 5.0.77 and MySql Workbench with an SSH connection for DB admin.
0
Comment
Question by:ou81aswell
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
3 Comments
 
LVL 78

Accepted Solution

by:
arnold earned 500 total points
ID: 34129524
http://dev.mysql.com/doc/refman/5.1/en/alter-table.html

alter table tablename convert to character set UTF8 collation=utf8

You may need to run the same thing on the database level
alter database
http://dev.mysql.com/doc/refman/5.0/en/alter-database.html
0
 

Author Comment

by:ou81aswell
ID: 34129567
Thanks.

Can you confirm that going from latin1 to utf8 will not result in any weird character conversions. All of the data in there right now is 7-bit ascii with no control characters (I guess the Text fields have have line separators)?

I want to do this with MySql Workbench but am a bit confused because it only gives me the option to set the collation. There is no option to set the character set although in the description is makes it sound like collation is the same thing as character set. I have attached a screen shot.

I'm also confused as to which utf8 to choose. As you can see in the screen shot, there is utf8 default, general, bin, unicode followed by a bunch of language/country options. I was hoping to not have to be specific since I want to be able to use other languages as well in the future.

 MySQL Workbench Alter Table Dialog
0
 
LVL 78

Expert Comment

by:arnold
ID: 34129933
I have to look at workbench to see which option you should use:
http://dev.mysql.com/doc/refman/5.0/en/charset-charsets.html describes the character sets/collation options.

You may want to first copy the current database into a new one and then try your changes on the test database to make sure the change does not have an adverse impact.
0

Featured Post

Enroll in May's Course of the Month

May’s Course of the Month is now available! Experts Exchange’s Premium Members and Team Accounts have access to a complimentary course each month as part of their membership—an extra way to increase training and boost professional development.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
How do uses indexes to maximize MySQL Searches 14 78
Unwanted output from my query 5 52
Undefined variable with $_POST in PHP 5 38
MySQL_Development_Traininng.. 10 15
Introduction In this article, I will by showing a nice little trick for MySQL similar to that of my previous EE Article for SQLite (http://www.sqlite.org/), A SQLite Tidbit: Quick Numbers Table Generation (http://www.experts-exchange.com/A_3570.htm…
I use MySQL for many of my development projects in a Windows environment. To manage my databases (and perform queries) for years I used a tool called MySQL administrator.  This tool has since been replaced by MySQL Workbench. So I decided to m…

734 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question