成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

MySQL向GraphQL遷移

大數據
GraphQL 是一個開源的圖形數據庫(基于Node.js實現), sequelize-auto 將 MySQL 數據庫轉變成模型。

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}`);  
責任編輯:龐桂玉 來源: 36大數據
相關推薦

2013-01-06 09:43:35

MySQLMySQL遷移Redis

2010-01-13 17:24:34

SQL Server遷

2009-03-09 16:27:17

數據遷移PHPOracle

2010-11-10 09:03:27

云計算遷移

2015-11-24 17:46:42

云遷移IT基礎設施云服務

2016-01-29 10:26:47

云端云遷移

2015-09-09 15:16:19

混合云云遷移

2011-06-09 10:36:51

IPv6IPv6部署

2012-07-31 09:55:53

云計算

2012-06-12 09:13:14

2020-12-02 10:35:09

云端災難恢復云遷移

2014-06-06 09:52:20

802.11acWi-Fi

2012-08-01 10:08:10

云計算云遷移

2023-12-15 16:45:22

微軟Azure遷移

2011-05-04 13:11:29

Exchange

2011-08-11 18:10:58

iCoremail云計算企業郵箱

2016-08-05 15:04:33

javascripthtmljs

2020-09-28 06:57:39

Node.jsGraphQLAPI

2019-12-18 16:05:57

Python編程語言代碼

2021-08-12 13:35:35

云計算云服務安全
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲成人精品在线 | 久久9精品 | 99久久夜色精品国产亚洲96 | jlzzjlzz国产精品久久 | 亚洲一区二区在线电影 | www午夜视频 | 日韩欧美一区二区三区四区 | www.久久久久久久久久久久 | 在线成人av | 国产精品美女久久久久久免费 | 精品在线一区二区 | 亚洲情综合五月天 | 欧美亚洲在线 | 国产一区久久精品 | 欧美久久一区二区 | 亚洲午夜精品 | se婷婷| 亚洲精精品 | 成人福利在线 | 日韩高清国产一区在线 | 国产探花 | 三级在线免费 | 精品国产乱码久久久久久闺蜜 | 亚洲国产精品久久久久 | 欧美在线观看一区二区 | 视频在线亚洲 | 欧美中文一区 | 罗宾被扒开腿做同人网站 | 91视频久久 | 国产精品国产精品国产专区不片 | 91亚洲免费 | 亚洲欧美精品国产一级在线 | 91在线视频观看免费 | 国产高清免费视频 | 国产精品高潮呻吟久久aⅴ码 | 久久久久www | 日韩综合在线视频 | 一区二区三区不卡视频 | 欧美专区在线观看 | 中文在线一区二区 | 少妇黄色 |