首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >有Sqlite错误的Laravel迁移: typeSet不存在

有Sqlite错误的Laravel迁移: typeSet不存在
EN

Stack Overflow用户
提问于 2020-02-02 12:26:31
回答 1查看 688关注 0票数 4

TLDR;

在SQLite中,是否有更好的或替代的方法来使用"set"?

全信息

我试图在Laravel中运行一个迁移,它在MySQL上运行得很好。但是,每当试图在SQLite上的测试数据库上运行相同的迁移时,我都会遇到以下错误:

代码语言:javascript
复制
In Macroable.php line 103:

  Method Illuminate\Database\Schema\Grammars\SQLiteGrammar::typeSet does not exist.

据我所知,错误是指出"set“在SQLite中不存在。为了解决这个问题,我简单地将"set“改为"string”。但是,这是次优的,因为我想将该字段限制在特定的值上。

在SQLite中,是否有更好的或替代的方法来使用"set"?

示例:

下面是我的迁移,它适用于MySQL,但引发typeSet错误,如上面所示:

代码语言:javascript
复制
Schema::create('subscribers', function (Blueprint $table) {
    $table->bigIncrements('id');
    $table->set('test', ['one', 'two', 'three']);
    $table->timestamps();
});

下面是我对SQLite数据库的临时修复:

代码语言:javascript
复制
Schema::create('subscribers', function (Blueprint $table) {
    $table->bigIncrements('id');
    $table->string('test', 255);
    $table->timestamps();
});

谢谢大家的意见和建议!

谢谢你的回答!对于其他人来说,如果你想知道更多关于ENUM和SET之间的区别的话,这个答案也很有帮助:MySQL enum vs. set)

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-02-02 12:36:04

对于这里的设置,您可以使用枚举数据类型。在迁移文件中尝试下面的格式。

代码语言:javascript
复制
$table->enum('test', ['one', 'two', 'three']);
票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60026077

复制
相关文章

相似问题

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