„MySQL“ „Jei tada“ pareiškimai

Mysql If Then Statements



„IF“ deklaracija dažnai naudojama išsaugotose „MySQL“ programose, kurios užtikrina paprastą sąlyginę konstrukciją. IF-THEN sakinys leidžia atlikti SQL sakinių seriją pagal nurodytą sąlygą. Pateikiama tiesa, klaidinga arba NULL kaip viena iš trijų verčių. Šiame vadove mes suprasime, kaip apdoroti SQL komandos dalį, susijusią su tam tikra sąlyga, naudojant „MySQL IF-then“ teiginį.

Sintaksė:

>>IF sąlyga THEN teiginiai PABAIGA IF;

Šioje sintaksėje:





  • Jei tai' s raktinių žodžių sąlyga sąlygai pradėti.
  • Būklė : Po „IF“ sąlygos tai turi būti įvykdytas apribojimas.
  • Pareiškimai : Gali būti bet koks kodo fragmentas, pvz., Pasirinkti, gauti, atnaujinti, ištrinti. Jei sąlyga vertinama kaip TIESA, tada bus įvykdyti teiginiai po „THEN“ sąlygos.
  • PABAIGA: Tai „IF“ sąlygos pabaiga. Po to galia perkeliama į kitą punktą.

Pradėkime suprasti „If-then“, paleisdami „MySQL“ komandų apvalkalą. Įvedę slaptažodį, esame pasiruošę eiti.





01 pavyzdys: „MySQL IF“ () funkcija:

Norėdami įgyti žinių apie If teiginį, pirmiausia turime išbandyti IF () funkciją. Žemiau esančiame pavyzdyje SELECT užklausoje apibrėžėme funkciją IF () ir nustatėme jai sąlygą, kad patikrintume, ar 2 yra didesnis nei 9, ar ne. Jei sąlyga galioja, ji grąžina pirmąją reikšmę po sąlygos; antraip. Kadangi mūsų sąlyga negalioja, ji grąžina „klaidingą“.





Tarkime, lentelės „tvarka“, kaip parodyta pridėtame paveikslėlyje.



>>PASIRINKTI*FROM data.order;

Pažvelkime į šioje lentelėje atliktą funkciją IF (). Mes pasirinkome tris stulpelius. Jei stulpelio „Būsena“ vertė yra „Mokama“, IF () metodas grąžins „Puikus“, kitaip - „Blogas“. Funkcijos IF () grąžinta vertė bus išsaugota naujai paleidimo metu sukurtame stulpelyje „Pastabos“. Dabar galime pamatyti išvestį, kaip pridėta žemiau.

02 pavyzdys: MySQL IF-THEN teiginys

Mes išbandėme IF () funkciją MySQL komandinėje eilutėje. Išbandykime naują IF-Then teiginio pavyzdį MySQL GUI, naudodami procedūras. Atidarykite „MySQL Workbench 8.0“ ir pirmiausia prisijunkite prie duomenų bazės.

Mes dirbome prie duomenų bazės „duomenys“; tada, norėdami juos naudoti „Workbench“, turite nurodyti komandą „use data“. Norėdami tai padaryti, paspauskite blykstės piktogramą. Turite žinoti, kad teiginiai „Jei tada“ veikia su parduotuvės procedūromis, kaip parodyta žemiau. Norėdami pradėti parduotuvės procedūrą, paskelbėme raktinių žodžių skiriamąjį ženklą. Procedūra „myResult“ remiasi dviem argumentais. Po BEGIN sakinio turime IF teiginį, kuris tikrina būklę. Jei sąlyga tenkinama, komanda „THEN“ ir jos nurodymas bus vykdomi. Jei sąlyga bus klaidinga, bus įvykdyti teiginiai po „END IF“.

Kadangi procedūra „myResult“ turi du argumentus, turime į ją įtraukti dvi vertes.

