Apabila membuat prosedur tersimpan, anda mungkin menghadapi kesukaran menggunakan hasil ungkapan sebagai parameter. Berikut ialah contoh:
<code class="language-sql">DECLARE @pID int; SET @pID = 1; EXEC WriteLog 'Component', 'Source', 'Could not find given id: ' + CAST(@pID AS varchar);</code>
Walau bagaimanapun, kod ini menimbulkan ralat (SQL Server 2005):
<code>Msg 102, Level 15, State 1, Line 4 Incorrect syntax near '+'.</code>
Penjelasan ralat tatabahasa
SQL Server tidak membenarkan operasi sedemikian dalam senarai parameter. Ia menjangkakan hujah ialah nilai literal, pembolehubah yang diisytiharkan atau ungkapan tanpa pengendali.
Penyelesaian: Gunakan pembolehubah perantaraan
Untuk menyelesaikan masalah ini, anda mesti menggunakan pembolehubah perantaraan. Kod yang diperbetulkan di bawah menunjukkan pendekatan ini:
<code class="language-sql">DECLARE @pID INT; SET @pID = 1; DECLARE @logMessage VARCHAR(50) = 'Could not find given id: ' + CAST(@pID AS VARCHAR(11)); EXEC WriteLog 'Component', 'Source', @logMessage;</code>
Sintaks pernyataan Exec
Untuk rujukan, sintaks pernyataan EXEC adalah seperti berikut:
<code class="language-sql">[ { EXEC | EXECUTE } ] { [ @return_status = ] { module_name [ ;number ] | @module_name_var } [ [ @parameter = ] { value | @variable [ OUTPUT ] | [ DEFAULT ] } ] [ ,...n ] [ WITH <execute_option> [ ,...n ] ] } [;]</execute_option></code>
Batasan Semasa
Dalam SQL Server, nilai yang boleh diterima untuk parameter dalam senarai parameter dihadkan kepada nilai literal dan fungsi sistem yang diawali dengan @@. Fungsi seperti SCOPE_IDENTITY() tidak disokong.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Meluluskan Hasil Ungkapan sebagai Parameter kepada Prosedur Tersimpan Pelayan SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!