[原创]MySQL数据库查询和LVM备份还原学习笔记记录
一、查询语句类型:
1)简单查询
2)多表查询
3)子查询
4)联合查询
1)简单查询:
SELECT * FROM tb_name;
SELECT field1,field2 FROM tb_name;投影
SELECT [DISTINCT] * FROM tb_name WHERE qualification;选择
FROM子句:要查询的关系
表、多个表、其他select语句
WHERE子句:布尔关系表达式
AND,OR,NOT,BETWEEN...AND...,LIKE ''[%:任意长度任意字符;_:任意单个字符],RLIKE,IN,IS NULL,IS NOT NULL
ORDER BY field_name {ASC|DESC}
AS 字段别名
LIMIT [offset,]Count offset偏移量,Count取几个
聚合:
SUM(),MIN(),MAX(),AVG(),COUNT()
GROUP BY分组:
HAVING:过滤[qualification]
SELECT AVG(Age) FROM students GROUP BY Gender;
ELECT COUNT(CID1) AS Persons,CID1 FROM students GROUP BY CID1;
SELECT COUNT(CID1) AS Persons,CID1 FROM students GROUP BY CID1 HAVING Persons>=2;
SQL语句执行的顺序:
start->from->where->group by->having->order by->select fieldN->LIMIT->end
2)多表查询:
连接:
交叉连接:笛卡尔积
select * from students,courses;
自然连接:内连接,外链接:左外连接:... LEFT JOIN ... ON ...,右外连接:... RIGHT JOIN ... ON ...,自连接
select * from students,courses where students.cid1 = courses.cid;
select Name,Cname from students,courses where students.cid1 = courses.cid;
select s.Name,c.Cname from students AS s,courses AS c where s.cid1 = c.cid;
SELECT s.Name,c.Cname FROM students AS s LEFT JOIN courses AS c ON s.CID1=c.CID1;
SELECT s.Name,c.Cname FROM students AS s RIGHT JOIN courses AS c ON s.CID1=c.CID1;
3)子查询:
比较操作中使用子查询:子查询只能返回单个值
IN():使用子查询
在FROM中使用子查询
select name from students where Age > (select AVG(Age) from students);
select name from students where Age IN (select Age from tutors);
select Name,Age from (SELECT Name,Age FROM students) AS t where t.Age >= 20;
4)联合查询:
UNION:
(select Nmae,Age FROM students) UNION (select Tname,Age from tutors);
二、备份和还原
备份:
select * into OUTFILE '/path/beifen.txt' from tb_name [where clause];
恢复:
LOAD DATA INFILE '/path/beifen.txt' INTO TABLE tb_name;
LVM快照备份和还原:
前提:
1、数据文件要在逻辑卷上;
2、此逻辑卷所在卷组必须有足够空间使用快照卷;
3、数据文件和事务日志要在同一个逻辑卷上;
步骤:
1、打开会话,施加读锁,锁定所有表:
mysql> FLUSH TABLES WITH READ LOCK;
mysql> FLUSH LOGS;
2、通过另一个终端,保存二进制日志文件及相关位置信息:
$mysql -uroot -p -e "SHOW MASTER STATUS\G" > /path/master.info
3、创建快照卷:
#lvcreate -L [size] -s -p r -n LV_NAME /path/source_lv
4、释放锁:
mysql> UNLOCK TABLES;
5、挂载快照卷,备份:
#mount LV_NAME /mnt -o ro
#cp -a ./* /backup/
#rm -f /backup/mysql-bin.*
6、删除快照卷:
#lvremove --force LV_NAME
7、增量备份二进制日志[从master.info文件的位置开始备份,如果还有其他滚动的二进制文件单独备份即可]:
#mysqlbinlog --start-post=107 mysql-bin.000003 mysql-bin.000004> /backup/incremental.sql
8、还原数据:
#cp -a /bakcup/* /mysql/data/
#service mysqld start
mysql> set sql_log_bin=0;
mysql> source /backup/incremental.sql;
mysql> set sql_log_bin=1;
mysql> SHOW MASTER STATUS\G;
扩展:
MySQL创建表的三种方式:
1)直接手动创建:
mysql> create table tb_name(feild1-N);
2)基于其他表创建新表,这种方式创建的表不会把原表的主键,约束,触发器等复制过来,需要手动在追加。
mysql> create table test_new as select * from test where 1=2; //where 1=2只有表结构没有数据,where 1=1包括表结构和表数据一起复制了
3)基于原表创建的新表,这种方式使用like关键字会将原表的结构都复制过来,包括主键,约束,触发器等。
mysql> create table test like tb_name;
[原创]MySQL数据库查询和LVM备份还原学习笔记记录的更多相关文章
- MySQL数据库应用 从入门到精通 学习笔记
以下内容是学习<MySQL数据库应用 从入门到精通>过程中总结的一些内容提要,供以后自己复现使用. 一:数据库查看所有数据库: SHOW DATABASES创建数据库: CREATE DA ...
- MySQL/MariaDB数据库的mysqldump工具备份还原实战
MySQL/MariaDB数据库的mysqldump工具备份还原实战 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.mysqldump概述 1>.逻辑备份工具 mysq ...
- SqlServer批量压缩数据库日志-多数据库批量作业,批量备份还原
原文:SqlServer批量压缩数据库日志-多数据库批量作业,批量备份还原 --作业定时压缩脚本 多库批量操作 DECLARE @DatabaseName NVARCHAR(50) DECLARE @ ...
- mysql数据库查询pdo的用法
最早的php对mysql数据库查询是mysql和mysqli方法,后来php的新版本进一步封住了该方法,于是又pdo,抛开php框架,使用pdo查询数据,使用也是相当简便 <?php ini_s ...
- 提高MySQL数据库查询效率的几个技巧(转载)
[size=5][color=Red]提高MySQL数据库查询效率的几个技巧(转)[/color][/size] MySQL由于它本身的小巧和操作的高效, 在数据库应用中越来越多的被采用.我 ...
- centos6.5环境通过shell脚本备份php的web及mysql数据库并做远程备份容灾
centos6.5环境通过shell脚本备份php的web及mysql数据库并做远程备份容灾 系统:centos6.5 1.创建脚本目录 mkdir -p /usr/local/sh/ 创建备份web ...
- 将从mysql数据库查询的信息,遍历到List<>以及一些随机数的生成
将从mysql数据库查询的信息,遍历到List<>以及一些随机数的生成. 代码比较乱,但是方法还是对的,大家又需要的选择看,希望对博友 有帮助,欢迎留言分享! public class s ...
- MySQL 数据库查询数据,过滤重复数据保留一条数据---(MySQL中的row_number变相实现方法)
转自: http://www.maomao365.com/?p=10564 摘要: 下文讲述MySQL数据库查询重复数据时,只保留一条数据的方法 实现思路: 在MySQL数据库中没有row_numbe ...
- Mysql多实例安装+主从复制+读写分离 -学习笔记
Mysql多实例安装+主从复制+读写分离 -学习笔记 .embody{ padding:10px 10px 10px; margin:0 -20px; border-bottom:solid 1px ...
随机推荐
- 传入字典的模型项的类型为“System.Boolean”,但此字典需要类型“InternalCRM.EntityIACrm.Template”的模型项。
“/”应用程序中的服务器错误. 传入字典的模型项的类型为“System.Boolean”,但此字典需要类型“InternalCRM.EntityIACrm.Template”的模型项. 说明: 执行当 ...
- Android卡片设置透明度失效问题
最近在做蓝牙电话项目,需要支持双路通话,涉及到通话卡片透明度调节,当正在通话中,有新的来电时,原来的通话卡片需要做成30%的透明度,本来很简单的一个小改进,但通过 setAlpha()接口总是失效! ...
- OpenSSL包括了8个功能
什么是OpenSSL 众多的密码算法.公钥基础设施标准以及SSL协议,或许这些有趣的功能会让你产生实现所有这些 算法和标准的想法.果真如此,在对你表示敬佩的同时,还是忍不住提醒你:这是一个令人望而生畏 ...
- oh my god,写20万数据到Excel只需9秒
还是菜鸟时,在某个.Net项目中,用户需要从业务系统导出Report,而数据量通常都在上万条以上,最初采用的方式就是在服务器端用NPOI生成Excel,把Data一行一行一个Cell一个Cell地写到 ...
- Hadoop集群(第2期)虚拟机网卡的介绍和配置
很多人安装虚拟机的时候,经常遇到不能上网的问题,而vmware有三种网络模式,对初学者来说也比较眼花聊乱,今天我就来基于虚拟机3种网络模式,帮大家普及下虚拟机上网的背景知识 虚拟机网络模式 无论是vm ...
- WebApp 安全风险与防护课堂(第二讲)开课了!
本文由葡萄城技术团队于原创并首发 转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具.解决方案和服务,赋能开发者. 在昨天的公开课中,由于参与的小伙伴们积极性和热情非常高,我们的讲师Carl ...
- Keepalived双主模式配置流程
实验说明 1)keepalived 支持配置多个VRRP实例,每个实例对应一个业务 2)本次实验将实现 keepalived 的互为主备: 业务A:keepalived01为Master,keepal ...
- 节能减排到底如何----google earth engine 告诉你!!
(First,再次严谨说明,本人成果未经允许,切勿发表到相关学术期刊,如果有技术交流,qq1044625113,顺便打个广告,兼职GEE开发,欢迎联系!) 终于过了严寒的冬天,2017年的冬天中国南方 ...
- PATB 1004 成绩排名 (20)
1004. 成绩排名 (20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 读入n名学生的姓名.学号.成绩,分 ...
- RT-Thread的CPU占用率查看
今天看到朋友的博客,他在描述RT-Thread钩子函数时,简单提了下RT-Thread中CPU占用,没有具体描述,所以我在这里做下补充. RT-Thread查看CPU使用率时,我知道的有这种方法. 大 ...