Perdavę vertes į parduotuvės procedūrą, turime iškviesti procedūrą, kad pamatytume teiginio „Jei tada“ rezultatus.

Ir rezultatas pateiktas žemiau. Ji apskaičiavo nuolaidą_kaite per „If-then“ teiginį.

Jei norite dar kartą naudoti tą pačią išsaugotą procedūrą, pirmiausia turite atsisakyti šios procedūros naudodami toliau pateiktą komandą DROP ir tada ją pakartoti.

03 pavyzdys: MySQL IF-THEN-ELSE teiginys

Eikime į platų lygį. Šį kartą pažvelgsime į IF-then-Else teiginį, naudodami mūsų pavyzdyje išsaugotą procedūrą. Pažvelkite į žemiau esančią lentelę „studentas“ su kai kuriais laukais.

>>PASIRINKTI*IŠ duomenų. Studentas;

Pirmiausia, norėdami naudoti lentelę „studentas“ mūsų parduotuvės procedūroje, turite naudoti duomenų bazę „duomenys“. Norėdami tai padaryti, įveskite žemiau esančią komandą „MySQL“ komandų eilutės terminale.

>>naudoti duomenis;

Dabar paskelbkite ribotuvą ir pradėkite rašyti saugojimo procedūrą. „CREATE“ komanda bus naudojama kaip visada deklaruoti arba sukurti procedūrą. Procedūros „detalės“ buvo pagrįstos dviem argumentais. Po to parduotuvės procedūra prasideda raktažodžiu „BEGIN“. Žodis „DECLARE“ buvo naudojamas tiriamųjų kintamajam „Sub“ apibrėžti. Užklausa „SELECT“ buvo naudojama lentelės „studentas“ stulpelio „Tema“ reikšmėms pasirinkti ir išsaugoti naujai paskelbtame kintamajame „Sub“. Vartotojo pateikta vertė „S_Subject“ bus lyginama su stulpelio „Subject“ verte. „IF“ teiginyje, jei vartotojo pateikta vertė „S_Subject“ sutampa su stulpelio „Subject“ verte, tada santykinis „THEN“ teiginys bus vykdomas kartu su jo teiginiais. Ši procedūra bus apdorota nuo pirmojo „IF“ teiginio iki antrojo, tada trečiojo „ELSEIF“ teiginio. Jei paskutinė „ELSEIF“ dalis nesutampa su vartotojo pateikta verte, tada valdoma „END IF“.

Užbaikime ribotuvą naudodami žemiau pateiktą komandą.

Turime iškviesti parduotuvės procedūrą, vykdydami ją su „CALL“ užklausa ir skliausteliuose pateikdami argumentus. Kaip vertę nurodėme „Matematika“, bus sugeneruotas naujas stulpelis, kad būtų išvestos „THEN“ ir „SET“ frazės.

Patikrinkite naujai sukurtą stulpelį „S_Cource“ naudodami žemiau esančią komandą. Matote, kad turime atitinkamą rezultatą pagal kursą „Matematika“.

Dar kartą iškvieskite procedūrą pakeisdami pirmąjį argumentą, ty temą. Šį kartą pateikėme temą „Kompiuteris“.

Pasirinkdami stulpelio „S_Cource“ vertę, matote, kad turime reikšmę, susijusią su tema „Kompiuteris“, kuri yra „IT“.

Dar kartą mes iškvietėme procedūrą, kaip nurodyta toliau, pakeisdami pirmąjį argumentą. Šį kartą pristatėme temą „Istorija“.

Dar kartą paskambinę į stulpelį „S_Cource“, galite pamatyti, kaip mes turime rezultatą „Meistrai istorijoje“, susijusį su neseniai pateikta tema, pvz., Istorija.

Išvada:

Mes padarėme visus pavyzdžius, reikalingus teiginiams „jei tada“ parengti, pvz., Funkciją IF (), paprastą teiginį, jei tada paprastą teiginį, jei tada kitą teiginį.