Saya mempunyai dua program yang kelihatan hampir sama. Seorang menerima Lokasi dan Harga dan menjalankan operasi, seorang lagi menerima Pengalaman dan Harga. < /p>
Yang pertama:
-- Returns: service providers in given location and price DELIMITER && CREATE PROCEDURE get_service_providers_location_price (IN id_location INT,IN price DOUBLE,IN limite INT, IN inicio INT) BEGIN SELECT user.idUser, user.name,user.lastActivity,user.active,serviceprovider.description,location.name AS location, location.cordsX, location.cordsY, file.image FROM user INNER JOIN location ON user.idLocation = location.idLocation INNER JOIN file ON user.idUser = file.idUser INNER JOIN serviceprovider ON user.idUser = serviceprovider.idSP INNER JOIN category_has_serviceprovider ON serviceprovider.idSP = category_has_serviceprovider.idServiceProvider WHERE user.type = 3 AND user.idLocation = id_location AND (category_has_serviceprovider.price <= price OR category_has_serviceprovider.price IS NULL) and serviceprovider.idSubscription != 1 ORDER BY CASE WHEN serviceprovider.idSubscription in (5,6,7) then 1 else 2 end, serviceprovider.endSub ASC LIMIT limite OFFSET inicio; END && DELIMITER ;
Kedua:
-- Returns: service providers in given experience and price DELIMITER && CREATE PROCEDURE get_service_providers_experience_price (IN experience INT, IN price DOUBLE,IN limite INT, IN inicio INT) BEGIN SELECT user.idUser, user.name,user.lastActivity,user.active,serviceprovider.description,location.name AS location, location.cordsX, location.cordsY, file.image FROM user INNER JOIN location ON user.idLocation = location.idLocation INNER JOIN file ON user.idUser = file.idUser INNER JOIN serviceprovider ON user.idUser = serviceprovider.idSP INNER JOIN category_has_serviceprovider ON serviceprovider.idSP = category_has_serviceprovider.idServiceProvider WHERE user.type = 3 AND (category_has_serviceprovider.price <= price OR category_has_serviceprovider.price IS NULL) AND category_has_serviceprovider.experience >= experience and serviceprovider.idSubscription != 1 ORDER BY CASE WHEN serviceprovider.idSubscription in (5,6,7) then 1 else 2 end, serviceprovider.endSub ASC LIMIT limite OFFSET inicio; END && DELIMITER ;
Seperti yang anda lihat, hanya klausa WHERE sahaja yang telah berubah. Dalam MySQL, adakah mungkin untuk mengagregatkan kedua-dua prosedur ini menjadi satu? Kerana saya mempunyai kira-kira 5 program yang kelihatan sama tetapi ia hanya berubah Klausa WHERE, saya rasa menjengkelkan untuk melakukan proses berasingan untuk setiap kes.
Anda boleh menggunakan IFNULL. Lulus
experience
或id_location
值并使用NULL
sebagai nilai lain.Adalah juga amalan yang baik untuk mempunyai skema penamaan (di sini
in_
-prefix) untuk parameter supaya parameter berbeza daripada nama lajur.Sebagai contoh, anda boleh menggunakan ini:
Jika disediakan
IN 经验 INT
设置为某个值,则应用它的条件。如果您为此参数提供 NULL,则应用IN id_location INT
syarat.NOTA - SP anda kini mempunyai 5 parameter dan bukannya 4.
PS. SP anda mengandungi satu pernyataan SQL - jadi BEGIN-END dan DELIMITER tidak diperlukan.PPS. Menggunakan pendekatan yang serupa, anda boleh mencipta SP yang menggunakan satu, kedua-duanya, atau kedua-dua syarat. Contohnya, boleh jadi:
Pariti kuasa beli. Jika anda ingin mempunyai 2 fungsi berasingan tetapi mempunyai salinan kod (contohnya, nama fungsi ini telah digunakan dalam sekumpulan kod), maka anda boleh melakukan ini: