从其他数据库迁移到MySQL

Oracle,SQL Server迁移到MySQL

一些变化

不再使用存储过程、视图、定时作业

表结构变更,如采用自增id做主键,以及其他语法变更

业务SQL改造,不使用窗口函数、CTE等功能

制定MySQL业务开发规范

数据迁移

MySQL Workbench、Navicat

OGG

ODBC/JDBC

dataX

otter + canal

全量一次复制 + 增量变化应用

数据校验

yugong (for Oracle)

理解MySQL特点

单进程,多线程

在超高并发情况下,对多核CPU的利用不足

不使用MySQL5.1以前版本,多核CPU利用差

MySQL新版本高并发可以很好利用多核CPU

每个连接只能用到一个逻辑CPU

每个Query/SQL只能用到一个逻辑CPU

使用/优化建议

使用新版本,抛弃旧版本

用高主频,多核CPU

不跑复杂SQL

事务及早结束

InnoDB buffer pool (简称IBP)是最大的内存单元

innodb_buffer_pool_free,innodb_buffer_pool_wait_free,innodb_buffer_pool_pages_dirty

MySQL5.7起可在线调整IBP

每个session(连接/会话)分配sort/join/read buffer/tmp table

使用/优化建议

IBP一般设置物理内存的50%~70%

加大物理内存,减少物理I/O,提高TPS

session级buffer按需分配,因此适当就好,无需过大

所谓的高速查询缓存反倒是影响并发性能的鸡肋,直接禁用

随着MyISAM逐步被抛弃,key buffer只需设置非常小

磁盘I/O是数据库应用场景最大的瓶颈

OLTP业务场景中,绝大多数是随机I/O读写

UNDO log以顺序写、随机读为主

REDO log、binlog、relay log以顺序写、顺序读为主

使用/优化建议

加大物理内存,减少物理I/O

采用高速磁盘设备

适当创建索引,减少随机读

不存图片、文件、长文本等大对象数据

不跑复杂SQL,表达式运算、函数运算等

不跑长事务

不跑全文检索

不支持bitmap索引

不支持hash join

MySQL8.0之前不支持统计直方图

开源、免费、跨平台

和Linux深度结合

特别适合互联网应用场景

入门学习成本低

社区庞大,生态完善

人才储备充足

新版本新功能越来越赞,值得信赖

