Viele Entwickler, die den Query Builder von Laravel oder die Fluent API verwenden, sehen sich häufig mit der Notwendigkeit konfrontiert, Tabellen mit Aliasnamen zu versehen, um Abfragen besser lesbar und verwaltbar zu machen . In diesem Artikel wird gezeigt, wie Tabellen in Laravel Eloquent-Abfragen und dem Query Builder mit Aliasnamen versehen werden.
Stellen Sie sich das folgende Szenario vor:
<code class="php">$users = DB::table('really_long_table_name') ->select('really_long_table_name.id') ->get();</code>
In SQL können wir Tabellenaliase verwenden, um die Abfrage zu vereinfachen:
<code class="sql">really_long_table_name AS short_name</code>
Laravel unterstützt Tabellenaliase mit dem Schlüsselwort AS. Um eine Tabelle im Laravel Query Builder mit einem Alias zu versehen, fügen Sie einfach den Alias wie folgt nach dem Tabellennamen hinzu:
<code class="php">$users = DB::table('really_long_table_name AS t') ->select('t.id') ->get();</code>
Hier wurde der Tabelle wirklich_langer_Tabellenname ein Alias mit t zugewiesen. Sie können diesen Alias in der gesamten Abfrage verwenden, einschließlich in Select-, Where- und anderen Klauseln.
Um die Verwendung zu demonstrieren, führen wir eine Abfrage mit Tinker durch:
<code class="bash">Schema::create('really_long_table_name', function($table) {$table->increments('id');}); DB::table('really_long_table_name')->insert(['id' => null]); DB::table('really_long_table_name AS t')->select('t.id AS uid')->get();</code>
Dies gibt eine zurück Objekt mit der Alias-Spalten-UID, wie unten gezeigt:
<code class="php">array( 0 => object(stdClass)( 'uid' => '1' ) )</code>
Durch das Verständnis dieser Technik können Sie Tabellen in Laravel Eloquent-Abfragen und Query Builder effektiv mit Alias versehen, wodurch Ihr Code lesbarer und verwaltbarer wird, insbesondere bei der Arbeit mit komplexe Abfragen.
Das obige ist der detaillierte Inhalt vonWie werden Aliastabellen in Laravel Eloquent- und Query Builder-Abfragen erstellt?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!