Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Menjana Nombor Baris Berjujukan dalam Pertanyaan PostgreSQL?
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:
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!