zoukankan      html  css  js  c++  java
  • Mysql优化(2) 字符集设置以及分区

     

     

    设置编码:
    查看字符集的设置

    [SQL] 纯文本查看 复制代码
    001
    show variables like 'character_set_%';


    打开/etc/mysql/my.cnf在[mysqld]后添加:

    [Plain Text] 纯文本查看 复制代码
    001
    002
    character-set-server=utf8
    init_connect='SET NAMES utf8'

    在[client]后添加

    [SQL] 纯文本查看 复制代码
    001
    default-character-set=utf8

    修改表级

    [SQL] 纯文本查看 复制代码
    001
    ALTER TABLE table_name DEFAULT CHARSET utf8;

    更改了后永久生效
    注:如果没有找到my.cnf文件,可以用以下命令进行查找:

    [Shell] 纯文本查看 复制代码
    001
    find / -name "my.cnf" -print



    还有一种修改字符集的方法,就是使用mysql的命令

    [Plain Text] 纯文本查看 复制代码
    001
    002
    003
    004
    005
    006
    007
    008
    SET character_set_client = utf8 ;
    SET character_set_connection = utf8 ;
    SET character_set_database = utf8 ;
    SET character_set_results = utf8 ;
    SET character_set_server = utf8 ;
    SET collation_connection = utf8 ;
    SET collation_database = utf8 ;
    SET collation_server = utf8 ;



    然后我们登陆mysql查看是否支持分区:

    [SQL] 纯文本查看 复制代码
    001
    show plugins;


    结果如下图所示。
    <ignore_js_op> 
    必须要有箭头所示的插件。

    然后创建一个test数据库。

    [SQL] 纯文本查看 复制代码
    001
    002
    003
    create database test;
    use test;
    select database();

    然后我们创建一个表:

    [SQL] 纯文本查看 复制代码
    001
    002
    003
    004
    005
    006
    007
    008
    009
    010
    011
    mysql> create table t1(id int);
    Query OK, 0 rows affected (0.02 sec)
     
    mysql> show create table t1;
    +-------+----------------------------------------------------------------------------------------+
    | Table | Create Table                                                                           |
    +-------+----------------------------------------------------------------------------------------+
    | t1    | CREATE TABLE `t1` (
      `id` int(11) DEFAULT NULL
    ) ENGINE=MyISAM DEFAULT CHARSET=latin1 |
    +-------+----------------------------------------------------------------------------------------+


    然后我用下面的命令更改了字符集:

    [SQL] 纯文本查看 复制代码
    001
    002
    003
    004
    005
    006
    007
    008
    009
    010
    011
    012
    013
    mysql> ALTER TABLE t1 DEFAULT CHARSET utf8;
    Query OK, 0 rows affected (0.01 sec)
    Records: 0  Duplicates: 0  Warnings: 0
     
    mysql> show create table t1;
    +-------+--------------------------------------------------------------------------------------+
    | Table | Create Table                                                                         |
    +-------+--------------------------------------------------------------------------------------+
    | t1    | CREATE TABLE `t1` (
      `id` int(11) DEFAULT NULL
    ) ENGINE=MyISAM DEFAULT CHARSET=utf8 |
    +-------+--------------------------------------------------------------------------------------+
    1 row in set (0.00 sec)

    然后我们再创建张t2表:

    [SQL] 纯文本查看 复制代码
    001
    002
    003
    004
    mysql> create table t2(
        -> id int)
        -> partition by hash(id)
        -> partitions 5;

    然后我们执行如下shell命令:

    [Shell] 纯文本查看 复制代码
    001
    002
    [root@localhost mysql]# cd /var/lib/mysql/test
    [root@localhost test]# ll


    进入后我们可以看到创建的t1和t2表。
    <ignore_js_op> 

    关于本文章视频见:http://v.youku.com/v_show/id_XNDE1MzgzNjky.html 有兴趣的可以去看看。

    http://www.sodu666.com/ZeTianJi/

    http://tieba.sodu666.com/p_5.html

     
  • 相关阅读:
    图的广度优先遍历,运用了数据结构,感觉非常好用,等会把深度优先遍历也用数据结构写一遍
    DFS之素数环问题
    图的深度优先遍历
    八皇后的详细解答,纯手打,求推荐!!!
    c++中priority_queue的用法
    c++中vector的用法
    #ifndef是什么意思????
    筛法求1000000以内素数个数---时间复杂度为o(n)
    C++中1/0和1/0.0的区别
    C++程序生成.exe文件,在文件夹中运行时闪现问题
  • 原文地址:https://www.cnblogs.com/onesea/p/15031390.html
Copyright © 2011-2022 走看看