首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用goose进行数据库迁移时的回滚

使用goose进行数据库迁移时的回滚
EN

Stack Overflow用户
提问于 2021-07-24 13:49:56
回答 1查看 85关注 0票数 1

我用的是this goose口味。我希望我的迁移脚本在出现错误时回滚。在-- +goose StatementStart-- +goose StatementEnd中包装我的语句对我不起作用。

代码语言:javascript
复制
-- +goose Up
-- SQL in section 'Up' is executed when this migration is applied
-- +goose StatementBegin
ALTER TABLE books
    ADD COLUMN author VARCHAR(10) NOT NULL AFTER name;

UPDATE books
SET author = created_by
WHERE created > '2021-01-05';
-- +goose StatementEnd

-- +goose Down
-- SQL section 'Down' is executed when this migration is rolled back
-- +goose StatementBegin
ALTER TABLE books
    DROP COLUMN author;
-- +goose StatementEnd

这将导致Error 1064: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'UPDATE...

goose可以做到这一点吗?或者我只需要在一个迁移文件中编写一个查询?

EN

回答 1

Stack Overflow用户

发布于 2021-07-25 21:12:16

根据MySQL 5.7 documentation,大多数动态链接库查询不能作为事务执行。

因此,这应该不可能使用任何解决方法来完成,因为它与底层数据库类型和版本相关。

@mh-cbon谢谢你指出这一点。

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

https://stackoverflow.com/questions/68507360

复制
相关文章

相似问题

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