MySQL向GraphQL迁移

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介:

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.   schemaSchema
  14.   pretty: true
  15.   graphiql: true 
  16. })); 
  17.  
  18. app.listen(APP_PORT, ()=> { 
  19.   console.log(`App listening on port ${APP_PORT}`);   本文作者:佚名 来源:51CTO
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
30天前
|
存储 SQL 关系型数据库
【YashanDB知识库】MySQL迁移至崖山char类型数据自动补空格问题
**简介**:在MySQL迁移到崖山环境时,若字段类型为char(2),而应用存储的数据仅为&#39;0&#39;或&#39;1&#39;,查询时崖山会自动补空格。原因是mysql的sql_mode可能启用了PAD_CHAR_TO_FULL_LENGTH模式,导致保留CHAR类型尾随空格。解决方法是与应用确认数据需求,可将崖山环境中的char类型改为varchar类型以规避补空格问题,适用于所有版本。
|
22天前
|
关系型数据库 MySQL Java
【YashanDB知识库】Kettle迁移MySQL到YashanDB
本文介绍了使用Kettle将MySQL数据库中的中文数据迁移到YashanDB的方法,解决因YMP不支持Latin1字符集导致的乱码问题。提供了Windows和Linux两种环境下的操作步骤,包括配置JAVA环境、解压作业包、设置数据库连接(MySQLInput与YashanOutput)、修改表列表配置文件及运行迁移任务。Windows环境支持图形界面便于调试,Linux环境网络性能更优。通过详细的操作指南,确保数据迁移成功并可重试无冲突。
|
24天前
|
安全 关系型数据库 MySQL
【YashanDB知识库】YMP从mysql迁移到崖山,报错:服务器错误
【YashanDB知识库】YMP从mysql迁移到崖山,报错:服务器错误
|
22天前
|
SQL 关系型数据库 MySQL
【YashanDB知识库】字符集latin1的MySQL中文数据如何迁移到YashanDB
本文探讨了在使用YMP 23.2.1.3迁移MySQL Server字符集为latin1的中文数据至YashanDB时出现乱码的问题。问题根源在于MySQL latin1字符集存放的是实际utf8编码的数据,而YMP尚未支持此类场景。文章提供了两种解决方法:一是通过DBeaver直接迁移表数据;二是将MySQL表数据转换为Insert语句后手动插入YashanDB。同时指出,这两种方法适合单张表迁移,多表迁移可能存在兼容性问题,建议对问题表单独处理。
【YashanDB知识库】字符集latin1的MySQL中文数据如何迁移到YashanDB
|
23天前
|
安全 关系型数据库 MySQL
【YashanDB知识库】YMP从mysql迁移到崖山,报错:服务器错误
【YashanDB知识库】YMP从mysql迁移到崖山,报错:服务器错误
【YashanDB知识库】YMP从mysql迁移到崖山,报错:服务器错误
|
1月前
|
Oracle 关系型数据库 MySQL
使用崖山YMP 迁移 Oracle/MySQL 至YashanDB 23.2 验证测试
这篇文章是作者尚雷关于使用崖山YMP迁移Oracle/MySQL至YashanDB 23.2的验证测试分享。介绍了YMP的产品信息,包括架构、版本支持等,还详细阐述了外置库部署、YMP部署、访问YMP、数据源管理、任务管理(创建任务、迁移配置、离线迁移、校验初始化、一致性校验)及MySQL迁移的全过程。
|
1月前
|
SQL 关系型数据库 MySQL
MySQL生产环境迁移至YashanDB数据库深度体验
这篇文章是作者将 MySQL 生产环境迁移至 YashanDB 数据库的深度体验。介绍了 YashanDB 迁移平台 YMP 的产品相关信息、安装步骤、迁移中遇到的各种兼容问题及解决方案,最后总结了迁移体验,包括工具部署和操作特点,也指出功能有优化空间及暂不支持的部分,期待其不断优化。
|
8月前
|
弹性计算 关系型数据库 数据库
手把手带你从自建 MySQL 迁移到云数据库,一步就能脱胎换骨
阿里云瑶池数据库来开课啦!自建数据库迁移至云数据库 RDS原来只要一步操作就能搞定!点击阅读原文完成实验就可获得一本日历哦~
|
2月前
|
存储 SQL 关系型数据库
【YashanDB 知识库】MySQL 迁移至崖山 char 类型数据自动补空格问题
问题分类】功能使用 【关键字】char,char(1) 【问题描述】MySQL 迁移至崖山环境,字段类型源端和目标端都为 char(2),但应用存储的数据为'0'、'1',此时崖山查询该表字段时会自动补充空格 【问题原因分析】mysql 有 sql_mode 控制,检查是否启用了 PAD_CHAR_TO_FULL_LENGTH SQL 模式。如果启用了这个模式,MySQL 才会保留 CHAR 类型字段的尾随空格,默认没有启动。 #查看sql_mode mysql> SHOW VARIABLES LIKE 'sql_mode'; 【解决/规避方法】与应用确认存储的数据,正确定义数据
|
8月前
|
关系型数据库 MySQL 数据库

推荐镜像

更多
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等