我遇到了一个小问题(希望),希望你们中的一个能够帮助我:)
在我的数据库中得到以下值: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) =…