Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Menjana Nombor Baris Berjujukan dalam Pertanyaan PostgreSQL?

Bagaimana untuk Menjana Nombor Baris Berjujukan dalam Pertanyaan PostgreSQL?

Susan Sarandon
Susan Sarandonasal
2024-12-28 00:53:14907semak imbas

How to Generate Sequential Row Numbers in PostgreSQL Queries?

Menjana Nombor Baris Berjujukan dalam Pertanyaan PostgreSQL

Apabila bekerja dengan pertanyaan PostgreSQL, adalah wajar untuk memaparkan nombor pemerhatian untuk setiap rekod yang dikembalikan . Dalam versi PostgreSQL 8.4 dan yang lebih baru, ini boleh dicapai menggunakan fungsi tetingkap yang berkuasa row_number().

Syntax:

Untuk menjana nombor baris berjujukan, gunakan yang berikut sintaks:

select row_number() over (order by <field> nulls last) as rownum, *
from <table_name>
order by <field>;

Parameter:

  • : Medan yang digunakan untuk menyusun baris.
  • < ;table_name>: Jadual dari mana data berada dipilih.

Contoh:

Untuk memaparkan nombor pemerhatian bagi jadual bernama foo_tbl yang disusun mengikut medan id, gunakan pertanyaan berikut:

select row_number() over (order by id nulls last) as rownum, *
from foo_tbl
order by id;

Sintaks Ringkas:

Jika pesanan tidak perlu, pertanyaan boleh dipermudahkan dengan meninggalkan susunan mengikut klausa:

select row_number() over(), *  -- no fields are needed
from foo_tbl;

Ini akan menjana nombor baris berurutan tanpa sebarang susunan tertentu.

Bukti Konsep:

Bukti konsep SQL Fiddle berikut menunjukkan penggunaan fungsi row_number() untuk jana nombor baris berjujukan:

import sqlalchemy

# Create a test table
engine = sqlalchemy.create_engine('postgresql://postgres:my_password@localhost:5432/test_db')
metadata = sqlalchemy.MetaData()
table = sqlalchemy.Table('test_table', metadata,
    sqlalchemy.Column('id', sqlalchemy.Integer, primary_key=True),
    sqlalchemy.Column('name', sqlalchemy.String(255)),
    sqlalchemy.Column('score', sqlalchemy.Float),
)
metadata.create_all(engine)

# Insert some data into the table
insert_data = [
    {'id': 1, 'name': 'John', 'score': 90},
    {'id': 2, 'name': 'Jane', 'score': 85},
    {'id': 3, 'name': 'Bob', 'score': 95},
]
insert = table.insert().values(insert_data)
engine.execute(insert)

# Query the table with row numbers
select_query = sqlalchemy.select([
    sqlalchemy.func.row_number().over().label('rownum'),
    table.c.id,
    table.c.name,
    table.c.score,
]).order_by(table.c.id)
results = engine.execute(select_query).fetchall()

# Print the results
for result in results:
    print(f"Row {result.rownum}: {result.id}, {result.name}, {result.score}")

Atas ialah kandungan terperinci Bagaimana untuk Menjana Nombor Baris Berjujukan dalam Pertanyaan PostgreSQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn