MySQL向GraphQL迁移

GraphQL 是一个开源的图形数据库(基于Node.js实现), 中文文档: https://graphql.js.cool/

sequelize-auto 将 MySQL 数据库转变成模型


  1. [node] sequelize-auto -h <host> -d <database> -u <user> -x [password] -p [port] --dialect [dialect] -c [/path/to/config] -o [/path/to/models] -t [tableName] -C 参数: -h, --host 主机地址 [必须] -d, --database 数据名 [必须] -u, --user 用户名 -x, --pass 密码 -p, --port 端口号 -c, --config 配置文件,参考: https://sequelize.readthedocs.org/en/latest/api/sequelize/ -o, --output 输出目录 -e, --dialect 数据库引擎: postgres, mysql, sqlite -t, --tables 需要导入的表 -T, --skip-tables 需要排除的表 -C, --camel 使用用驼峰命名法 -n, --no-write 不需要写入文件 -s, --schema 数据库结构 

使用数据模型

这里是生成的一个示例模型:


  1. /* jshint indent: 2 */ 
  2.  
  3. module.exports = function(sequelize, DataTypes) { 
  4.   return sequelize.define('d_user', { 
  5.     uid: { 
  6.       type: DataTypes.INTEGER(11).UNSIGNED, 
  7.       allowNull: false, 
  8.       primaryKey: true 
  9.     }, 
  10.     username: { 
  11.       type: DataTypes.STRING(16), 
  12.       allowNull: false, 
  13.       defaultValue: '' 
  14.     }, 
  15.     mobile: { 
  16.       type: DataTypes.STRING(16), 
  17.       allowNull: false, 
  18.       defaultValue: '' 
  19.     }, 
  20.     email: { 
  21.       type: DataTypes.STRING(32), 
  22.       allowNull: false, 
  23.       defaultValue: '' 
  24.     }, 
  25.     password: { 
  26.       type: DataTypes.STRING(32), 
  27.       allowNull: false, 
  28.       defaultValue: '' 
  29.     }, 
  30.     salt: { 
  31.       type: DataTypes.STRING(8), 
  32.       allowNull: false, 
  33.       defaultValue: '' 
  34.     }, 
  35.     updatedAt: { 
  36.       type: DataTypes.INTEGER(10).UNSIGNED, 
  37.       allowNull: false 
  38.     } 
  39.   }, { 
  40.     tableName: 'user' 
  41.   }); 
  42. };  

