Want to win a PS4? Go Premium and enter to win our High-Tech Treats giveaway. Enter to Win

x
?
Solved

MySQL Converting from latin1 to utf8

Posted on 2010-11-13
3
Medium Priority
?
1,452 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 80

Accepted Solution

by:
arnold earned 2000 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 80

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

Ask an Anonymous Question!

Don't feel intimidated by what you don't know. Ask your question anonymously. It's easy! Learn more and upgrade.

Question has a verified solution.

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

Introduction Since I wrote the original article about Handling Date and Time in PHP and MySQL several years ago, it seemed like now was a good time to update it for object-oriented PHP.  This article does that, replacing as much as possible the pr…
Does the idea of dealing with bits scare or confuse you? Does it seem like a waste of time in an age where we all have terabytes of storage? If so, you're missing out on one of the core tools in every professional programmer's toolbox. Learn how to …
In this video, Percona Solution Engineer Dimitri Vanoverbeke discusses why you want to use at least three nodes in a database cluster. To discuss how Percona Consulting can help with your design and architecture needs for your database and infras…
In this video, Percona Solution Engineer Rick Golba discuss how (and why) you implement high availability in a database environment. To discuss how Percona Consulting can help with your design and architecture needs for your database and infrastr…
Suggested Courses

610 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