


recommend! Extension package for easily optimizing sql statements in Laravel
下面由laravel教程栏目给大家介绍在Laravel中轻松容易的优化sql语句的扩展包(laravel-soar),希望对需要的朋友有所帮助!
laravel-soar - 在 Laravel 应用程序中轻松容易的优化 sql 语句的扩展包。
功能
- 支持基于启发式算法的语句优化
- 支持复杂查询的多列索引优化(UPDATE, INSERT, DELETE, SELECT)
- 支持 EXPLAIN 信息丰富解读
- 支持 SQL 指纹、压缩和美化
- 支持 Eloquent 查询构建器方法生成 SQL 优化报告
源码链接
- github.com/guanguans/laravel-soar
相关项目
- github.com/XiaoMi/soar
- github.com/guanguans/soar-php
- github.com/huangdijia/laravel-web-soar
- github.com/wilbur-yu/hyperf-soar
- github.com/guanguans/think-soar
环境要求
- laravel >= 5.5
安装
$ composer require guanguans/laravel-soar --dev -vvv
发布服务
$ php artisan vendor:publish --provider="Guanguans\\LaravelSoar\\SoarServiceProvider"
使用
门面使用示例
$sql = Member::query()->select(['id', 'nickname'])->where('id', 100)->toRawSql(); \Soar::score($sql); // 生成 sql 评分报告 \Soar::mdExplain($sql); // 生成 markdown 格式的 explain 信息解读报告 \Soar::htmlExplain($sql); // 生成 html 格式的 Explain 信息解读报告 \Soar::syntaxCheck($sql); // sql 语法检查 \Soar::fingerPrint($sql); // 生成 sql 指纹 \Soar::pretty($sql); // 美化 sql \Soar::md2html($sql); // 将 markdown 格式内容转化为 html 格式内容 \Soar::help($sql); // 输出 soar 帮助命令内容 \Soar::exec($command); // 执行任意 soar 命令
生成 sql 评分报告示例
use App\Models\Member; Member::query() ->select([ 'id', 'nickname', ]) ->where('id', 100) // ->toSoarScore() // 生成 sql 评分报告 // ->dumpSoarScore() // 打印 sql 评分报告 ->ddSoarScore() // 打印 sql 评分报告,并且退出应用程序。 ;
// 查询构建器使用示例 DB::table('yb_member') ->select('*') ->join('yb_member_account as yb_member_account', 'yb_member_account.member_id', '=', 'yb_member.id') ->whereRaw('1 <> 1') ->where('yb_member.nickname', 'like', 'admin') ->where('yb_member.username', 'like', '%admin%') ->whereRaw("substring(yb_member.username, 1, 5) = 'admin'") ->whereIn('yb_member.id', [110, 111, 112, 113, 114, 115, 116, 117, 118, 119, 120]) ->orWhereNotNull('yb_member.realname') ->groupByRaw("yb_member.status, '100'") ->having('yb_member.id', '>', '100') ->inRandomOrder() // ->toSoarScore() // 生成 sql 评分报告 // ->dumpSoarScore() // 打印 sql 评分报告 ->ddSoarScore() // 打印 sql 评分报告,并且退出应用程序。 ;
生成 explain 信息解读报告示例
// 查询构建器使用示例 DB::table('yb_member') ->select('*') ->join('yb_member_account as yb_member_account', 'yb_member_account.member_id', '=', 'yb_member.id') ->whereRaw('1 <> 1') ->where('yb_member.nickname', 'like', 'admin') ->where('yb_member.username', 'like', '%admin%') ->whereRaw("substring(yb_member.username, 1, 5) = 'admin'") ->whereIn('yb_member.id', [110, 120]) ->orWhereNotNull('yb_member.realname') ->groupByRaw("yb_member.status, '100'") ->having('yb_member.id', '>', '100') ->inRandomOrder() // ->toSoarHtmlExplain() // 生成 explain 信息解读报告 // ->dumpSoarHtmlExplain() // 打印 explain 信息解读报告 ->ddSoarHtmlExplain() // 打印 explain 信息解读报告,并且退出应用程序。 ;
美化 sql 语句
// 查询构建器使用示例 DB::table('yb_member') ->select('*') ->join('yb_member_account as yb_member_account', 'yb_member_account.member_id', '=', 'yb_member.id') ->whereRaw('1 <> 1') ->where('yb_member.nickname', 'like', 'admin') ->where('yb_member.username', 'like', '%admin%') ->whereRaw("substring(yb_member.username, 1, 5) = 'admin'") ->whereIn('yb_member.id', [110, 120]) ->orWhereNotNull('yb_member.realname') ->groupByRaw("yb_member.status, '100'") ->having('yb_member.id', '>', '100') ->inRandomOrder() // ->toSoarPretty() // 生成美化后的 sql // ->dumpSoarPretty() // 打印美化后的 sql ->dumpSoarPretty() // 打印美化后的 sql,并且退出应用程序。 ;
《相关推荐:最新的五个Laravel视频教程》
The above is the detailed content of recommend! Extension package for easily optimizing sql statements in Laravel. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



Laravel - Artisan Commands - Laravel 5.7 comes with new way of treating and testing new commands. It includes a new feature of testing artisan commands and the demonstration is mentioned below ?

Laravel - Pagination Customizations - Laravel includes a feature of pagination which helps a user or a developer to include a pagination feature. Laravel paginator is integrated with the query builder and Eloquent ORM. The paginate method automatical

Method for obtaining the return code when Laravel email sending fails. When using Laravel to develop applications, you often encounter situations where you need to send verification codes. And in reality...

Laravel schedule task run unresponsive troubleshooting When using Laravel's schedule task scheduling, many developers will encounter this problem: schedule:run...

The method of handling Laravel's email failure to send verification code is to use Laravel...

How to implement the table function of custom click to add data in dcatadmin (laravel-admin) When using dcat...

Laravel - Dump Server - Laravel dump server comes with the version of Laravel 5.7. The previous versions do not include any dump server. Dump server will be a development dependency in laravel/laravel composer file.

The impact of sharing of Redis connections in Laravel framework and select methods When using Laravel framework and Redis, developers may encounter a problem: through configuration...