创建数据库模型:


  1. const Sequelize = require('sequelize'); const Db = new Sequelize('数据库名', '用户名', '密码', { host: 'localhost', dialect: 'mysql' }) const User = Db.define('user', { uid: { type: Sequelize.INTEGER(11).UNSIGNED, allowNull: false, primaryKey: true }, username: { type: Sequelize.STRING(16), allowNull: false, defaultValue: '' }, mobile: { type: Sequelize.STRING(16), allowNull: false, defaultValue: '' }, email: { type: Sequelize.STRING(32), allowNull: false, defaultValue: '' }, password: { type: Sequelize.STRING(32), allowNull: false, defaultValue: '' }, salt: { type: Sequelize.STRING(8), allowNull: false, defaultValue: '' } }, { tableName: 'user', // 取消默认的时间戳, 否则会报 createdAt 不存在错误 timestamps: false }); Db.sync(); module.exports = { Db, User }; 

graphql-sequelize 转换 MySQL -> GraphQL 结构


  1. const { GraphQLObjectType,GraphQLSchema,GraphQLList,GraphQLInt,GraphQLString } = require('graphql'); 
  2. const { attributeFields, resolver } = require('graphql-sequelize'); 
  3. const { Db, User } = require('./db'); 
  4.  
  5. userType = new GraphQLObjectType({ 
  6.   name: 'User', 
  7.   description: 'A user', 
  8.   fields: attributeFields(User) 
  9. }); 
  10.  
  11. const Query = new GraphQLObjectType({ 
  12.   name: 'Query', 
  13.   description: 'Root query object', 
  14.   fields: () => { 
  15.     return { 
  16.       user: { 
  17.         type: new GraphQLList(userType), 
  18.         args: { 
  19.           uid: { 
  20.             type: GraphQLInt 
  21.           }, 
  22.           email: { 
  23.             type: GraphQLString 
  24.           } 
  25.         }, 
  26.         resolve(root, args) { 
  27.           return Db.models.user.findAll({ where: args }); 
  28.         } 
  29.       } 
  30.     }; 
  31.   } 
  32. }); 
  33.  
  34. const Schema = new GraphQLSchema({ 
  35.   query: Query 
  36. }); 
  37.  
  38. module.exports = Schema;  

启动服务器


  1. const Express =require( 'express'); 
  2. const GraphHTTP =require( 'express-graphql'); 
  3. const Schema =require( './schema'); 
  4.  
  5. // Config 
  6. const APP_PORT = 3000; 
  7.  
  8. // Start 
  9. const app = Express(); 
  10.  
  11. // GraphQL 
  12. app.use('/graphql', GraphHTTP({ 
  13.   schema: Schema, 
  14.   pretty: true, 
  15.   graphiql: true 
  16. })); 
  17.  
  18. app.listen(APP_PORT, ()=> { 
  19.   console.log(`App listening on port ${APP_PORT}`);  
    本文作者:佚名
    来源:51CTO
时间: 2025-01-21 07:39:19

MySQL向GraphQL迁移的相关文章

教你实现MySQL表数据迁移自动化

一.背景 之前我写过关于SQL Server的数据迁移自动化的文章:SQL Server 数据库迁移偏方,在上篇文章中设计了一张临时表,这个临时表记录搬迁的配置信息,用一个存储过程读取这张表进行数据的迁移,再由一个Job进行迭代调用这个存储过程. 在这次MySQL的实战中,我的数据库已经做了4个分片,分布在不同的4台机器上,每台机器上的数据量有1.7亿(1.7*4=6.8亿),占用空间260G(260*4=1040G),这次迁移的目的就是删除掉一些历史记录,减轻数据库压力,有人说这为什么不使用表

从MySQL 5.5迁移到Mariadb 10.1.14所遇到的问题_Mysql

迁移计划如下: 1.备份MySQL 5.5的数据库,对指定库进行备份. 2.还原到Mariadb,然后建立复制. 3.然后就可以愿意啥时候切换就啥时候切换. 遇到的问题: 因为一般都是innodb,所以我想用xtrabackup工具备份.备份后发现还原需要依赖innodb的表空间切换. 1.表空间切换,必须要打开innodb_file_per_table.也就是说所有的表都要有独立的文件.有一些表虽然是innodb但是存在ibdata下面. 幸好可以申请维护窗口,简单粗暴的重建了. 2.从MyS

MySQL数据库数据迁移到SQLserver

最近因工作需要,需要将mysql数据库迁移到sqlserver,仅仅是数据迁移,因此相对比较简单.对于mysql迁移到sqlserver,我们需要使用到mysql odbc驱动,然后透过sqlserver链接服务器的方式来访问mysql.具体见下文描述. 一. 迁移环境 源:RHEL 6.5 + MySQL 5.6.26 目标: Windows 7 64 + SQLserver 2014 二.准备迁移环境 1.下载及安装ODBC驱动 http://dev.mysql.com/downloads/

使用perl实现拆分数据表(mysql)并迁移数据实例_perl

随着业务量的增长,可能需要对表进行拆分来提高性能. 下面这个例子是将www.jb51.net的users表拆分成10个表ttlsa_user_0-ttlsa_user_9. 拆分迁移数据程序如下所示: 1.创建ttlsa_user_0-ttlsa_user_9表 复制代码 代码如下: #!/usr/bin/perl ################################### ### author: www.jb51.net ### ### QQ群:232608061  ### ###

MySQL数据库快速迁移方法

 如果要保证数据的完整性, 最好的做法就是停服, 不在向数据库中写入数据了, 全备然后在新的DB上恢复. 但是这样的话大量的数据可能会消耗几个小时的时间来备份和恢复数据, 停止几个小时的时间会让人觉得崩溃!  所以比较好的方案是提前做一个全备, 并且新开始一个二进制日志, 然后在迁移的时候把二进制日志转移过去, 在全备的基础上做增量.     迁移第一步: 先将DB做全备, 并转移大部分数据             很幸运的是 mysqldump 提供了这样的功能!             my

mysql数据文件目录迁移

  以前都是改/etc/my.cnf,再将数据文件移到新的目录下,操作起来比较烦,且易出错,今天学习了一种新的方法,再此记录和分享. 1.停掉mysql service mysqld stop 2.移动数据文件到新目录下mv /var/lib/mysql /data/sas0/ 3.连接目录cd /var/lib/ln -s /data/sas0/mysql 4.启动数据库service mysqld start

mysql字符集latin1迁移utf8的方法

场景说明: 1.现上几百台mysql数据库,字符编码latin1,现在需要做一个活动,将现上mysql数据库的一些活动数据同步到一台mysql汇总数据库(latin1),然后再将数据同步oracle中,最后官网显示. 2.oracle是活动库,字符集是ZHS16GBK,由于还有很大一部分数据都在oracle库中,所以需要将mysql中的数据同步到oracle中. 3.mysql中有一个字段name,内容是中文.各种火星文. 4.官网是用java开发的,所有项目都是以utf8编码的. 首先需要简单

一句命令完成MySQL的数据迁移(轻量级数据)_Mysql

用管道符将mysqldump的输出流和mysql的输入流串接在一起,管道符真是一个伟大的发明. 复制代码 代码如下: mysqldump -uXXX -pYYY -h192.168.4.98 -P3306 DBNAME --skip-lock-tables | mysql -uroot -h127.0.0.1 DBNAME 首先要保证本地可以连接服务器上的3306端口,如果win2003系统相同直接复制数据库文件夹即可.

mysql 备份与迁移 数据同步方法_Mysql

不过最近发现这个可视化操作有点点问题,就是当数据条数超过一定数目EMS SQL Manager就挂了,也不知道是否是软件问题--当然该开始我是将大的数据库文件分拆成小份小份的,多次导入. 刚才发现同事用了mysql 自带的mysqldump 工具就不存在这个问题. (羞愧,不过我平时极少接触数据库) 这里记录下操作方式: 1. 进入bin目录,执行命令: mysqldump -hlocalhost -uroot -padmin local_db > a.sql 2. 这时发现在bin目录生成了