MySQL数据库常用操作

服务器操作(cmd)


  1. 开启服务器(必须保证mysql为windows服务):net start mysql56(此处与系统进程中名字相同)

查看进程表中是否存在:mysqld.exe进程(存在)

  • 关闭服务器(必须保证mysql为windows服务):net stop mysql56
    查看进程表中是否存在:mysqld.exe进程(不存在)

  • 客户登操作
    cmd
    1. 登录服务器:mysql -uroot -p123 -hlocalhost//-hlocalhost可省略,他是默认的
    -u:后面跟随用户名
    -p:后面跟随密码
    -h:后面跟随IP
    2. 退出服务器:exit或quit

备份与恢复

  1. 数据库导出SQL脚本

    mysqldump –u用户名 –p密码 数据库名>生成的脚本文件路径
    例如:mysqldump -uroot -p123 mydb1>C:\mydb1.sql (与mysql.exe和mysqld.exe一样, 都在bin目录下)
    注意,不要打分号,不要登录mysql,直接在cmd下运行
    注意,生成的脚本文件中不包含create database语句

  2. 执行SQL脚本
    第一种方式

    mysql -u用户名 -p密码 数据库<脚本文件路径
    例如:

    • 先删除mydb1库,再重新创建mydb1库
    • mysql -uroot -p123 mydb1

MySQL存储blob数据包太大

com.mysql.jdbc.PacketTooBigException: Packet for query is too large (9802817 > 1048576). You can change this value on the server by setting the max_allowed_packet’ variable.

在my.ini中设置,在[mysqld]下添加max_allowed_packet=10M,例如:

[mysqld]
max_allowed_packet=64M

编码

  1. 查看MySQL数据库编码

    • SHOW VARIABLES LIKE ‘char%’;
  2. 编码解释

    • character_set_client:MySQL使用该编码来解读客户端发送过来的数据,例如该编码为UTF8,那么如果客户端发送过来的数据不是UTF8,那么就会出现乱码
    • character_set_results:MySQL会把数据转换成该编码后,再发送给客户端,例如该编码为UTF8,那么如果客户端不使用UTF8来解读,那么就会出现乱码
      其它编码只要支持中文即可,也就是说不能使用latin1
  3. 控制台乱码问题

    • 插入或修改时出现乱码:

    这时因为cmd下默认使用GBK,而character_set_client不是GBK的原因。我们只需让这两个编码相同即可。
    因为修改cmd的编码不方便,所以我们去设置character_set_client为GBK即可。

  4. 查询出的数据为乱码:
    这是因为character_set_results不是GBK,而cmd默认使用GBK的原因。我们只需让这两个编码相同即可。
    因为修改cmd的编码不方便,所以我们去设置character_set_results为GBK即可。
  5. 设置变量的语句:
    set character_set_client=gbk;
    set character_set_results=gbk;

  6. 注意,设置变量只对当前连接有效,当退出窗口后,再次登录mysql,还需要再次设置变量。
    为了一劳永逸,可以在my.ini中设置:
    设置default-character-set=gbk即可。
     
  7. 指定默认编码
    我们在安装MySQL时已经指定了默认编码为UTF8,所以我们在创建数据库、创建表时,都无需再次指定编码。
    为了一劳永逸,可以在my.ini中设置:
    设置character-set-server=utf8即可。

    character_set_client | utf8 –> mysql把我们客户端传递的数据都当成是utf8!一是给它传递utf8,二是如果我们传递的是gbk,那么需要修改这个变量为gbk
    character_set_connection | utf8
    character_set_database | utf8
    character_set_results | utf8 –> mysql发送给客户端的数据都是utf8的。一是客户端用utf8编码,二是如果客户端使用gbk来编码,那么需要修改这个变量为gbk的。
    character_set_server | utf8
    character_set_system | utf8

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值