MySQL服务端编码设置

安装完mysql,启动后发现服务器默认使用的是lat1编码。那么我们怎么去设置呢?下文详细的介绍了具体的操作和查看。

AD:51CTO 网+ 第十二期沙龙:大话数据之美_如何用数据驱动用户体验

安装完mysql,启动后发现服务器默认使用的是lat1编码。

具体操作和查看过程如下:

启动方式:/etc/init.d/mysql.server start

效果:

Database changed
mysql> status
--------------
mysql Ver 14.12 Distrib 5.0.77, for redhat-linux-gnu (x86_64) using readline 5.1

Connection id: 8
Current database: demodb
Current user: root@localhost
SSL: Not in use
Current pager: stdout
Using outfile: ''
Using delimiter: ;
Server version: 5.5.21 MySQL Community Server (GPL)
Protocol version: 10
Connection: Localhost via UNIX socket
Server characterset: latin1
Db characterset: utf8
Client characterset: latin1
Conn. characterset: latin1
UNIX socket: /var/lib/mysql/mysql.sock
Uptime: 33 sec

Threads: 7 Questions: 137 Slow queries: 0 Opens: 83 Flush tables: 1 Open tables: 76 Queries per second avg: 4.151
--------------

mysql>

启动方式: /etc/init.d/mysql.server start --character-set-server=utf8

效果:

mysql> use demodb;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> status;
--------------
mysql  Ver 14.12 Distrib 5.0.77, for redhat-linux-gnu (x86_64) using readline 5.1

Connection id:        4
Current database:    demodb
Current user:        root@localhost
SSL:            Not in use
Current pager:        stdout
Using outfile:        ''
Using delimiter:    ;
Server version:        5.5.21 MySQL Community Server (GPL)
Protocol version:    10
Connection:        Localhost via UNIX socket
Server characterset:    utf8
Db     characterset:    utf8
Client characterset:    latin1
Conn.  characterset:    latin1
UNIX socket:        /var/lib/mysql/mysql.sock
Uptime:            1 min 15 sec

Threads: 4  Questions: 131  Slow queries: 0  Opens: 84  Flush tables: 1  Open tables: 77  Queries per second avg: 1.746
--------------

mysql>

这种方式,在每次启动的时候都需要指定编码参数。否则服务器就使用的是系统默认的lat1编码。

另外一种方法是:

mysql>set character_set_server=utf8;

这种方法我也试了,不行,再重新登录客户端后,就又恢复了原来的编码。理由很简单,系统启动的时候用的不是utf8编码。

一劳永逸的办法,就是通过修改配置文件实现.

# vim /etc/my.cnf

内容如下:

[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
user=mysql

#添加下面的红字内容

character-set-server=utf8

# Default to using old password format for compatibility with mysql 3.x
# clients (those using the mysqlclient10 compatibility package).
old_passwords=1


[mysqld_safe]
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid

原文链接:http://www.blogjava.net/zhyiwww/archive/2012/03/01/371055.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要开发一个IM服务端的Demo,你需要考虑以下几个方面: 1.选择适合的编程语言和框架:目前常用的IM服务端编程语言主要有Java、C++和Python等,其中Java最为常用。Java开发IM服务端可以使用Netty、Mina、Spring Boot等框架。 2.实现IM协议:IM协议是IM服务端和客户端进行通信的基础,常用的IM协议有XMPP、WebSocket、MQTT等,你需要选择一个适合自己的协议,并在服务端实现这个协议。 3.实现消息存储:IM服务端需要将用户发送的消息存储到数据库中,以便用户登录后可以查看历史消息。你可以选择MySQL、MongoDB等数据库进行存储。 4.实现用户管理:IM服务端需要实现用户注册、登录、注销等功能,并对用户进行身份验证、权限控制等。 下面是一个使用Java和Netty实现IM服务端Demo的示例代码: ```java public class IMServer { public static void main(String[] args) { EventLoopGroup bossGroup = new NioEventLoopGroup(); EventLoopGroup workerGroup = new NioEventLoopGroup(); try { ServerBootstrap b = new ServerBootstrap(); b.group(bossGroup, workerGroup) .channel(NioServerSocketChannel.class) .childHandler(new ChannelInitializer<SocketChannel>() { @Override public void initChannel(SocketChannel ch) throws Exception { ChannelPipeline pipeline = ch.pipeline(); pipeline.addLast(new IMDecoder()); pipeline.addLast(new IMEncoder()); pipeline.addLast(new IMServerHandler()); } }) .option(ChannelOption.SO_BACKLOG, 128) .childOption(ChannelOption.SO_KEEPALIVE, true); ChannelFuture f = b.bind(8080).sync(); f.channel().closeFuture().sync(); } catch (InterruptedException e) { e.printStackTrace(); } finally { workerGroup.shutdownGracefully(); bossGroup.shutdownGracefully(); } } } public class IMDecoder extends ByteToMessageDecoder { @Override protected void decode(ChannelHandlerContext ctx, ByteBuf in, List<Object> out) { // 解码消息 } } public class IMEncoder extends MessageToByteEncoder { @Override protected void encode(ChannelHandlerContext ctx, Object msg, ByteBuf out) { // 编码消息 } } public class IMServerHandler extends ChannelInboundHandlerAdapter { @Override public void channelRead(ChannelHandlerContext ctx, Object msg) { // 处理消息 } } ``` 在这个示例代码中,我们使用Netty框架实现了一个IM服务端Demo,其中IMDecoder和IMEncoder实现了消息的解码和编码,IMServerHandler实现了消息的处理。你可以根据自己的需求修改这个代码,实现一个符合自己需求的IM服务端Demo。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值