Generate mysql table schema to graphql defination
- Node 7.6 or greater for async/await support
npm install graphql-mysql-schema --save
const mysqlGQL = require('graphql-mysql-schema');
let r = await mysqlGQL({
host: '127.0.0.1',
port: 3306,
user: "myuser",
password: 'mypwd',
database: 'db1'
}, {
tableName: 't1'
});
console.log(r);
output:
type t2 {
# comment of c1
c1: String,
# comment of c2
c2: Int,
c3: String,
# comment of c4
c4: Float,
# comment of c5
c5: Int,
}
default generate rules:
mysql type | graphql type |
---|---|
varchar | String |
char | String |
tinytext | String |
mediumtext | String |
longtext | String |
int | Int |
tinyint | Int |
smallint | Int |
mediumint | Int |
bigint | Int |
float | Float |
double | Float |
real | Float |
decimal | Float |
date | String |
time | String |
datetime | String |
timestamp | String |
year | String |
Others |
UNKNOWN |
mysqlGQL(mysqlOpt, options)
mysqlOpt: reference
options:
- tableName:
string
, name of mysql table. required - genRule:
function
orobject
, rule of generating columns, user-defined rule. optional - unknown: unknown type, default "UNKNOWN", optional
Example: override default type rules
// "varchar" will be generated as "my-type" type, instead of "String"
const overrideRules = {
varchar: 'my-type',
};
let r = await mysqlGQL({
host: '127.0.0.1',
port: 3306,
user: "root",
password: 'pwd',
database: 'db'
}, {
tableName: 'tn',
genRule: overrideRules
});
console.log(r);
Example: user define generate rule
const TypeMap = {
varchar: 'String',
char: 'String',
tinytext: 'String',
text: 'String',
// ...
};
// input: string, column type in mysql
function genType(input) {
let gType = TypeMap.hasOwnProperty(input) ? TypeMap[input] : 'UNKNOWN';
return gType;
}
let r = await mysqlGQL({
host: '127.0.0.1',
port: 3306,
user: "myuser",
password: 'mypwd',
database: 'db1'
}, {
tableName: 't2',
genFn: genType
});
console.log(r);
npm install graphql-mysql-schema -g
mygql -H 127.0.0.1 -P 3306 -U myuser -p mypwd -D mydb t2
output:
type t2 {
# comment of c1
c1: String,
# comment of c2
c2: Int,
c3: String,
# comment of c4
c4: Float,
# comment of c5
c5: Int,
}
options:
Usage: mygql [options] <tablename ...>
Options:
-V, --version output the version number
-H, --host [value] Mysql host
-P, --port [value] Mysql port
-U, --user [value] Mysql user
-p, --pwd [value] Mysql password
-D, --database [value] Mysql database
-h, --help output usage information
npm test