Laravel雄辩的顺序以数百个第一而不是最后一个 - php

我遇到了一个小问题(希望),希望你们中的一个能够帮助我:)

在我的数据库中得到以下值:56,63,75,80,90,100,132

我得到以下代码:

MotorSize::orderBy('framesize', 'asc')
            ->get();

然后在刀片中:

@foreach($motor_sizes as $motor_size)
    {{ $motor_size->name }}
@endforeach

我希望输出为:56,63,75,80,90,100,132

但是输出是:100、132、56、63、75、80、90

为什么会这样,如何解决?我想这与值的起始整数有关。

与数据库表有关的值:

$table->string('framesize');

也许因为它不是整数?有什么解决办法吗?

参考方案

您可以使用原始查询来获得所需的结果。

$query = "CAST(framesize AS INTEGER) ASC";
DB::table('motor_size')->orderByRaw($query)->get();

但是,更好的方法应该是修改列的数据类型。这样做将:

减少表的大小。
优化包含该列的索引。
其他雄辩的查询也将需要上面的原始查询,不建议这样做。

为此,创建一个新的迁移:

php artisan make:migration AlterFrameSizeInMotorSizeTable

添加以下内容作为up函数定义:

public function up()
{
    Schema::table('motor_size', function (Blueprint $table) {
        $table->integer('framesize')->change();
    });
}

然后使用以下命令运行迁移:

php artisan migrate

检查对象是否已在集合中-Laravel - php

当我循环一系列不同的结果时,我希望将对象添加到新集合中。查询:$osRed = Item::where('category', 'Hardware') ->where(function ($query) { $query->where('operating_system', '…

php-casperjs获取内部文本 - php

我正在为casperjs使用php包装器-https://github.com/alwex/php-casperjs我正在网上自动化一些重复的工作,我需要访问一个项目的innerText,但是我尚不清楚如何从casperjs浏览器访问dom。我认为在js中我会var arr = document.querySelector('label.input…

PHP getallheaders替代 - php

我正在尝试从服务器上的apache切换到nginx。唯一的问题是我在PHP脚本中使用的getallheaders()函数,该函数不适用于Nginx。我已经尝试过用户在getallheaders函数上的php站点上提供的注释,但这并不返回所有请求标头。请告诉我如何解决这个问题。我真的想切换到Nginx。 参考方案 您仍然可以使用它,但是您必须像这里一样重新定义…

Laravel打印日志 - php

我正在尝试在控制台上打印日志:我输入了:use Log; 然后在控制器中使用 Log::info('test log'); 但它不打印任何日志。 参考方案 我认为您需要在运行后检查storage/logs/laravel.logLog::info('test log'); 希望这对您有帮助

PHP:将字符串拆分为字母和数字部分的最佳方法 - php

我有几个格式的字符串AA11 AAAAAA1111111 AA1111111 分离字符串的字母和数字部分的最佳方法(最有效)? 参考方案 如果它们都是一系列字母,然后是一系列数字,并且没有非字母数字字符,那么sscanf()可能比regexp更有效$example = 'AAA11111'; list($alpha,$numeric) =…