MySQL总结02
sql优化
- Insert使用批量
- 查询不要使用*, MySQ需要先查出表里的所有字段,再进行匹配
- 字符串的查询条件要带引号,否则可能不走索引
备份及恢复
备份
mysqldump -uroot -ppasswd -B dbname > filename.sql
note: -B备份指定库,使用-B备份文件中多了两行代码(create database dbname; use dbname;)
-A是备份所有的库指定字符集备份
mysqldump -uroot -ppasswd -B -default-character-set=utf8 dbname > mysql.bak.sql使用压缩命令备份
mysqldump -uroot -ppasswd --default-character-set=utf8 dbname|gzip > mysql.bak.sql.zip备份多个库
mysqldump -uroot -ppasswd -B dbname1 dbname2..|gzip > mysql.bak.sql.zip备份多个表
mysqldump -uroot -ppasswd dbname tablename1 tablename2.. > mysql.bak.sql恢复
mysqldump -uroot -ppasswd dbname < filename.sqlmysqldump关键参数
- -B 指定多个库,增加建库语句和use语句
- --compact去掉注释,适合调试输出,生产不用
- -A备份所有库
- -F刷新binlog日志
- --master-data 增加binlog日志文件及对应的位置点
- -x, --lock-all-tables
- -d 只备份表结构
- -t 只备份数据
mysqlbinlog
开启binlog
修改mysqld文件中的log-bin=日志文件名,binlog日志会根据自己的规则自动轮询
binlog只记录增删改的操作日志,不记录查询的操作日志,此日志通常用来恢复数据用使用binlog日志恢复数据
首先将binlog日志到处为sql文件
mysqlbinlog -d dbname binlogname > bin.sql
note: binlog文件只能用mysqlbinlog命令打开查看
-d: 只导出数据内容将sql文件导入数据库
mysql -uroot -ppasswd dbname < bin.sql
刷新切割日志
mysqladmin -uroot -ppasswd flush-log
命令使用范围
在mysql内部操作外部命令
system + 外部命令在mysql外部执行mysql内部命令
mysql -uroot -ppasswd -e "sql命令"
字符集乱码问题
mysql字符集乱码问题主要是因为系统字符集、客户端字符集、mysql字符集不统一造成的
客户端字符集修改
临时改变显示字符集:set names utf-8
永久:更改my.cng客户端模块的参数服务端字符集修改
更改my.cnf参数
[mysql]
default-character-set=utf8 适合5.1及之前版本
default-set-server=utf8 适合5.5版本
linux系统字符集修改
修改linux的字符集:vi /etc/sysconfig/i18n
是修改的文件生效:source /etc/sysconfig/i18n或者. /etc/sysconfig/i18n查看字符集
mysql -uroot -ppasswd -e "show variables like 'character_set%'
显示内容为:

