mysqlbinlog 查看binlog日志时报错unknown variable ‘default-character-set=utf8‘ 在通过全备文件和增量binlog文件来导出sql文件,用以恢复完整的数据库时。由于裸的binlog文件是无法直视的,所以使用mysqlbinlog这个工具是用来查看binlog文件内容的(使用方式man mysqlbinlog查看),但是使用mysqlbinlog将binlog文件转换成人类可读的内容时却报错:[root@server data]$ mysqlbinlog mysql-bin.000009
mysqlbinlog: ...
最近接手一个手机端服务端的程序(JAVA实现),我这边测试的话前台直接用的get方式传数据,get请求编码方式和post请求提交编码方式不同,get是把数据直接放到url中,例如以上的uname,IE浏览器先对中文进行utf-8编码(一个中文3个字符表示 太长),继而为了缩短字符又用ISO8859-1编码后传递给服务器。服务器的doGet方法中要先进行ISO8859-1解码再utf-8解码才能看到中文。post请求则在浏览器端把数据以utf-8的形式存储到http的请求体中...
Q: How do I see what the character set that a MySQL database, table and column
are in? Is there something like SHOW CHARACTER SETFOR mydatabase; and SHOW CHARACTER SETFOR mydatabase.mytable; and SHOW CHARACTER SETFOR mydatabase.mytable.mycolumn;A:How do I see what the character set that a MySQL database, table and column
are in? Is there something likeSHOW CHARACTER SETFOR mydatabase;andSHOW CHA...
在通过全备文件和增量binlog文件来导出sql文件,用以恢复完整的数据库时。由于裸的binlog文件是无法直视的,所以使用mysqlbinlog这个工具是用来查看binlog文件内容的(使用方式man mysqlbinlog查看),但是使用mysqlbinlog将binlog文件转换成人类可读的内容时却报错:[root@server data]$ mysqlbinlog mysql-bin.000009
mysqlbinlog: unknown variable ‘default-character-set=utf8‘ 原因是mysqlbinlog这个工具无法识别bin...
mysql链接建立之后,通过如下方式设置编码: 代码如下:mysql_query("SET character_set_connection=" . $GLOBALS[charset] . ",character_set_results=" . $GLOBALS[charset] . ",character_set_client=binary", $this->link); 然而建立出来的表结构描述竟然是乱码: 代码如下:mysql> show create table nw_admin_config\G *************************** 1. row *************************** Table: nw_admin_config Create Tabl...
因为character_set_server为latin1,插入数据库的中文是乱码,如何修改编码呢 回复讨论(解决方案) set names gbk; 后再执行插入 你这个好像在my.ini里面添加一个字符编码就可以了吧,为什么要在dos里面修改呢 你这个好像在my.ini里面添加一个字符编码就可以了吧,为什么要在dos里面修改呢 我在my.ini的client和mysqld下加default-character-set=utf8 ,用的wamp,添加过后wanp就启动不了了 set na...
dos下如何修改mysql数据库的character_set_server编码因为character_set_server为latin1,插入数据库的中文是乱码,如何修改编码呢分享到:------解决方案--------------------set names gbk; 后再执行插入------解决方案--------------------帮顶一下------解决方案--------------------你这个好像在my.ini里面添加一个字符编码就可以了吧,为什么要在dos里面修改呢
mysql链接建立之后,通过如下方式设置编码: 代码如下:mysql_query("SET character_set_connection=" . $GLOBALS[charset] . ",character_set_results=" . $GLOBALS[charset] . ",character_set_client=binary", $this->link); 然而建立出来的表结构描述竟然是乱码: 代码如下:mysql> show create table nw_admin_config\G *************************** 1. row *************************** Table: nw_admin_config Create Tabl...
mysql链接建立之后,通过如下方式设置编码: 代码如下:mysql_query("SET character_set_connection=" . $GLOBALS[charset] . ",character_set_results=" . $GLOBALS[charset] . ",character_set_client=binary", $this->link); 然而建立出来的表结构描述竟然是乱码: 代码如下:mysql> show create table nw_admin_config\G *************************** 1. row *************************** Table: nw_admin_config Create Tabl...
mysql链接建立之后,通过如下方式设置编码: 代码如下:mysql_query("SET character_set_connection=" . $GLOBALS[charset] . ",character_set_results=" . $GLOBALS[charset] . ",character_set_client=binary", $this->link); 然而建立出来的表结构描述竟然是乱码: 代码如下:mysql> show create table nw_admin_config\G *************************** 1. row *************************** Table: nw_admin_config Create Tabl...
[root@rac3 ~]# more /etc/my.cnf
[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
user=mysql
old_passwords=1
character-set-server = utf8
关闭数据库服务,并重新启动!
[root@rac3 ~]# mysqladmin shutdown
[root@rac3 ~]# mysqld_safe &
[1] 15102
[root@rac3 ~]# Starting mysqld daemon with databases from /var/lib/mysql
[root@rac3 ~]# mysql
Welcome to the MySQL monitor. Commands end wit...
[root@localhost app]# mysql -uroot -p
2 mysql: unknown variable ‘character-set-client=utf8‘查了下my.cnf的配置文件,是在client段下面配置了这么一个选项,按道理来说,是不会有问题的呀,然后上网google了下,发现:
了解到这个是mysqlbinlog的一个bug。 既然client选项组里允许通过character_set_client选项设置客户端编码,为何自带的工具mysqlbinlog却不认识这个选项?
在这里即使不认识,那也用不着直接出错而退出运行...
原因:
[client]下的选项会被所有客户端程序读取(但不包括mysqld),但是mysqlbinlog却不能识别default-character-set,而当客户端不能识别时就会报错并退出,不在继续执行。可以使用loose-variable_name=xxx来解决。
三种解决方法:
1. 修改my.cnf,在[client]下注释或删除default-character-set=gbk;
2. 在命令行中加入--no-defaults开关,使用mysqlbinlog --no-defaults;
3. 将default-character-set=gbk改为(不需重启):
[c...
html_encode(str)
{ var s = ""; if (str.length == 0) return ""; s = str.replace(/&/g, "&"); s = s.replace(/</g, "<"); s = s.replace(/>/g, ">"); //s = s.replace(/ /g, " "); s = s.replace(/\‘/g, ""); s = s.replace(/\"/g, """); //s = s.replace(/\n/g, "<br>"); return s;
} function html_decode(str)
{ var s = ""; if (str.length == 0) return ""; s = str.repla...
第一种:初始化文件(my.cnf)中设置参数
mysql数据库默认的字符集是latin。所以需要在my.cnf中设置下。比如:
[root@dbadb1 test]# more /etc/my.cnf
[mysqld]
default-character-set=utf8
然后连接进mysql,查看:
mysql> status
Server characterset: utf8Db characterset: utf8Client characterset: latin1Conn. characterset: latin1第二种:设置客户端的字符集
在连接mysql的时候,需要加上个参数,比如:
[ro...