由于在开发中不小心删除客户上传的商品数据,客户本身也不好说话,只好恢复数据库,记录下过程。
原理是数据库开启bin-log功能,然后再通过备份的bin-log进行数据库恢复。
先查找备份的数据库日志二进制文件。一般在mysql的data文件夹中,文件名大概为mysql-bin.00001,具体看文件的修改时间来确定哪个是最新的。
./mysqlbinlog --no-defaults --stop-datetime="2017-09-29 8:30:00" --database="haoge" /data/mysql/mysql-bin.00001 > back.log 前面的意思是执行mysqlbinlog工具,no-defaults解决编码问题, database是从数据库日志中提取的数据库名称,我丢失的haoge数据库的数据 , stop-datetime是你确定数据正常的时间,在这之前的数据正常就行. 输出的文件保存到当前目录下back.log
我没敢在服务器测试,下面开始的命令是在本地使用的。mysql命令行登陆,执行source back.log; 不需要提前创建haoge这个数据库。登陆后直接执行即可。
恢复完成
Left join:即左连接,是以左表为基础,根据ON后给出的两表的条件将两表连接起来。结果会将左表所有的查询信息列出,而右表只列出ON后条件与左表满足的部分。左连接全称为左外连接,是外连接的一种。Right join:即右连接,是以右表为基础,根据ON后给出的两表的条件将两表连接起来。结果会将右表...
1.查看所有表,包括视图表,show tables;2.查看表结果,包括视图表,desc 表名3.查看建表过程,show create table 表名;4.查看建视图过程,show create view...
概述: 目前我们的表设计,最高级别的范式是6NF,对于PHP程序员而言,我们的表满足3NF即可(范式即规范)【一】1NF (1).所谓1NF,就是指标的属性具有原子性,即表的列不能再分割,不能分割意思是字段本身的含义(例如address字段不能再分割)...
1.查看歌曲表结构(主要是给name字段添加全文索引)(mysql5.7才支持全中文索引)desc music; +---------+-------------+------+-----+---------+----------------+ | Fie...
在项目中发现大量的form连接表,就开始质疑inner join 和 form a,b的性能问题。找到一份有价值的资料,特别记录:ANSI SQL规范首选INNER JOIN语法。此外,尽管使用WHERE子句定义联结的确比较简单,但是使用明确的联结语法能够确保不会忘记联结条件,有时候这样做也能影响性...
项目中查询数据部分字段出现null,影响到了排序,但是由于没有数据库权限,还想将null转为其他值表示;例如现有表member的原始数据:SELECT * FROM memberid &n...