未加星标

koa2 之 migration with knex

字体大小 | |
[前端(javascript) 所属分类 前端(javascript) | 发布者 店小二04 | 时间 2017 | 作者 红领巾 ] 0人收藏点击收藏
安装knexfile npm install -g knex

然后在项目的根目录

knex init

将会产生knexfile.js,内容类似如下

// Update with your config settings.
module.exports = {
development: {
client: 'mysql',
connection: {
host: '127.0.0.1',
user: 'root',
password: '',
database: '<YOUR TEST DB NAME>',
charset: 'utf8'
}
},
staging: {
...
},
production: {
...
}
};

如果想要根据具体环境来执行具体配置,可以使用如下命令来指定环境

knex migrate:latest --env production

更多的使用可以参考 Knex docs

创建Migration knex migrate:make create_person

将会创建migrations目录并且将migration的文件放入文件夹中

默认的内容如下:

exports.up = function(knex, Promise){
}
exports.down = function(knex, Promise){
}

接下来我们在这里面实现具体的表信息

exports.up = function(knex, Promise){
return Promise.all([
knex.schema.createTable('person', function(table){table.increments('id').primary();table.integer('parentId').unsigned().references('id').inTable('person');table.string('firstName');table.string('fullName');table.integer('age');table.json('address');
})
]);
}
exports.down = function(knex, Promise){
return Promise.all([
knex.schema.dropTable('person')
]);
}

当应用migration的时候up被调用,当执行回滚的时候down被调用

在这些功能中,你可以使用 Knex Schema functions

执行如下命令来使用新的migration

knex migrate:latest 更新数据库表 knex migrate:make update_person

内容如下

exports.up = function(knex, Promise) {
return Promise.all([
knex.schema.table('person', function(table){table.string('twitter');
})
])
}
exports.down = function(knex, Promise) {
return Promise.all([
knex.schema.table('person', function(table){table.dropColumn('twitter');
})
]);
} 回滚操作

回滚操作执行下面的命令

knex migrate:rollback

knex对于创建跟修改表变得很容易。

本文前端(javascript)相关术语:javascript是什么意思 javascript下载 javascript权威指南 javascript基础教程 javascript 正则表达式 javascript设计模式 javascript高级程序设计 精通javascript javascript教程

主题: 数据数据库
分页:12
转载请注明
本文标题:koa2 之 migration with knex
本站链接:http://www.codesec.net/view/534843.html
分享请点击:


1.凡CodeSecTeam转载的文章,均出自其它媒体或其他官网介绍,目的在于传递更多的信息,并不代表本站赞同其观点和其真实性负责;
2.转载的文章仅代表原创作者观点,与本站无关。其原创性以及文中陈述文字和内容未经本站证实,本站对该文以及其中全部或者部分内容、文字的真实性、完整性、及时性,不作出任何保证或承若;
3.如本站转载稿涉及版权等问题,请作者及时联系本站,我们会及时处理。
登录后可拥有收藏文章、关注作者等权限...
技术大类 技术大类 | 前端(javascript) | 评论(0) | 阅读(44)