Heim > Datenbank > MySQL-Tutorial > Wie kann ich PostgreSQL-Array-Indizes effizient so normalisieren, dass sie bei 1 beginnen?

Wie kann ich PostgreSQL-Array-Indizes effizient so normalisieren, dass sie bei 1 beginnen?

Linda Hamilton
Freigeben: 2025-01-09 12:06:42
Original
698 Leute haben es durchsucht

How Can I Efficiently Normalize PostgreSQL Array Subscripts to Start at 1?

PostgreSQL-Array-Index-Normalisierung: ab 1

PostgreSQL-Array-Indizes können bei jedem Wert beginnen. Array-Operationen können jedoch vereinfacht werden, indem die Indizes eindimensionaler Arrays so normalisiert werden, dass sie bei 1 beginnen. In diesem Artikel wird eine elegantere Methode der Normalisierung untersucht, die in PostgreSQL Version 9.6 eingeführt wurde.

In Versionen von PostgreSQL vor 9.6 bestand ein Ansatz darin, die Funktionen array_lower und array_upper zu verwenden, um einen Indexbereich anzugeben:

<code class="language-sql">SELECT ('[5:7]={1,2,3}'::int[])[array_lower('[5:7]={1,2,3}'::int[], 1):array_upper('[5:7]={1,2,3}'::int[], 1)]</code>
Nach dem Login kopieren

Ab PostgreSQL 9.6 hat sich jedoch eine einfachere und effizientere Methode herausgebildet: das Weglassen der unteren und oberen Grenzen des Slice-Spezifizierers. Laut Handbuch:

<code>可以省略切片指定符的下限和/或上限;缺失的边界将被替换为数组下标的下限或上限。</code>
Nach dem Login kopieren

Dies ermöglicht die Verwendung einer prägnanten Normalisierungssyntax:

<code class="language-sql">SELECT my_arr[:];</code>
Nach dem Login kopieren

Für das Array-Literal '[5:7]={1,2,3}' können Sie beispielsweise Folgendes verwenden:

<code class="language-sql">SELECT ('[5:7]={1,2,3}'::int[])[:];</code>
Nach dem Login kopieren

Dieser Ansatz hat eine ähnliche Leistung wie der vorherige Ansatz mit der Verwendung hartcodierter maximaler Array-Indizes, ist jedoch eleganter und kann mit Arrays jeder Größe verwendet werden.

Das obige ist der detaillierte Inhalt vonWie kann ich PostgreSQL-Array-Indizes effizient so normalisieren, dass sie bei 1 beginnen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage