Rumah >pangkalan data >tutorial mysql >Fungsi Tunggal lwn. Fungsi Berasingan untuk Kemas Kini PostgreSQL: Mana Yang Lebih Cekap?
Dalam PostgreSQL, prosedur (fungsi) tersimpan memberikan fleksibiliti dalam manipulasi pangkalan data. Apabila bekerja dengan parameter input yang berbeza-beza, anda mungkin mempersoalkan pendekatan terbaik antara menggunakan fungsi tunggal dengan parameter mod atau fungsi berasingan untuk tujuan yang berbeza. Memahami pilihan dan kecekapannya adalah penting untuk pengurusan pangkalan data yang berkesan.
Pertimbangkan kod berikut, yang melaksanakan fungsi dengan parameter mod untuk mengawal kemas kini tingkah laku:
CREATE OR REPLACE FUNCTION update_site( mode integer, name character varying, city character varying, telephone integer, ) RETURNS integer AS $$ BEGIN IF mode = 0 THEN UPDATE "Sites" SET ("City","Telephone") = (city,telephone) WHERE "SiteName" = name; RETURN 1; ELSIF mode = 1 THEN UPDATE "Sites" SET "City" = city WHERE "SiteName" = name; RETURN 1; ELSIF mode = 2 THEN UPDATE "Sites" SET "Telephone" = telephone WHERE "SiteName" = name; RETURN 1; ELSE RAISE NOTICE 'Error on site update: %, %', SQLERRM, SQLSTATE; RETURN 0; END IF; END; $$ LANGUAGE plpgsql;
Pilihan ini membolehkan anda mengendalikan senario kemas kini yang berbeza dalam satu fungsi, tetapi ia boleh menjadi rumit dan terdedah kepada ralat apabila bilangan mod bertambah.
Sebagai alternatif, anda boleh mencipta fungsi individu untuk tujuan tertentu, seperti:
CREATE OR REPLACE FUNCTION update_site_name_city( name character varying, city character varying ) RETURNS integer AS $$ BEGIN UPDATE "Sites" SET "City" = city WHERE "SiteName" = name; RETURN 1; END; $$ LANGUAGE plpgsql; CREATE OR REPLACE FUNCTION update_site_telephone( name character varying, telephone integer ) RETURNS integer AS $$ BEGIN UPDATE "Sites" SET "Telephone" = telephone WHERE "SiteName" = name; RETURN 1; END; $$ LANGUAGE plpgsql;
Pendekatan ini memudahkan penyelenggaraan dan kebolehbacaan, kerana setiap fungsi dikhaskan untuk tugas tertentu. Walau bagaimanapun, ia memerlukan lebih banyak fungsi, yang boleh meningkatkan kerumitan kod.
Kecekapan kedua-dua pilihan bergantung pada keperluan khusus aplikasi anda. Fungsi berasaskan mod mungkin lebih pantas sedikit untuk kemas kini mudah dengan bilangan mod yang kecil. Walau bagaimanapun, untuk kemas kini yang kompleks atau sejumlah besar mod, fungsi berasingan boleh menjadi lebih cekap dan berskala.
Pilihan antara fungsi berasaskan mod tunggal atau fungsi berasingan bergantung pada perkara berikut faktor:
Pertimbangkan faktor ini dengan teliti untuk menentukan pendekatan terbaik untuk anda permohonan.
Atas ialah kandungan terperinci Fungsi Tunggal lwn. Fungsi Berasingan untuk Kemas Kini PostgreSQL: Mana Yang Lebih Cekap?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!