首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >迁移:在特定列之后添加一列

迁移:在特定列之后添加一列
EN

Stack Overflow用户
提问于 2019-11-13 07:56:49
回答 2查看 1.9K关注 0票数 1

使用SQL很容易做到这一点,但是我需要编写一个我不熟悉的Knex迁移脚本。下面在order表中的行尾添加order_id列。我希望在id之后添加order_id。我该怎么做?

代码语言:javascript
运行
复制
const TABLE_NAME = 'order';
exports.up = function (knex) {
    return knex.schema.alterTable(TABLE_NAME, table => {
        table
            .specificType('order_id', 'char(10)')
            .unique()
            .notNullable();

    });
};

exports.down = function (knex) {
    return knex.schema.table(TABLE_NAME, function (t) {
        t.dropColumn('order_id');
    });
};
EN

回答 2

Stack Overflow用户

发布于 2019-11-14 01:43:30

在更改表时,没有SQL确定列的顺序。顺序是在查询时确定的,例如:

代码语言:javascript
运行
复制
knex
  .select('id', 'order_id')
  .from('order')

收益率

代码语言:javascript
运行
复制
id | order_id
===+=========
1  | 2

鉴于

代码语言:javascript
运行
复制
knex
  .select('order_id', 'id')
  .from('order')

收益率

代码语言:javascript
运行
复制
order_id | id
=========+===
2        | 1

如果单个数据库引擎确实支持在创建表之后更改列的顺序,这将是特定于该引擎的,并且对于像Knex这样的SQL生成器来说不容易操作。有关详细信息,请参阅How do I alter the position of a column in a PostgreSQL database table?

票数 1
EN

Stack Overflow用户

发布于 2021-05-26 20:11:31

老话题,但我找到了答案:

代码语言:javascript
运行
复制
return knex.schema.table('the_table', table => {    
    table.tinyint('new_column').defaultTo('0').after('other_column')
})

这适用于Mysql数据库。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58828429

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档