如何让whereIn里面的数字 不被转成字符串

如何让 whereIn 里面的数字 不被转成字符串
Laravel

《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
最佳答案

laravel 实际执行的时候不会转换成字符串,你打印的 sql 应该是通过替换占位符生成的,统一转成了字符串

2年前 评论
讨论数量: 11

class Post extends Model
{
    /**
     * The attributes that should be cast.
     *
     * @var array<string, string|class-string>
     */
    protected $casts = [
        'transaction_id' => 'int',
    ];
}

我是这样弄的, 应该是可以的

Laravel

2年前 评论
kis龍 (作者) 2年前
哪吒的狗腿子 (楼主) 2年前

超过数字的最大值就只能字符了吧

2年前 评论
哪吒的狗腿子 (楼主) 2年前
deatil (作者) 2年前
哪吒的狗腿子 (楼主) 2年前

如果是 MySQL 的话,没什么影响呐。

列是数字类型,值是字符串,不会有啥影响呐,反过来会有影响。

2年前 评论

在 database config 里加 PDO::ATTR_STRINGIFY_FETCHES => false

2年前 评论

->whereIn('id', [1, Db::raw('2')])

2年前 评论

laravel 实际执行的时候不会转换成字符串,你打印的 sql 应该是通过替换占位符生成的,统一转成了字符串

2年前 评论