mysqldump 在 StoneDB 中的使用注意事项

此场景是利用mysqldump从InnoDB导出,然后再导入StoneDB,在导入StoneDB前,需要对导出文件做如下修改。
1)修改存储引擎

CREATE TABLE t_user (
xxx
) ENGINE=InnoDB;
CREATE TABLE t_user (
xxx
) ENGINE=stonedb;

2)去掉锁表语句

导出文件会输出”LOCK TABLES…WRITE”,这是因为导出时默认使用了参数”–add-locks”,由于StoneDB没有锁表语句,需要将导出文件的锁表语句去掉。

LOCK TABLES t_user WRITE;
UNLOCK TABLES;

3)去掉USING BTREE

StoneDB的索引结构是LMSTREE,InnoDB的索引结构是BTREE,如果是从其他客户端导出的文本,建表语句中如果有索引字段,通常会含有”USING BTREE”,导入StoneDB需要去掉。

4)去掉索引

在StoneDB中是不需要创建索引的,如果一个表有很多个索引,反而需要额外维护,可以将导出文件中的索引定义去掉。

此场景是利用mysqldump从StoneDB导出,然后再导入StoneDB,在使用mysqldump时,需要注意如下几个事项。

1)使用mysqldump导出时会有如下报错,这是因为导出参数”–lock-all-tables”是默认的,表示导出期间锁表。但由于StoneDB没有锁表语句,可以使用参数”–single-transaction”规避。

Got error: 1031: Table storage engine for 'STONEDB' doesn't have this option when doing LOCK TABLES

2)导入数据时会有如下报错,这是因为导出参数”–add-locks”是默认的,会在导出文件输出”LOCK TABLES…WRITE”,导出时可以使用参数”–skip-add-locks”规避。

注:使用Percona的物理备份工具xtrabackup备份StoneDB时,有如下提示,说明xtrabackup不支持StoneDB备份。

innobackupex --defaults-file=/stonedb/install/stonedb.cnf --user=root --password=MySQL_123 --socket=/stonedb/install/tmp/mysql.sock --databases=ztpch.customer --no-timestamp /backup

Warning: "ztpch.customer" uses engine "STONEDB" and will not be backed up.

Original: https://www.cnblogs.com/yangwilly/p/16600940.html
Author: 来来士
Title: mysqldump 在 StoneDB 中的使用注意事项

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/504984/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • Ansible Playbook概览

    Ansible playbook 执行需要三步路执行: 1.编写playbook 2.定义主机清单文件 3.设置运行环境,写入配置文件 1.编写playbook Playbook使…

    数据库 2023年6月14日
    075
  • Fork/Join框架

    我们要使用ForkJoin框架,必须首先创建一个ForkJoin任务。它提供在任务中执行 fork()和 join() 操作的机制,通常情况下我们不需要直接继承ForkJoinTa…

    数据库 2023年6月14日
    081
  • Python:如何只用十几行代码写一个程序?

    Python可以做的事情真的太多了,常见的网站开发,软件开发,爬虫,数据分析,人工智能,机器学习,量化投资,自动化办公,自动化运维,游戏开发,脚本制作,树莓派等等等等~ 今天咱们就…

    数据库 2023年6月14日
    083
  • Mysql的知识梳理

    数据准备: –建表 create table customer_jia(CID int(4), Cname varchar(20), Csex varchar(2), …

    数据库 2023年6月16日
    083
  • Redis——数据操作

    2022-09-20 Redis——select Redis数据库中的数据库的个数为: 16个,使用0号数据库开始的,到第15个数据库结束。 在ubantu中,进入Redis客户端…

    数据库 2023年6月14日
    069
  • mysql拆分字符串做条件查询

    mysql拆分字符串作为查询条件 有个群友问一个问题 这表的ancestors列存放的是所有的祖先节点,以 ,分隔 例如我查询dept_id为103的所有祖先节点,现在我只有一个d…

    数据库 2023年5月24日
    077
  • 一文读懂Redis

    Redis与NoSQL概述 Nosql的优势 使用nosql解决cpu与内存压力 使用nosql解决I/O压力 Nosql数据库的概述 NoSql= Not Only SQL 采用…

    数据库 2023年6月6日
    0106
  • CentOS7源码安装MySQL

    CentOS7源码安装MySQL 1:安装依赖包 执行:yum -y install ncurses-devel gcc- bzip2- bison 2:升级cmake工具(我用的…

    数据库 2023年6月6日
    081
  • js异步编程终级解决方案 async/await

    在最新的ES7(ES2017)中提出的前端异步特性:async、await。 async、await是什么 async顾名思义是”异步”的意思,async用…

    数据库 2023年6月9日
    086
  • sql_mode详解,bug修复!!!!!

    处理MySQL数据库工作中遇到关于sql_mode的情况,特学习记录一下 废话不多说直接上错误提示,哈哈哈 bug开始!!!! INSERT INTO mmb_user (open…

    数据库 2023年5月24日
    079
  • 人如蝼蚁,跌倒再起。

    本文来自博客园,作者:ukyo–BlackJesus,转载请注明原文链接:https://www.cnblogs.com/ukzq/p/16750141.html Or…

    数据库 2023年6月11日
    097
  • mysql数据类型与表操作

    一、mysql基本认知 创建用户 create host aa identified with mysql_native_password by ”; 修改用户权限 a…

    数据库 2023年5月24日
    091
  • 接口和抽象类有什么区别

    1.抽象类和接口都不能直接实例化,如果要实例化,抽象类变量必须指向实现所有抽象方法的子类对象,接口变量必须指向实现所有接口方法的类对象 2.抽象类要被子类继承,接口要被类实现 3….

    数据库 2023年6月6日
    069
  • linux系统安装MySQL数据库安装保姆级教程及1045错误和2058问题解决

    使用Mysql的zip压缩包解压版,下载之后需进行一定的配置,才能使用它。下面对Mysql压缩包版的安装方法进行详细的描述,如有疑问或错误,望及时反馈。 首先,mysql的官方下载…

    数据库 2023年6月11日
    095
  • Java面向对象(下)作业

    首先我把题目先列到这里,可以仔细看一下题。 (1)设计一个名为Geometric的几何图形的抽象类,该类包括: ①两个名为color、filled属性分别表示图形颜色和是否填充。 …

    数据库 2023年6月11日
    0141
  • MySQL主从复制

    一、概述 主从复制是指将主数据库(Master)的DDL和DML操作通过二进制日志传到从库(Slave)服务器中,然后在从库上对这些日志重新执行(也叫重做),从而使得从库和主库的数…

    数据库 2023年5月24日
    0106
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球