मैं जांचें कि उपयोगकर्ता या पासवर्ड वैध नहीं है, उन मानकों को आउट पैरामीटर में अगर उपयोगकर्ता और वैध में पासवर्ड, लेकिन अगर सफलता, आपको इसके लिए निश्चित रूप से यह एक पंक्ति का चयन करने की कोशिश करता है जहां यूजरनेम और ई-मेल IUsername और पासवर्ड के बराबर होती है Iaspassword के बराबर होती है और आउटपुट वैरिएबल के लिए दो मान आउटपुट करती है। जिस तरह से यह यहां < / Strong> डेमो व्यक्तिगत रूप से मैं आगे बढ़ता हूं और इसे थोड़ा सा सरल बना देता हूं और इसे एक इंटरफ़ेस के साथ एक-स्पष्टीकरण सपा बनाती हूं: यह विचार है कि यह उपयोगकर्ता के लिए उपयुक्त संदेश बनाने के लिए एक प्रस्तुति स्तर का कार्य है और उन सभी संदेशों को नहीं छींटा डेटा परत में लिखेक्स। यहां डेमो है संसाधित प्रक्रियाओं में
MySQL डेटाबेस के साथ लॉगिन प्रमाणीकरण कार्य कर रहा हूं। नीचे कोड है, मैंने लिखा है लेकिन इसका काम नहीं कर रहा है। मुझे पता है, क्या गलत है।
मेरे पास प्रश्न हैं
CURSOR है
खाली या
null
मैं क्या कर रहा हूं ..
इनपुट पैरामीटर और
ouput के लिए दो पैरामीटर लेना।
SELECT 'अमान्य प्रयोक्तानाम और पासवर्ड', 'शून्य' संदेश में, ओयूएसएआरआईडी;
isActive स्तंभ
0 तो
चुनें 'निष्क्रिय खाता', 'अशक्त' oMessage, oUserID में है;
का चयन करें 'सफल', v_UserID जांच oMessage, oUserID;
एसक्यूएल कोड <> <कोड pre> परिसीमक का उपयोग $$ `acl` $$ Definer = बनाएँ` FreeUser` @ `localhost` प्रक्रिया` acl`.`checkAuthenticationTwo` (iUsername VARCHAR में (50), iPassword VARCHAR में (50), बाहर ओ संदेश VARCHAR (50), OUserID INT आउट करें) DECLARE v_isActive INT; DECLARE v_UserID INT; DECLARE v_count INT; का चयन करें UserID, m_users से IsActive लिए cur1 कर्सर घोषणा कहां (LOGINNAME = TRIM (iUsername) या ईमेल = TRIM (iUsername)) और `Password` = iPassword; ओपन क्यूअर 1; सेट v_count = (SELECT FOUND_ROWS ()); यदि (v_count & gt; 0) वीएयूयूआईएसआईडीआईडी, वी_आईएसएक्टिव; यदि (v_isActive = 0) तो 'निष्क्रिय खाता' का चयन करें, 'शून्य' में संदेश, ओयूएसएआरआईडी; इसके बाद 'सफलता' का चयन करें, वी_यूएसआरआईडी में ओमेसेज, ओयूएसएआरआईडी; अगर अंत; चयन करें 'अमान्य उपयोगकर्ता नाम और पासवर्ड', 'शून्य' में संदेश, ओयूएसएआरआईडी; अगर अंत; END $ $ DELIMITER;
CURSOR s की आवश्यकता नहीं है ; सादे सरल
SELECT का उपयोग करें के अपने सपा एक अधिक संक्षिप्त संस्करण कैसा लग सकता है
परिसीमक $$ Definer = बनाएँ `FreeUser` @` localhost` प्रक्रिया `acl`.`checkAuthenticationTwo` (iUsername VARCHAR में (50), में iPassword VARCHAR (50), बाहर oMessage VARCHAR (50), बाहर oUserID INT) का चयन करें मामला शुरू करते IsActive = 0 फिर 'निष्क्रिय खाता' शेष 'सफल' अंत, मामला है जब IsActive = 0 तब शून्य oMessage, से oUserID जांच और के UserID अंत M_users जहां (लॉगिन नाम = = TRIM (iUsername) या ईमेल = TRIM (iUsername)) और `पासवर्ड` = iPassword LIMIT 1; - आप बेहतर डुप्लिकेट से खुद को सुरक्षित रख सकते हैं SET oMessage = IFNULL (oMessage, 'अमान्य उपयोगकर्ता नाम और पासवर्ड'); END $ $ DELIMITER;
का उपयोग करता है का उपयोग करने के लिए है एक्टिव वैल्यू यदि यह
0 है, तो उपयोगकर्ता के लिए 'निष्क्रिय' और नल के लिए एक संदेश सेट करता है। अन्यथा यह 'सफलता' संदेश और वास्तविक यूजर आईडी लौटाता है। अब, यदि उपयोगकर्ता को नहीं मिला है तो दोनों चर को नल पर सेट किया जाएगा। हम इसका लाभ उठा सकते हैं और उस तथ्य का पता लगाने और 'अमान्य उपयोगकर्ता नाम और पासवर्ड' को सेट करने के लिए
IFNULL () फ़ंक्शन का उपयोग कर सकते हैं।
रिटर्न: यूजरआड (जो है & gt; 0) अगर उपयोगकर्ता उपयोगकर्ता नाम और पासवर्ड यदि 0 - उपयोगकर्ता नाम और (या) पासवर्ड गलत है -1 - कोई उपयोगकर्ता निष्क्रिय है
बनायें DEFINER = 'फ्रीयूसर' @ 'लोकलहोस्ट' प्रक्रिया 'एसीएल'। 'चेकऑक्टिफिकेशन थ्री' (आईयूयूएन नाम वीएआरएआर (50), आईपैसवर्ड वीएआरएआर (50) में, ओयूसीआरआईडी आउट INT) SET oUserID = IFNULL ((चयन का मामला जब IActive = 0 THEN -1 ELSE UserID अंत से m_users जहां (लॉगिन नाम = TRIM (iUsername) या ईमेल = TRIM (iUsername)) और `पासवर्ड` = iPassword LIMIT 1 - आप बेहतर तुम्हारी रक्षा डुप्लिकेट से च), 0);
No comments:
Post a Comment