use DBI;
my $dbh = DBI->connect("dbi:mysql:test:localhost:3306", "root", "123456",
{RaiseError => 1,
mysql_enable_utf8 => 1,
mysql_auto_reconnect => 1} );
$pstmt = $dbh->prepare("show variables like '%character_set%'");
$pstmt->execute();
while(my $row = $pstmt->fetchrow_arrayref){
printf "%s,%s\n",$row->[0],$row->[1];
}
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,E:\MySQL\share\charsets\
你看看你当前字符集的环境变量是什么。
在 2010年7月7日 上午11:49,azure wang
<azure1st@gmail.com>写道:
Illegal mix of collations (latin1_swedish_ci,IMPLICIT) and (utf8_general_ci,COERCIBLE) for operation '=' 是等号两边的字符集不一样 显然等号左边就是字段的字符集是latin1_swedish_ci, 而有变输入的字符串是utf8_general_ci 问题应该在你的表。
你把整个表结构导出SQL 然后发出来看看。
--
Azure.Wang
--
Azure.Wang
--
您收到此邮件是因为您订阅了 Google 网上论坛的“PerlChina Mongers 讨论组”论坛。
要向此网上论坛发帖,请发送电子邮件至 perlchina@googlegroups.com。
要取消订阅此网上论坛,请发送电子邮件至 perlchina+unsubscribe@googlegroups.com。
若有更多问题,请通过 http://groups.google.com/group/perlchina?hl=zh-CN 访问此网上论坛。