从其他数据库迁移到MySQL及MySQL特点的更多相关文章

  1. 数据库迁移后报错提示MySQL Error:Can''t find file errno: 13 - Permission denied的解决方法

    用户MYSQL数据库迁移后,遇到报错MySQL Error:Can't find file (errno: 13 - Permission denied)使用以下指令重新设置所有者和权限,依然不能解决 ...

  2. 项目那几步走:先配置setting路径文件、创建数据库、执行数据库迁移命令、配置mysql数据库信息、注册app、注释中间件、pymysql替换mysqldb-配置urls路由-继续视图函数-然后HTML页面展示-HTML里面导入css文件、models配置数据库表、

    django使用mysql数据库: 首先cmd创建库 1.settings: """Django settings for day42 project. Generate ...

  3. 用kettle实现数据库迁移之oracle到mysql

    项目完成后,需要把历史oracle 的数据库转移mysql 用kettle 转换数据. 步骤: 1.打开spoon.bat,文件-->新建-->转换,点击“主对象树”,DB连接右键“新建” ...

  4. [Windows Server 2008] MySQL单数据库迁移方法

    ★ 欢迎来到[护卫神·V课堂],网站地址:http://v.huweishen.com ★ 护卫神·V课堂 是护卫神旗下专业提供服务器教学视频的网站,每周更新视频. ★ 本节我们将带领大家:MySQL ...

  5. DJango配置mysql数据库以及数据库迁移

    DJango配置mysql数据库以及数据库迁移 一.Django 配置MySQL数据库 在settings.py中配置 import pymysql # 配置MySQL pymysql.install ...

  6. ubuntu系统lamp环境搭建、数据库迁移、设置数据库外部访问

    sudo passwd root设置两次密码su输入设置的密码exit (退出root帐号) 1.sudo apt-get update 2.sudo apt-get install apache2 ...

  7. MySQL数据库迁移(转)

    MySQL数据库迁移(数据文件直接迁移) 在今年10月下旬的时候,公司的服务器需要迁移,其中涉及到了MySQL数据库迁移.查看了一下MySQL数据文件的大小,接近60G的大小(实际数据并没用那么多). ...

  8. 数据库迁移之从oracle 到 MySQL

    方式一: 手动方式导入导出 手动的方式导入, 就是操作步骤会比较繁琐一些. 对Table 的结构和数据: 1. 使用 SQL Developer 把 oracle 的 table 的schema 和 ...

  9. [saiku] 将saiku自带的H2嵌入式数据库迁移到本地mysql数据库

    saiku数据库的表和用户默认创建是在启动项目的时候,通过初始化 saiku-beans.xml 中的 h2database 这个 bean 执行org.saiku.service.Database类 ...

  10. MySQL数据库迁移详细步骤(转)

    ========================================================================================== 一.背景简介 == ...

随机推荐

  1. eQTL | Expression quantitative trait loci | 表达数量性状基因座 | QTL | 数量性状位点

    到底什么是eQTL? eQTL和QTL之间有什么联系?为什么说QTL比eQTL难很多? QTL和GWAS有什么关系? GTEx数据库里的eQTL数据如何利用? 说eQTL之前必须先解释QTL,QTL, ...

  2. 手写HashMap实践

    1.什么是HashMap 2.源码分析 3.手写实现 4.不足 一.什么是HashMap hash散列 将一个任意长度通过某种算法(hash函数算法)换成一个固定值 map: 地图x,y 存储 总结: ...

  3. RabbitMQ教程C#版 - 发布订阅

    先决条件本教程假定 RabbitMQ 已经安装,并运行在localhost标准端口(5672).如果你使用不同的主机.端口或证书,则需要调整连接设置. 从哪里获得帮助如果您在阅读本教程时遇到困难,可以 ...

  4. MySQL 行转列 -》动态行转列 -》动态行转列带计算

    Pivot Table Using MySQL - A Complete Guide | WebDevZoomhttp://webdevzoom.com/pivot-table-using-mysql ...

  5. centos下如何开放某个端口?

    命令如下: firewall-cmd --permanent --add-port=/tcp (开放22端口) firewall-cmd --reload

  6. 美国gfs数据介绍和解析

    最近有个项目需要开发个气象信息API,可以通过经纬度查找未来几天的气象信息. 经过几天的研究,现在简单总结一下. 1.数据来源数据来源采自美国国家环境预报中心的GFS(全球预报系统),该系统每天发布4 ...

  7. C++17 std::shared_mutex的替代方案boost::shared_mutex

    C++17 std::shared_mutex的替代方案boost::shared_mutex C++17boost  std::shared_mutex http://en.cppreference ...

  8. Spring cloud微服务安全实战-5-6实现授权码认证流程(2)

    授权服务器,返回给我一个授权码,这里我只需要把授权传回去就可以了.来证明我是这个服务器. URI的地址传和第一次的地址一样的,认证服务器会比,第一次跳转的请求和第二次申请令牌的请求redirect_u ...

  9. Linux记录-mysql参数优化

    1.参数优化show variables like ''/etc/my.cnf[mysqld]Max_connections =1024 #请求的最大连接数back_log =1024 #mysql能 ...

  10. Python - Django - simple_tag 和 inclusion_tag

    simple_tag: simple_tag 和自定义 filter 类似,但可以接收更多更灵活的参数 在 app01/templatetags/ 目录下创建 mysimple_tag.py mysi ...