Mysql
 sql >> Teknologi Basis Data >  >> RDS >> Mysql

Melewati nama kolom sebagai parameter dalam fungsi tersimpan mysql

Ada beberapa masalah dengan pendekatan Anda. Pertama-tama Anda tidak dapat menggunakan argumen Anda nilai untuk referensi kolom yang mendasarinya. Untung Anda dapat menggunakan Pernyataan yang Disiapkan sebagai solusi untuk ini.

Masalah kedua adalah bahwa fungsi MySQL tidak mengizinkan penggunaan Pernyataan yang Disiapkan. Untuk mengatasi batasan itu, Anda perlu menggunakan Prosedur Tersimpan. Sebagai contoh:

CREATE PROCEDURE test_func (IN col1 varchar(100), OUT res int)
BEGIN

SET @s=CONCAT('SELECT ',col1,' INTO @res FROM yourtable WHERE id=1');
PREPARE stmt1 FROM @s;
EXECUTE stmt1;
DEALLOCATE PREPARE stmt1;

SELECT @res INTO res;

END


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Cara mengatur MySQL di IBM Worklight

  2. PHP dan MySQL Kurangi Detik Dari Waktu

  3. cara mendapatkan nilai dalam array dari kueri individual

  4. Menggunakan MySQL dengan Entity Framework

  5. node.js kumpulan mysql mulaiTransaksi &koneksi