在实际开发中有时会遇到这样的情况,比如数据从设备采集器实时采集,导致每天有几十万或者几百万的数据,那么想要查询就会很慢,甚至有可能会导致数据库服务器崩溃,那么我们就需要备份数据库表,比如做一个定时任务,每天凌晨备份数据并生成新的数据库表,可是怎么备份数据呢,没有写过怎么办,那么下边就是解决的sql语句。
首先我们要重命名我们的数据库表,这条语句是将原表名为course重命名为course_copy,
-- 重命名——将course表命名为course_copy
ALTER TABLE course RENAME TO course_copy;
然后我们之前的表没有了,以后的数据怎么办,所以第二条sql是将重命名后的course_copy重新创建一个表结构相同的数据库表course,
-- 复制表结构创建新表——将course_copy表复制结构并创建名为course的新表
CREATE TABLE course LIKE course_copy;
这样就不会影响数据增删改查的问题了。
在项目中我们的sql在mapper中是这样写的
<!-- 备份旧表 -->
<update id="renameTableName">
ALTER TABLE data RENAME TO ${oldTableName};
</update>
<!-- 创建新表 -->
<update id="createNewTable">
CREATE TABLE data LIKE ${oldTableName}
</update>
那么剩下的就不写了,大家可尽情发挥