Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Melewati Parameter ke Paparan dalam Pelayan SQL?

Bagaimanakah Saya Boleh Melewati Parameter ke Paparan dalam Pelayan SQL?

DDD
DDDasal
2024-12-26 01:58:10557semak imbas

How Can I Pass Parameters to Views in SQL Server?

Melalui Parameter dalam Paparan dalam SQL

Tidak seperti prosedur tersimpan, paparan dalam SQL Server tidak membenarkan penghantaran parameter langsung. Ini boleh menjadi pengehadan apabila perlu menapis data berdasarkan kriteria yang ditentukan pengguna.

Satu percubaan penyelesaian untuk isu ini ialah membuat paparan dengan parameter, seperti yang dilihat di bawah:

create or replace view v_emp(eno number) as select * from emp where emp_id=&eno;

Walau bagaimanapun, ini tidak akan berfungsi dalam SQL Server.

Penyelesaian Alternatif: Disimpan Fungsi

Pendekatan alternatif untuk menghantar parameter kepada kefungsian seperti paparan ialah mencipta fungsi tersimpan. Fungsi tersimpan boleh ditakrifkan dengan parameter input dan boleh mengembalikan jadual sebagai set keputusannya.

Berikut ialah contoh fungsi tersimpan yang boleh bertindak sebagai paparan berparameter:

CREATE FUNCTION v_emp (@pintEno INT)
RETURNS TABLE
AS
RETURN
   SELECT * FROM emp WHERE emp_id=@pintEno;

Ini fungsi yang disimpan mengambil parameter integer @pintEno dan mengembalikan jadual dengan pekerja yang sepadan dengan ID tersebut.

Untuk menggunakan fungsi yang disimpan, anda boleh memanggilnya seperti pandangan:

SELECT * FROM v_emp(10)

Ini akan mengembalikan semua pekerja dengan emp_id sebanyak 10.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Melewati Parameter ke Paparan dalam Pelayan SQL?. 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