修改已经中文乱码的数据库表
- 建库及建表语句到处,修改为utf8
- 到处所有的mysql数据
- 修改mysql服务端和客户端编码为utf8
- 删除原有的库表及数据
- 导入新的建库及建表语句
- 导入mysql所有数据
MySQL主从同步
文件同步
- NFS网络文件共享同步存储数据
- samba共享数据
- 定时任务或守护进程结合rsync, scp
- inotify(scrsync) + rsync触发式实时数据同步
- ftp数据同步
- ssh key + scp/rsync
mysql主从同步四种方案
- 主从方式,通过同步binlog最大限度保持数据一致,但也有风险
- 双写, 写的压力大
- 谷歌半同步插件,异步改为半同步
MySQL总结02的更多相关文章
- mysql笔记02 创建高性能的索引
创建高性能的索引 1. 索引(在MySQL中也叫做"键(key)")是存储引擎用于快速找到记录的一种数据结构. 2. 索引可以包含一个或多个列的值.如果索引包含多个列,那么列的顺序 ...
- MYSQL基础02(查询)
查询是很大的一块,所以这里我只会写mysql的特点,就我目前使用的情况,MYSQL对标准SQL是比较支持,如果是新手的话,建议去w3school 学习标准SQL. 1.DUAL DUAL是一个虚拟表, ...
- MySQL高级02
索引简介 索引(Index)是帮助MySQL高效获取数据的数据结构.可以得到索引的本质:索引是数据结构.你可以简单理解为“排好序的快速查找数据结构”. 在数据之外,数据库系统还维护着满足特定查找算法的 ...
- MySQL案例02:ERROR 1221 (HY000): Incorrect usage of DB GRANT and GLOBAL PRIVILEGES
MySQL在授权用户时出现报错信息,具体信息如下: 一.错误信息 执行命令: GRANT SELECT,INSERT, UPDATE, DELETE, CREATE, DROP, RELOAD, SH ...
- Angular4+NodeJs+MySQL 入门-02 MySql操作类
NodeJs操作MySQL类 此类封装了几个常用的方法:插入,更新,删除,查询,开启事务,事务提交,事务回滚等操作.有一这个类,操作MYSQL就方便多了. 批处理,存储过程等方法还没有添加,因为觉得目 ...
- MySQL训练营02
一.表操作: 1.MySQL表的数据类型: MySQL的数据类型分为3种: 数值 时间/日期 字符/字符串 (1)数值类型: 包括:TinyInt.SmallInt.MediumInt.Int.Big ...
- MySQL丨02丨忘记root用户密码怎么办?
软件:Mysql 版本:8.0.13 1. 先暂停mysql的服务,方法是在cmd里输入如下代码: net stop mysql 2. 在安装文件夹下创建一个文件:mysql-ini.txt (我的安 ...
- MySQL存储过程02
这次接着说MySQL存储过程: 我们先看它的多分支控制结构case: case的语句很简单: case 变量名 when 条件1 then 输出结果1; when 条件2 then 输出结果2; .. ...
- MySQL数据库02
MySQL数据库 前言: 前面我们了解了什么是数据库,什么是MySQL数据库以及如何运用,接下来我们接着深入学习MySQL. (提前声明,以下所提供的事例不标准,仅供参考) 数据库的备份与还原: 备份 ...
随机推荐
- with cats as pets get cataracts and macular degeneration
I really enjoyed this talk, optimistic and helpful. May I offer a small but perhaps helpful bit of k ...
- JavaScript 获取function的参数
function getArgs(func) { // 先用正则匹配,取得符合参数模式的字符串. // 第一个分组是这个: ([^)]*) 非右括号的任意字符 var args = func.toSt ...
- v-cloakd的应用场景和使用方法
使用vue构建前端应用,加载应用后页面可能会出现闪烁: <div id="app" v-cloak> {{message}} </div> 例如上述场景,应 ...
- 如何通过HTTP API 调取tushare的股票数据
长久以来,Tushare一直以固定的Python SDK方式为大家提供数据服务. 虽然在基于Python的数据分析和Python的量化策略开发很方便,但习惯用其他语言的同学们表示了“抗议”,于是在Tu ...
- 别人整理的dp题目
动态规划 动态规划 容易: 1018, 1050, 1083, 1088, 1125, 1143, 1157, 1163, 1178, 1179, 1189, 1208, 1276, 1322, 14 ...
- SqlServer 行转列 查询 并 导出 到 Excel 中 自动换行
SELECT A.Hawb, ( SELECT GoodsNameCn+char(10) FROM HawbBody hl WHERE hl.Hawb=A.Hawb FOR XML PATH('') ...
- C#获取文件夹/文件的大小以及占用空间 转摘自:http://www.cnblogs.com/chenpeng-dota/articles/2176470.html
C#获取文件夹/文件的大小以及占用空间 今天,头给了个任务:写个方法,我会给你个路径,计算这个路径所占用的磁盘空间 . 然后,找了很多资料.但大部分都是获取文件夹/文件的大小的.对于占用空间的没有成品 ...
- 浏览器中的JavaScript事件循环机制
浏览器的事件循环机制是HTML中定义的规范. JavaScript有一个主线程和调用栈,所有的任务都会被放到调用栈等待主线程执行. JS调用栈 是一种先进后出的数据结构.当函数被调用时,会被添加到栈中 ...
- Shell02---变量
Shell02---变量 1. shell变量概述 1. 什么是变量 变量是Shell传递数据的一种方法,简单理解:用一个固定的字符串去表示不固定的内容,便于后续引用. 2.变量命令规范 变量定义时名 ...
- Welcome to MarkdownPad 2
Welcome to MarkdownPad 2 MarkdownPad is a full-featured Markdown editor for Windows. Built exclusive ...