MySQLi - क्विक गाइड

डेटाबेस क्या है?

एक डेटाबेस एक अलग अनुप्रयोग है जो डेटा का संग्रह संग्रहीत करता है। प्रत्येक डेटाबेस में उस डेटा को बनाने, उस तक पहुंचने, प्रबंधन, खोज और प्रतिकृति बनाने के लिए एक या अधिक विशिष्ट एपीआई होते हैं।

अन्य प्रकार के डेटा स्टोर का उपयोग किया जा सकता है, जैसे कि फ़ाइल सिस्टम पर फाइलें या मेमोरी में बड़ी हैश टेबल लेकिन डेटा लाना और लिखना उन प्रकार के सिस्टम के साथ इतना तेज़ और आसान नहीं होगा।

इसलिए आजकल, हम डेटा की विशाल मात्रा को संग्रहीत और प्रबंधित करने के लिए रिलेशनल डेटाबेस मैनेजमेंट सिस्टम (RDBMS) का उपयोग करते हैं। इसे संबंधपरक डेटाबेस कहा जाता है क्योंकि सभी डेटा को विभिन्न तालिकाओं में संग्रहीत किया जाता है और संबंधों को प्राथमिक कुंजी या विदेशी कुंजी के रूप में जाना जाता है।

Relational DataBase Management System (RDBMS) एक सॉफ्टवेयर है कि -

  • आपको तालिकाओं, स्तंभों और अनुक्रमित के साथ एक डेटाबेस को लागू करने में सक्षम बनाता है।

  • विभिन्न तालिकाओं की पंक्तियों के बीच संदर्भात्मक अखंडता की गारंटी देता है।

  • अनुक्रमणिका को स्वचालित रूप से अद्यतन करता है।

  • एक SQL क्वेरी की व्याख्या करता है और विभिन्न तालिकाओं से जानकारी को जोड़ता है।

RDBMS शब्दावली

इससे पहले कि हम MySQLi डेटाबेस सिस्टम की व्याख्या करने के लिए आगे बढ़ें, आइए डेटाबेस से संबंधित कुछ परिभाषाओं को संशोधित करें।

  • Database - एक डेटाबेस संबंधित डेटा के साथ तालिकाओं का एक संग्रह है।

  • Table- एक तालिका डेटा के साथ एक मैट्रिक्स है। डेटाबेस में एक तालिका एक साधारण स्प्रेडशीट की तरह दिखती है।

  • Column - एक कॉलम (डेटा एलिमेंट) में एक और एक ही तरह का डेटा होता है, उदाहरण के लिए कॉलम पोस्टकोड।

  • Row - एक पंक्ति (= टपल, प्रविष्टि या रिकॉर्ड) संबंधित डेटा का एक समूह है, उदाहरण के लिए एक सदस्यता का डेटा।

  • Redundancy - डेटा को दो बार स्टोर करना, सिस्टम को तेज बनाने के लिए अनावश्यक रूप से।

  • Primary Key- एक प्राथमिक कुंजी अद्वितीय है। एक कुंजी मान एक तालिका में दो बार नहीं हो सकता है। एक कुंजी के साथ, आप अधिकतम एक पंक्ति में पा सकते हैं।

  • Foreign Key - एक विदेशी कुंजी दो तालिकाओं के बीच लिंकिंग पिन है।

  • Compound Key - एक यौगिक कुंजी (समग्र कुंजी) एक कुंजी है जिसमें कई कॉलम होते हैं, क्योंकि एक कॉलम पर्याप्त रूप से अद्वितीय नहीं है।

  • Index - डेटाबेस में एक इंडेक्स एक किताब के पीछे एक इंडेक्स जैसा दिखता है।

  • Referential Integrity - रेफ़रेंशियल इंटीग्रिटी सुनिश्चित करता है कि एक विदेशी कुंजी हमेशा मौजूदा पंक्ति को इंगित करती है।

MySQLi डेटाबेस

MySQLi एक तेज, आसानी से उपयोग होने वाला RDBMS है जो कई छोटे और बड़े व्यवसायों के लिए उपयोग किया जा रहा है। MySQLi Extension MySQL द्वारा विकसित, विपणन और समर्थित है। कई अच्छे कारणों की वजह से MySQL इतना लोकप्रिय हो रहा है -

  • MySQLi एक ओपन-सोर्स लाइसेंस के तहत जारी किया गया है। इसलिए आपके पास इसका उपयोग करने के लिए कुछ भी नहीं है।

  • MySQLi अपने आप में एक बहुत शक्तिशाली कार्यक्रम है। यह सबसे महंगे और शक्तिशाली डेटाबेस पैकेजों की कार्यक्षमता का एक बड़ा सबसेट संभालता है।

  • MySQLi प्रसिद्ध SQL डेटा भाषा के मानक रूप का उपयोग करता है।

  • MySQLi कई ऑपरेटिंग सिस्टम पर और PHP, PERL, C, C ++, JAVA, आदि सहित कई भाषाओं के साथ काम करता है।

  • MySQLi बहुत जल्दी काम करता है और बड़े डेटा सेट के साथ भी अच्छा काम करता है।

  • MySQLi PHP के लिए बहुत अनुकूल है, वेब विकास के लिए सबसे अधिक सराहना की जाने वाली भाषा है।

  • MySQLi बड़े डेटाबेस का समर्थन करता है, एक तालिका में 50 मिलियन पंक्तियों या अधिक तक। तालिका के लिए डिफ़ॉल्ट फ़ाइल आकार सीमा 4GB है, लेकिन आप इसे (यदि आपका ऑपरेटिंग सिस्टम इसे संभाल सकते हैं) 8 मिलियन टेराबाइट्स (टीबी) की सैद्धांतिक सीमा तक बढ़ा सकते हैं।

  • MySQLi अनुकूलन योग्य है। ओपन-सोर्स जीपीएल लाइसेंस प्रोग्रामर को अपने विशिष्ट वातावरण में फिट होने के लिए MySQL सॉफ्टवेयर को संशोधित करने की अनुमति देता है।

शुरू करने से पहले

इस ट्यूटोरियल को शुरू करने से पहले, आपको हमारे PHP और HTML ट्यूटोरियल्स में शामिल जानकारी का बेसिक ज्ञान होना चाहिए।

यह ट्यूटोरियल PHP वातावरण में MySQLi का उपयोग करने पर बहुत अधिक ध्यान केंद्रित करता है। इस ट्यूटोरियल में दिए गए कई उदाहरण PHP प्रोग्रामर के लिए उपयोगी होंगे।

हम आपको अपने संदर्भ के लिए हमारे PHP ट्यूटोरियल की जांच करने की सलाह देते हैं ।

MySQL डाउनलोड करना

MySQLi एक्सटेंशन को MySQL संस्करण 4.1.13 या नए के साथ काम करने के लिए डिज़ाइन किया गया है, इसलिए MySQL डाउनलोड करना होगा। MySQL के सभी डाउनलोड MySQL डाउनलोड में स्थित हैं । MySQL कम्युनिटी सर्वर के लिए नवीनतम संस्करण संख्या चुनें जिसे आप चाहते हैं और, जितना संभव हो सके, वह प्लेटफ़ॉर्म जो आप चाहते हैं।

लिनक्स / यूनिक्स पर MySQL स्थापित करना

लिनक्स सिस्टम पर MySQL स्थापित करने का अनुशंसित तरीका RPM के माध्यम से है। MySQL AB अपनी वेब साइट पर निम्नलिखित RPM को डाउनलोड के लिए उपलब्ध कराता है -

  • MySQL - MySQL डेटाबेस सर्वर, जो डेटाबेस और टेबल का प्रबंधन करता है, उपयोगकर्ता अभिगम को नियंत्रित करता है, और SQL प्रश्नों को प्रोसेस करता है।

  • MySQL-client - MySQL क्लाइंट प्रोग्राम, जो सर्वर से कनेक्ट और इंटरैक्ट करना संभव बनाते हैं।

  • MySQL-devel - MySQL का उपयोग करने वाले अन्य कार्यक्रमों को संकलित करते समय लाइब्रेरी और हेडर फाइलें काम में आती हैं।

  • MySQL-shared - MySQL क्लाइंट के लिए साझा लाइब्रेरी।

  • MySQL-bench - बेंचमार्क और प्रदर्शन परीक्षण उपकरण MySQL डेटाबेस सर्वर के लिए।

यहां सूचीबद्ध MySQL RPM सभी एक SuSE Linux सिस्टम पर बनाए गए हैं, लेकिन वे आमतौर पर बिना किसी कठिनाई के अन्य Linux वेरिएंट पर काम करेंगे।

अब, स्थापना के लिए आगे बढ़ने के लिए निम्नलिखित चरणों का पालन करें -

  • सिस्टम का उपयोग कर लॉगिन करें root उपयोगकर्ता।

  • RPM युक्त निर्देशिका पर स्विच करें -

  • निम्नलिखित कमांड निष्पादित करके MySQL डेटाबेस सर्वर स्थापित करें। अपने RPM के फ़ाइल नाम के साथ इटैलिक में फ़ाइल नाम बदलना याद रखें।

[root@host]# rpm -i MySQL-5.0.9-0.i386.rpm

    ऊपर कमांड MySQL सर्वर को स्थापित करने, MySQL का उपयोगकर्ता बनाने, आवश्यक कॉन्फ़िगरेशन बनाने और स्वचालित रूप से MySQL सर्वर शुरू करने का ध्यान रखता है।

    आप सभी MySQL से संबंधित बायनेरिज़ / usr / bin और / usr / sbin में पा सकते हैं। सभी टेबल और डेटाबेस / var / lib / mysql डायरेक्टरी में बनाए जाएंगे।

  • यह शेष आरपीएम को उसी तरीके से स्थापित करने के लिए वैकल्पिक लेकिन अनुशंसित कदम है -

[root@host]# rpm -i MySQL-client-5.0.9-0.i386.rpm
[root@host]# rpm -i MySQL-devel-5.0.9-0.i386.rpm
[root@host]# rpm -i MySQL-shared-5.0.9-0.i386.rpm
[root@host]# rpm -i MySQL-bench-5.0.9-0.i386.rpm

विंडोज पर MySQL स्थापित करना

विंडोज के किसी भी संस्करण पर डिफ़ॉल्ट इंस्टॉलेशन अब पहले की तुलना में बहुत आसान है, क्योंकि MySQL अब इंस्टॉलर के साथ बड़े करीने से पैक किया गया है। बस इंस्टॉलर पैकेज डाउनलोड करें, इसे कहीं भी अनज़िप करें, और setup.exe चलाएं।

डिफ़ॉल्ट इंस्टॉलर setup.exe आपको तुच्छ प्रक्रिया के माध्यम से चलेगा और डिफ़ॉल्ट रूप से C: \ mysql के तहत सब कुछ स्थापित करेगा।

पहली बार कमांड प्रॉम्प्ट से फायर करके सर्वर का परीक्षण करें। Mysqld सर्वर के स्थान पर जाएँ जो संभवतः C: \ mysql \ bin है, और टाइप करें -

mysqld.exe --console

NOTE - यदि आप NT पर हैं, तो आपको mysqld.exe के बजाय mysqld-nt.exe का उपयोग करना होगा

यदि सब कुछ ठीक रहा, तो आपको स्टार्टअप और इनोबीडी के बारे में कुछ संदेश दिखाई देंगे। यदि नहीं, तो आपके पास अनुमतियां जारी हो सकती हैं। सुनिश्चित करें कि आपके डेटा को रखने वाली निर्देशिका जो भी उपयोगकर्ता (शायद mysql) डेटाबेस प्रक्रियाओं के तहत चलती है, के लिए सुलभ है।

MySQL खुद को स्टार्ट मेनू में नहीं जोड़ेगा, और सर्वर को रोकने के लिए कोई विशेष रूप से अच्छा GUI तरीका नहीं है। इसलिए, यदि आप mysqld निष्पादन योग्य पर डबल क्लिक करके सर्वर शुरू करते हैं, तो आपको mysqladmin, Task List, Task Manager, या अन्य Windows- विशिष्ट साधनों का उपयोग करके प्रक्रिया को हाथ से रोकना याद रखना चाहिए।

MySQL अधिष्ठापन का सत्यापन

MySQL सफलतापूर्वक स्थापित होने के बाद, बेस टेबल को इनिशियलाइज़ किया गया है, और सर्वर को शुरू किया गया है, आप यह सत्यापित कर सकते हैं कि यह सब कुछ सरल परीक्षणों के माध्यम से काम कर रहा है।

सर्वर स्थिति प्राप्त करने के लिए mysqladmin उपयोगिता का उपयोग करें

उपयोग mysqladminसर्वर संस्करण की जांच करने के लिए बाइनरी। यह बाइनरी लिनक्स पर / usr / bin में और विंडोज़ पर C: \ mysql \ bin में उपलब्ध होगा।

[root@host]# mysqladmin --version

यह लिनक्स पर निम्नलिखित परिणाम का उत्पादन करेगा। यह आपकी स्थापना के आधार पर भिन्न हो सकता है -

mysqladmin  Ver 8.23 Distrib 5.0.9-0, for redhat-linux-gnu on i386

यदि आपको ऐसा संदेश नहीं मिलता है, तो आपकी स्थापना में कुछ समस्या हो सकती है और इसे ठीक करने के लिए आपको कुछ मदद की आवश्यकता होगी।

MySQL क्लाइंट का उपयोग करके सरल SQL कमांड निष्पादित करें

आप MySQL क्लाइंट का उपयोग करके अपने MySQL सर्वर से कनेक्ट कर सकते हैं mysqlआदेश। इस समय, आपको कोई पासवर्ड देने की आवश्यकता नहीं है क्योंकि डिफ़ॉल्ट रूप से इसे रिक्त पर सेट किया जाएगा।

तो बस निम्नलिखित आदेश का उपयोग करें

[root@host]# mysql

इसे mysql> प्रॉम्प्ट से पुरस्कृत किया जाना चाहिए। अब, आप MySQL सर्वर से जुड़े हैं और आप mysql> प्रॉम्प्ट पर सभी SQL कमांड निष्पादित कर सकते हैं -

mysql> SHOW DATABASES;
+----------+
| Database |
+----------+
| mysql    |
| test     |
+----------+
2 rows in set (0.13 sec)

स्थापना के बाद के चरण

रूट MySQL उपयोगकर्ता के लिए एक खाली पासवर्ड के साथ MySQL जहाज। जैसे ही आपने डेटाबेस और क्लाइंट को सफलतापूर्वक स्थापित कर लिया है, आपको निम्नानुसार एक रूट पासवर्ड सेट करना होगा -

[root@host]# mysqladmin -u root password "new_password";

अब अपने MySQL सर्वर से संबंध बनाने के लिए, आपको निम्नलिखित कमांड का उपयोग करना होगा -

[root@host]# mysql -u root -p
Enter password:*******

UNIX उपयोगकर्ता आपकी PATH में MySQL डायरेक्टरी भी रखना चाहेंगे, इसलिए आपको हर बार जब आप कमांड-लाइन क्लाइंट का उपयोग करना चाहते हैं, तो आपको पूरा रास्ता लिखना नहीं पड़ेगा। बैश के लिए, यह कुछ इस तरह होगा -

export PATH = $PATH:/usr/bin:/usr/sbin

बूट समय पर MySQL चल रहा है

यदि आप बूट समय पर MySQL सर्वर चलाना चाहते हैं, तो सुनिश्चित करें कि आपके पास /etc/rc.local फाइल में प्रविष्टि है।

/etc/init.d/mysqld start

इसके अलावा, आपके पास /etc/init.d/ निर्देशिका में mysqld बाइनरी होनी चाहिए।

चल रहा है और MySQLi Server को बंद कर रहा है

MySQLi MySQL का विस्तारित है, इसलिए पहले जांचें कि आपका MySQL सर्वर चल रहा है या नहीं। इसे जांचने के लिए आप निम्न कमांड का उपयोग कर सकते हैं -

ps -ef | grep mysqld

यदि आपका MySql चल रहा है, तो आप देखेंगे mysqldआपके परिणाम में सूचीबद्ध प्रक्रिया। यदि सर्वर नहीं चल रहा है, तो आप निम्न कमांडो का उपयोग करके इसे शुरू कर सकते हैं

root@host# cd /usr/bin
./safe_mysqld &

अब, यदि आप पहले से चल रहे MySQL सर्वर को बंद करना चाहते हैं, तो आप निम्न कमांड का उपयोग करके इसे कर सकते हैं -

root@host# cd /usr/bin
./mysqladmin -u root -p shutdown
Enter password: ******

एक MySQLi उपयोगकर्ता खाते की स्थापना

MySQLi में एक नया उपयोगकर्ता जोड़ने के लिए जो MySQL का उन्नत संस्करण है, आपको बस एक नई प्रविष्टि जोड़ने की आवश्यकता है user डेटाबेस में तालिका mysql

नीचे नए उपयोगकर्ता को जोड़ने का एक उदाहरण है guest पासवर्ड के साथ SELECT, INSERT और UPDATE विशेषाधिकारों के साथ guest123; SQL क्वेरी है -

root@host# mysql -u root -p
Enter password:*******
mysql> use mysql;
Database changed

mysql> INSERT INTO user (
   host, user, password, select_priv, insert_priv, update_priv) 
   VALUES ('localhost', 'guest', PASSWORD('guest123'), 'Y', 'Y', 'Y');

Query OK, 1 row affected (0.20 sec)

mysql> FLUSH PRIVILEGES;
Query OK, 1 row affected (0.01 sec)

mysql> SELECT host, user, password FROM user WHERE user = 'guest';
+-----------+---------+------------------+
| host      | user    | password         |
+-----------+---------+------------------+
| localhost | guest | 6f8c114b58f2ce9e |
+-----------+---------+------------------+
1 row in set (0.00 sec)

नया उपयोगकर्ता जोड़ते समय, MySQL द्वारा प्रदान किए गए PASSWORD () फ़ंक्शन का उपयोग करके नए पासवर्ड को एन्क्रिप्ट करना याद रखें। जैसा कि आप उपरोक्त उदाहरण में देख सकते हैं कि पासवर्ड mypass 6f8c114b58f2ce9e पर एन्क्रिप्ट किया गया है।

FLUSH PRIVILEGES विवरण देखें। यह सर्वर को अनुदान तालिकाओं को फिर से लोड करने के लिए कहता है। यदि आप इसका उपयोग नहीं करते हैं, तो आप नए उपयोगकर्ता खाते का उपयोग करते हुए सर्वर रिबूट होने तक कम से कम mysql से कनेक्ट नहीं कर पाएंगे।

आप INSERT क्वेरी को निष्पादित करते समय उपयोगकर्ता तालिका में निम्नलिखित स्तंभों के मानों को 'Y' में सेट करके एक नए उपयोगकर्ता के लिए अन्य विशेषाधिकार भी निर्दिष्ट कर सकते हैं या आप बाद में UPDATE क्वेरी का उपयोग करके उन्हें अपडेट कर सकते हैं।

  • Select_priv
  • Insert_priv
  • Update_priv
  • Delete_priv
  • Create_priv
  • Drop_priv
  • Reload_priv
  • Shutdown_priv
  • Process_priv
  • File_priv
  • Grant_priv
  • References_priv
  • Index_priv
  • Alter_priv

उपयोगकर्ता का खाता जोड़ने का दूसरा तरीका GRANT SQL कमांड का उपयोग करके है; निम्नलिखित उदाहरण उपयोगकर्ता जोड़ देगाzara पासवर्ड के साथ zara123 नामक एक विशेष डेटाबेस के लिए TUTORIALS

root@host# mysql -u root -p password;
Enter password:*******
mysql> use mysql;
Database changed

mysql> GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP
   -> ON TUTORIALS.*
   -> TO 'zara'@'localhost'
   -> IDENTIFIED BY 'zara123';

यह mysql डेटाबेस तालिका नामक प्रविष्टि भी बनाएगा user

NOTE - SQL कमांड के अंत में जब तक आप एक अर्ध उपनिवेश (?) नहीं देते हैं तब तक MySQL एक कमांड को समाप्त नहीं करता है।

/Etc/my.cnf फ़ाइल कॉन्फ़िगरेशन

अधिकांश मामलों में, आपको इस फ़ाइल को नहीं छूना चाहिए। डिफ़ॉल्ट रूप से, इसमें निम्नलिखित प्रविष्टियाँ होंगी -

[mysqld]
datadir = /var/lib/mysql
socket = /var/lib/mysql/mysql.sock

[mysql.server]
user = mysql
basedir = /var/lib

[safe_mysqld]
err-log = /var/log/mysqld.log
pid-file = /var/run/mysqld/mysqld.pid

यहां, आप त्रुटि लॉग के लिए एक अलग निर्देशिका निर्दिष्ट कर सकते हैं, अन्यथा आपको इस तालिका में कोई प्रविष्टि नहीं बदलनी चाहिए।

प्रशासनिक MySQLi कमांड

यहां महत्वपूर्ण MySQLi कमांड की सूची दी गई है, जिन्हें आप MySQL डेटाबेस के साथ काम करने के लिए समय-समय पर उपयोग करेंगे -

  • USE Databasename - यह MySQLi workarea में एक विशेष डेटाबेस का चयन करने के लिए उपयोग किया जाएगा।

  • SHOW DATABASES - MySQLi DBMS द्वारा सुलभ डेटाबेस को सूचीबद्ध करता है।

  • SHOW TABLES - डेटाबेस में उपयोग कमांड के साथ चुने जाने के बाद डेटाबेस में तालिकाओं को दिखाता है।

  • SHOW COLUMNS FROM tablename - एक तालिका के लिए विशेषताओं, प्रकारों की विशेषताओं, महत्वपूर्ण जानकारी, चाहे NULL की अनुमति हो, चूक, और अन्य जानकारी दिखाता है।

  • SHOW INDEX FROM tablename - तालिका पर सभी सूचियों का विवरण प्रस्तुत करता है, जिसमें प्राथमिक कुंजी भी शामिल है।

  • SHOW TABLE STATUS LIKE tablename\G - MySQLi DBMS प्रदर्शन और आंकड़ों का विवरण।

MySQLi PERL, C, C ++, JAVA और PHP जैसी विभिन्न प्रोग्रामिंग भाषाओं के संयोजन में बहुत अच्छा काम करता है। इन भाषाओं में से, PHP अपनी वेब एप्लिकेशन डेवलपमेंट क्षमताओं के कारण सबसे लोकप्रिय है।

यह ट्यूटोरियल PHP वातावरण में MySQLi का उपयोग करने पर बहुत अधिक ध्यान केंद्रित करता है। PHP MySQLi डेटाबेस तक पहुँचने और MySQLi डेटाबेस के अंदर डेटा रिकॉर्ड में हेरफेर करने के लिए विभिन्न कार्य प्रदान करता है। आपको उसी तरह से PHP फ़ंक्शन को कॉल करना होगा जिस तरह से आप किसी अन्य PHP फ़ंक्शन को कॉल करते हैं।

MySQLi के साथ उपयोग के लिए PHP के कार्यों में निम्नलिखित सामान्य प्रारूप हैं -

mysqli_function(value,value,...);

फ़ंक्शन नाम का दूसरा भाग फ़ंक्शन के लिए विशिष्ट है, आमतौर पर एक शब्द जो फ़ंक्शन का वर्णन करता है। निम्नलिखित दो कार्य हैं, जिनका उपयोग हम अपने ट्यूटोरियल में करेंगे -

mysqli_connect($connect);
mysqli_query($connect,"SQL statement");

उदाहरण के बाद किसी भी MySQLi फ़ंक्शन को कॉल करने के लिए PHP का एक सामान्य वाक्यविन्यास दिखाता है।

<html>
   <head>
      <title>PHP with MySQLi</title>
   </head>
   
   <body>
      <?php
         $retval = mysqli_function(value, [value,...]);
         if( !$retval ){
            die ( "Error: a related error message" );
         }
         // Otherwise MySQLi  or PHP Statements
      ?>
   </body>
</html>

अगले अध्याय से शुरू, हम PHP के साथ सभी महत्वपूर्ण MySQLi कार्यक्षमता देखेंगे।

MySQLi कनेक्शन mysql बाइनरी का उपयोग कर

आप MySQLi डेटाबेस का उपयोग करके स्थापित कर सकते हैं mysql कमांड प्रॉम्प्ट पर बाइनरी।

उदाहरण

कमांड प्रॉम्प्ट से mysqli डेटाबेस स्थापित करने के लिए MySQL सर्वर से जुड़ने का एक सरल उदाहरण है -

[root@host]# mysql -u root -p
Enter password:******

यह आपको mysql> कमांड प्रॉम्प्ट देगा जहां आप किसी भी SQL कमांड को निष्पादित करने में सक्षम होंगे। निम्नलिखित आदेश का परिणाम है -

Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 2854760 to server version: 5.0.9

Type 'help;' or '\h' for help. Type '\c' to clear the buffer.

उपरोक्त उदाहरण में, हमने उपयोग किया है rootएक उपयोगकर्ता के रूप में लेकिन आप किसी अन्य उपयोगकर्ता का उपयोग कर सकते हैं। कोई भी उपयोगकर्ता सभी SQL संचालन करने में सक्षम होगा, जो उस उपयोगकर्ता को अनुमति दी जाती है।

आप किसी भी समय MySQL डेटाबेस से डिस्कनेक्ट कर सकते हैं exit mysql> प्रॉम्प्ट पर कमांड करें।

mysql> exit
Bye

PHP स्क्रिप्ट का उपयोग करके MySQLi कनेक्शन

PHP प्रदान करता है mysqli_connect()एक डेटाबेस कनेक्शन खोलने के लिए कार्य करता है। यह फ़ंक्शन पाँच पैरामीटर लेता है और सफलता पर एक MySQLi लिंक पहचानकर्ता या विफलता पर FALSE देता है।

वाक्य - विन्यास

connection mysqli_connect(server,user,passwd,new_link,client_flag);

अनु क्रमांक। पैरामीटर और विवरण
1

server

वैकल्पिक - होस्ट नाम चल डेटाबेस सर्वर। यदि निर्दिष्ट नहीं है, तो डिफ़ॉल्ट मान हैlocalhost:3306

2

user

वैकल्पिक - डेटाबेस तक पहुँचने वाला उपयोगकर्ता नाम। यदि निर्दिष्ट नहीं है, तो डिफ़ॉल्ट उस उपयोगकर्ता का नाम है जो सर्वर प्रक्रिया का मालिक है।

3

passwd

वैकल्पिक - डेटाबेस तक पहुँचने वाले उपयोगकर्ता का पासवर्ड। यदि निर्दिष्ट नहीं है, तो डिफ़ॉल्ट एक खाली पासवर्ड है।

4

new_link

वैकल्पिक - यदि एक ही तर्क के साथ mysqli_connect () के लिए दूसरी कॉल की जाती है, तो कोई नया कनेक्शन स्थापित नहीं किया जाएगा; इसके बजाय, पहले से खुले कनेक्शन के पहचानकर्ता को वापस कर दिया जाएगा।

5

client_flags

वैकल्पिक - निम्नलिखित स्थिरांक का संयोजन -

  • MYSQLI_CLIENT_SSL - SSL एन्क्रिप्शन का उपयोग करें
  • MYSQLI_CLIENT_COMPRESS - संपीड़न प्रोटोकॉल का उपयोग करें
  • MYSQLI_CLIENT_IGNORE_SPACE - फ़ंक्शन नामों के बाद स्थान की अनुमति दें
  • MYSQLI_CLIENT_INTERACTIVE - कनेक्शन बंद करने से पहले इंटरैक्टिव टाइमआउट सेकंड की निष्क्रियता की अनुमति दें

आप किसी अन्य PHP फ़ंक्शन का उपयोग करके कभी भी MySQLi डेटाबेस से डिस्कनेक्ट कर सकते हैं mysqli_close()। यह फ़ंक्शन एक एकल पैरामीटर लेता है, जो कि कनेक्शन द्वारा लौटाया जाता हैmysqli_connect() समारोह।

वाक्य - विन्यास

bool mysqli_close ( resource $link_identifier );

यदि कोई संसाधन निर्दिष्ट नहीं है, तो अंतिम खोला गया डेटाबेस बंद है। यदि यह कनेक्शन सफलतापूर्वक बंद हो जाता है तो यह फ़ंक्शन सही हो जाता है, अन्यथा यह गलत हो जाता है।

उदाहरण

MySQL सर्वर से कनेक्ट करने के लिए निम्नलिखित उदाहरण देखें -

<html>
   <head>
      <title>Connecting MySQLi Server</title>
   </head>
   
   <body>
      <?php
         $dbhost = 'localhost:3306'; $dbuser = 'guest';
         $dbpass = 'guest123'; $conn = mysqli_connect($dbhost, $dbuser, $dbpass); if(! $conn ){
            die('Could not connect: ' . mysqli_error());
         }
         echo 'Connected successfully';
         mysqli_close($conn);
      ?>
   </body>
</html>

यदि उपरोक्त उदाहरण MySQLi से जुड़ा है, तो आउटपुट आपके ब्राउज़र पर इस तरह होना चाहिए -

Connected successfully

Mysqladmin का उपयोग करके डेटाबेस बनाएँ

MySQLi डेटाबेस बनाने या हटाने के लिए आपको विशेष विशेषाधिकार की आवश्यकता होगी। इसलिए मान लें कि आपके पास रूट उपयोगकर्ता तक पहुंच है, तो आप mysql का उपयोग करके कोई भी डेटाबेस बना सकते हैंmysqladmin द्विआधारी।

उदाहरण

यहाँ डेटाबेस बनाने के लिए एक सरल उदाहरण है TUTORIALS -

[root@host]# mysqladmin -u root -p create TUTORIALS
Enter password:******

यह एक MySQLi डेटाबेस TUTORIALS बनाएगा।

PHP स्क्रिप्ट का उपयोग करके डेटाबेस बनाएं

PHP का उपयोग करता है mysqli_queryMySQLi डेटाबेस बनाने या हटाने का कार्य। यह फ़ंक्शन दो पैरामीटर लेता है और सफलता पर TRUE या विफलता पर FALSE देता है।

उदाहरण

डेटाबेस बनाने के लिए निम्नलिखित उदाहरण देखें -

<html>
   <head>
      <title>Connecting MySQLi Server</title>
   </head>
   
   <body>
      <?php
         $dbhost = 'localhost:3306';
         $dbuser = 'root'; $dbpass = '<password here>';
         $conn = mysqli_connect($dbhost, $dbuser, $dbpass);
   
         if(! $conn ){ echo 'Connected failure<br>'; } echo 'Connected successfully<br>'; $sql = "CREATE DATABASE TUTORIALS";
         
         if (mysqli_query($conn, $sql)) {
            echo "Database created successfully";
         } else {
            echo "Error creating database: " . mysqli_error($conn); } mysqli_close($conn);
      ?>
   </body>
</html>

यदि जुड़ा और सफलतापूर्वक डेटाबेस बनाया गया है, तो नमूना आउटपुट इस तरह होना चाहिए -

Connected successfully
Database created successfully

Mysqladmin का उपयोग कर डेटाबेस को छोड़ें

MySQLi डेटाबेस बनाने या हटाने के लिए आपको विशेष विशेषाधिकार की आवश्यकता होगी। इसलिए मान लें कि आपके पास रूट उपयोगकर्ता तक पहुंच है, तो आप mysql का उपयोग करके कोई भी डेटाबेस बना सकते हैंmysqladmin द्विआधारी।

किसी भी डेटाबेस को हटाते समय सावधान रहें क्योंकि आप अपने डेटाबेस में उपलब्ध सभी डेटा खो देंगे।

पिछले अध्याय में बनाए गए डेटाबेस को हटाने के लिए एक उदाहरण है -

[root@host]# mysqladmin -u root -p drop TUTORIALS
Enter password:******

यह आपको एक चेतावनी देगा और यह पुष्टि करेगा कि क्या आप वास्तव में इस डेटाबेस को हटाना चाहते हैं या नहीं।

Dropping the database is potentially a very bad thing to do.
Any data stored in the database will be destroyed.

Do you really want to drop the 'TUTORIALS' database [y/N] y
Database "TUTORIALS" dropped

PHP स्क्रिप्ट का उपयोग कर डेटाबेस को गिराएं

PHP का उपयोग करता है queryMySQLi डेटाबेस बनाने या हटाने का कार्य। यह फ़ंक्शन दो पैरामीटर लेता है और सफलता पर TRUE या विफलता पर FALSE देता है।

उदाहरण

डेटाबेस को हटाने के लिए निम्नलिखित उदाहरण देखें -

<html>
   <head>
      <title>Connecting MySQLi Server>/title>
   </head>
   
   <body>
      <?php
         $dbhost = 'localhost:3306'; $dbuser = 'root';
         $dbpass = '<Password Here>'; $conn = mysqli_connect($dbhost, $dbuser, $dbpass); if(! $conn ){
            echo 'Connected failure<br>';
         }
         echo 'Connected successfully<br>';
         $sql = "DROP DATABASE TUTORIALS"; if (mysqli_query($conn, $sql)) { echo "Record deleted successfully"; } else { echo "Error deleting record: " . mysqli_error($conn);
         }
         mysqli_close($conn);
      ?>
   </body>
</html>

WARNING- PHP स्क्रिप्ट का उपयोग कर एक डेटाबेस को हटाने के दौरान, यह आपको किसी भी पुष्टि के लिए संकेत नहीं देता है। इसलिए MySQLi डेटाबेस को हटाते समय सावधान रहें।

यदि डेटाबेस से सफलतापूर्वक जुड़ा और हटा दिया गया है, तो नमूना आउटपुट इस तरह होना चाहिए -

Connected successfully
Database deleted successfully

एक बार जब आप MySQLi सर्वर से कनेक्शन प्राप्त करते हैं, तो इसके साथ काम करने के लिए एक विशेष डेटाबेस का चयन करना आवश्यक है। ऐसा इसलिए है क्योंकि MySQLi Server के पास एक से अधिक डेटाबेस उपलब्ध हो सकते हैं।

वाक्य - विन्यास

bool mysqli_select_db( db_name, connection );

अनु क्रमांक। पैरामीटर और विवरण
1

db_name

आवश्यक - चयनित करने के लिए MySQLi डेटाबेस नाम

2

connection

वैकल्पिक - यदि निर्दिष्ट नहीं है, तो mysqli_connect द्वारा अंतिम खोला गया कनेक्शन उपयोग किया जाएगा।

उदाहरण

एक डेटाबेस का चयन करने का तरीका आपको दिखा रहा है।

<html>
   <head>
      <title>Connecting MySQLi Server</title>
   </head>

   <body>
      <?php
         $dbhost = 'localhost:3306';
         $dbuser = 'root'; $dbpass = '<Password Here>';
         $conn = mysqli_connect($dbhost, $dbuser, $dbpass);
   
         if(! $conn ) { echo 'Connected failure<br>'; } echo 'Connected successfully<br>'; mysqli_select_db( 'TUTORIALS' ); //Write some code here mysqli_close($conn);
      ?>
   </body>
</html>

यदि कनेक्ट और चयनित डेटाबेस सफलतापूर्वक, तो नमूना आउटपुट इस तरह होना चाहिए -

Connected successfully

किसी तालिका में फ़ील्ड्स को ठीक से परिभाषित करना आपके डेटाबेस के समग्र अनुकूलन के लिए महत्वपूर्ण है। आपको केवल फ़ील्ड के प्रकार और आकार का उपयोग करना चाहिए जिसे आपको वास्तव में उपयोग करने की आवश्यकता है; यदि आप जानते हैं कि आप केवल 2 वर्णों का उपयोग करने जा रहे हैं, तो किसी फ़ील्ड को 10 वर्णों के रूप में परिभाषित न करें। इस प्रकार के फ़ील्ड (या कॉलम) को डेटा प्रकार के रूप में भी संदर्भित किया जाता है, के बादtype of data आप उन क्षेत्रों में भंडारण करेंगे।

MySQLi तीन श्रेणियों में विभाजित कई अलग-अलग डेटा प्रकारों का उपयोग करता है: संख्यात्मक, दिनांक और समय, और स्ट्रिंग प्रकार।

संख्यात्मक डेटा प्रकार

MySQLi सभी मानक ANSI SQL संख्यात्मक डेटा प्रकारों का उपयोग करता है, इसलिए यदि आप किसी भिन्न डेटाबेस सिस्टम से MySQLi पर आ रहे हैं, तो ये परिभाषाएँ आपको परिचित लगेंगी। निम्न सूची सामान्य संख्यात्मक डेटा प्रकार और उनके विवरण दिखाती है -

  • INT- एक सामान्य आकार का पूर्णांक जो हस्ताक्षर या अहस्ताक्षरित हो सकता है। यदि हस्ताक्षरित हैं, तो स्वीकार्य सीमा -2147483648 से 2147483647 है। यदि अहस्ताक्षरित है, तो स्वीकार्य सीमा 0 से 4294967295 तक है। आप 11 अंकों तक की चौड़ाई निर्दिष्ट कर सकते हैं।

  • TINYINT- एक बहुत छोटा पूर्णांक जो हस्ताक्षर या अहस्ताक्षरित हो सकता है। यदि हस्ताक्षरित हैं, तो स्वीकार्य सीमा -128 से 127 है। यदि अहस्ताक्षरित है, तो स्वीकार्य सीमा 0 से 255 तक है। आप 4 अंकों तक की चौड़ाई निर्दिष्ट कर सकते हैं।

  • SMALLINT- एक छोटा पूर्णांक जो हस्ताक्षरित या अहस्ताक्षरित हो सकता है। यदि हस्ताक्षरित है, तो स्वीकार्य सीमा -32768 से 32767 है। यदि अहस्ताक्षरित है, तो स्वीकार्य सीमा 0 से 65535 तक है। आप 5 अंकों तक की चौड़ाई निर्दिष्ट कर सकते हैं।

  • MEDIUMINT- एक मध्यम आकार का पूर्णांक जो हस्ताक्षर या अहस्ताक्षरित हो सकता है। यदि हस्ताक्षरित हैं, तो स्वीकार्य सीमा -8388608 से 8388607 है। यदि अहस्ताक्षरित है, तो स्वीकार्य सीमा 0 से 16777215 तक है। आप अधिकतम 9 अंकों की चौड़ाई निर्दिष्ट कर सकते हैं।

  • BIGINT- एक बड़ा पूर्णांक जो हस्ताक्षर या अहस्ताक्षरित हो सकता है। यदि हस्ताक्षरित है, तो स्वीकार्य सीमा -9223372036854775808 से 9223372036854775807 है। यदि अहस्ताक्षरित है, तो स्वीकार्य सीमा 0 से 18446744073709551615 है। आप अधिकतम 20 अंकों की चौड़ाई निर्दिष्ट कर सकते हैं।

  • FLOAT(M,D)- एक फ़्लोटिंग-पॉइंट नंबर जो अहस्ताक्षरित नहीं हो सकता है। आप प्रदर्शन लंबाई (एम) और दशमलव (डी) की संख्या को परिभाषित कर सकते हैं। यह आवश्यक नहीं है और यह 10,2 तक डिफ़ॉल्ट होगा, जहां 2 दशमलव की संख्या है और 10 अंकों की कुल संख्या (दशमलव सहित) है। दशमलव सटीकता एक FLOAT के लिए 24 स्थानों पर जा सकती है।

  • DOUBLE(M,D)- एक डबल सटीक फ़्लोटिंग-पॉइंट संख्या जो अहस्ताक्षरित नहीं हो सकती है। आप प्रदर्शन लंबाई (एम) और दशमलव (डी) की संख्या को परिभाषित कर सकते हैं। यह आवश्यक नहीं है और यह 16,4 पर डिफ़ॉल्ट होगा, जहां 4 दशमलव की संख्या है। दशमलव सटीकता एक डबेल के लिए 53 स्थानों पर जा सकती है। REAL, DOUBLE का एक पर्याय है।

  • DECIMAL(M,D) एक अनपैक फ़्लोटिंग-पॉइंट नंबर जो अहस्ताक्षरित नहीं हो सकता है। अनपैक किए गए दशमलव में, प्रत्येक दशमलव एक बाइट से मेल खाता है। प्रदर्शन लंबाई (एम) और दशमलव (डी) की संख्या को परिभाषित करना आवश्यक है। NUMERIC DECIMAL का पर्याय है।

दिनांक और समय के प्रकार

MySQL की तारीख और समय डेटाैटिप्स हैं -

  • DATE- YYYY-MM-DD प्रारूप में एक तिथि, 1000-01-01 और 9999-12-31 के बीच। उदाहरण के लिए, 30 दिसंबर, 1973 को 1973-12-30 के रूप में संग्रहीत किया जाएगा।

  • DATETIME- YYYY-MM-DD HH: MM: SS प्रारूप, 1000-01-01 00:00:00 और 9999-12-31 23:59:59 के बीच की तारीख और समय का संयोजन। उदाहरण के लिए, 30 दिसंबर 1973 को दोपहर में 3:30, 1973-12-30 15:30:00 के रूप में संग्रहीत किया जाएगा।

  • TIMESTAMP - मध्यरात्रि, 1 जनवरी, 1970 और 2037 में कुछ समय के बीच का टाइमस्टैम्प। यह पिछले DATETIME प्रारूप जैसा दिखता है, केवल संख्याओं के बीच हाइफ़न के बिना; 30 दिसंबर, 1973 को दोपहर में 3:30 को 19731230153000 (YYYYMMDDHHMMSS) के रूप में संग्रहीत किया जाएगा।

  • TIME - HH: MM: SS प्रारूप में समय संग्रहीत करता है।

  • YEAR(M)- 2-अंकीय या 4-अंकीय प्रारूप में एक वर्ष का स्टोर। यदि लंबाई 2 के रूप में निर्दिष्ट की गई है (उदाहरण के लिए YEAR (2)), YEAR 1970 से 2069 (70 से 69) हो सकता है। यदि लंबाई 4 के रूप में निर्दिष्ट की गई है, तो YEAR 1901 से 2155 हो सकता है। डिफ़ॉल्ट लंबाई 4 है।

स्ट्रिंग प्रकार

हालाँकि संख्यात्मक और दिनांक प्रकार मज़ेदार हैं, लेकिन आपके द्वारा संग्रहित अधिकांश डेटा स्ट्रिंग प्रारूप में होंगे। इस सूची में MySQLi के सामान्य स्ट्रिंग डेटाटिप्स का वर्णन किया गया है।

  • CHAR(M)- लंबाई में 1 और 255 अक्षरों के बीच एक निश्चित लंबाई की स्ट्रिंग (उदाहरण के लिए CHAR (5)), संग्रहीत होने पर निर्दिष्ट लंबाई के रिक्त स्थान के साथ दाईं-गद्देदार। लंबाई निर्धारित करना आवश्यक नहीं है, लेकिन डिफ़ॉल्ट 1 है।

  • VARCHAR(M)- लंबाई में 1 और 255 अक्षरों के बीच एक चर-लंबाई स्ट्रिंग; उदाहरण के लिए VARCHAR (25)। VARCHAR फ़ील्ड बनाते समय आपको एक लंबाई निर्धारित करनी चाहिए।

  • BLOB or TEXT- अधिकतम 65535 वर्णों वाला क्षेत्र। BLOBs "बाइनरी लार्ज ऑब्जेक्ट्स" हैं और इसका उपयोग बड़ी मात्रा में बाइनरी डेटा, जैसे कि छवियों या अन्य प्रकार की फ़ाइलों को संग्रहीत करने के लिए किया जाता है। TEXT के रूप में परिभाषित फ़ील्ड भी बड़ी मात्रा में डेटा रखती हैं; दोनों के बीच अंतर यह है कि संग्रहीत डेटा पर सॉर्ट और तुलना BLOB पर संवेदनशील हैं और TEXT क्षेत्रों में संवेदनशील नहीं हैं। आप BLOB या TEXT के साथ लंबाई निर्दिष्ट नहीं करते हैं।

  • TINYBLOB or TINYTEXT- अधिकतम 255 वर्णों वाला एक BLOB या TEXT कॉलम। आप TINYBLOB या TINYTEXT के साथ एक लंबाई निर्दिष्ट नहीं करते हैं।

  • MEDIUMBLOB or MEDIUMTEXT- 16777215 वर्णों की अधिकतम लंबाई के साथ एक BLOB या पाठ स्तंभ। आप MEDIUMBLOB या MEDIUMTEXT के साथ एक लंबाई निर्दिष्ट नहीं करते हैं।

  • LONGBLOB or LONGTEXT- अधिकतम 4294967295 वर्णों वाला एक BLOB या TEXT कॉलम। आप LONGBLOB या LONGTEXT के साथ एक लंबाई निर्दिष्ट नहीं करते हैं।

  • ENUM - एक गणना, जो सूची के लिए एक फैंसी शब्द है। एक ENUM को परिभाषित करते समय, आप उन मदों की एक सूची बना रहे हैं, जिनसे मूल्य का चयन किया जाना चाहिए (या यह पूर्ण हो सकता है)। उदाहरण के लिए, यदि आप चाहते थे कि आपके क्षेत्र में "A" या "B" या "C" हो, तो आप अपने ENUM को ENUM ('A', 'B', 'C') और केवल उन मानों (या NULL) के रूप में परिभाषित करेंगे। कभी भी उस क्षेत्र को आबाद कर सकता है।

तालिका निर्माण आदेश की आवश्यकता है -

  • तालिका का नाम
  • खेतों के नाम
  • प्रत्येक क्षेत्र के लिए परिभाषाएँ

वाक्य - विन्यास

यहाँ MySQLi table बनाने के लिए जेनेरिक SQL सिंटैक्स है -

CREATE TABLE table_name (column_name column_type);

अब, हम निम्नलिखित तालिका बनाएंगे TUTORIALS डेटाबेस।

CREATE TABLE tutorials_inf(
   id INT AUTO_INCREMENT,
   name VARCHAR(20) NOT NULL,
   primary key (id),
);

यहाँ कुछ वस्तुओं के स्पष्टीकरण की आवश्यकता है -

  • फ़ील्ड विशेषता NOT NULLका उपयोग किया जा रहा है क्योंकि हम नहीं चाहते कि यह क्षेत्र NULL हो। इसलिए यदि उपयोगकर्ता NULL मान के साथ रिकॉर्ड बनाने की कोशिश करेगा, तो MySQLi एक त्रुटि बढ़ाएगा।

  • फ़ील्ड विशेषता AUTO_INCREMENT MySQLi को आगे जाने और अगले उपलब्ध नंबर को id फ़ील्ड में जोड़ने के लिए कहता है।

  • कीवर्ड PRIMARY KEYएक कॉलम को प्राथमिक कुंजी के रूप में परिभाषित करने के लिए उपयोग किया जाता है। आप एक प्राथमिक कुंजी को परिभाषित करने के लिए अल्पविराम द्वारा अलग किए गए कई स्तंभों का उपयोग कर सकते हैं।

कमांड प्रॉम्प्ट से टेबल्स बनाना

यह mysql> प्रॉम्प्ट से MySQLi तालिका बनाना आसान है। आप SQL कमांड का उपयोग करेंगेCREATE TABLE एक तालिका बनाने के लिए।

उदाहरण

यहाँ एक उदाहरण है, जो बनाता है tutorials_tbl -

root@host# mysql -u root -p
Enter password:*******

mysql> use TUTORIALS;
Database changed

mysql> CREATE TABLE tutorials_inf(
   id INT AUTO_INCREMENT,name VARCHAR(20) NOT NULL,primary key (id));
Query OK, 0 rows affected (0.16 sec)

mysql>

NOTE - MySQLi SQL कमांड के अंत में एक अर्धविराम (?) देने तक एक कमांड को समाप्त नहीं करता है।

PHP स्क्रिप्ट का उपयोग करके टेबल्स बनाना

किसी भी मौजूदा डेटाबेस में नई तालिका बनाने के लिए आपको PHP फ़ंक्शन का उपयोग करना होगा mysqli_query()। आप तालिका बनाने के लिए उचित SQL कमांड के साथ इसका दूसरा तर्क पारित करेंगे।

उदाहरण

PHP स्क्रिप्ट का उपयोग करके तालिका बनाने का एक उदाहरण यहां दिया गया है -

<html>
   <head>
      <title>Creating MySQLi Tables</title>
   </head>
   
   <body>
      <?php  
         $host = 'localhost:3306'; $user = 'root';  
         $pass = '<Password Here>'; $dbname = 'TUTORIALS';  
         $conn = mysqli_connect($host, $user, $pass,$dbname); if(!$conn){  
            die('Could not connect: '.mysqli_connect_error());  
         }  
         echo 'Connected successfully<br/>';  
  
         $sql = "create table tutorials_inf( id INT AUTO_INCREMENT,name VARCHAR(20) NOT NULL,primary key (id))"; if(mysqli_query($conn, $sql)){ echo "Table created successfully"; } else { echo "Table is not created successfully "; } mysqli_close($conn);  
      ?>  
   </body>
</html>

नमूना आउटपुट इस तरह होना चाहिए -

Connected successfully
Table created successfully

मौजूदा MySQLi तालिका को छोड़ना बहुत आसान है, लेकिन आपको किसी भी मौजूदा तालिका को हटाते समय बहुत सावधानी बरतने की आवश्यकता है क्योंकि किसी तालिका को हटाने के बाद खोए गए डेटा को पुनर्प्राप्त नहीं किया जाएगा।

वाक्य - विन्यास

यहाँ MySQLi table को छोड़ने के लिए जेनेरिक SQL सिंटैक्स है -

DROP TABLE table_name ;

कमांड प्रॉम्प्ट से टेबल्स को छोड़ना

इस पर अमल करने की जरूरत है DROP TABLE SQL कमांड mysql> प्रॉम्प्ट पर।

उदाहरण

यहाँ एक उदाहरण है, जो हटाता है tutorials_inf -

root@host# mysql -u root -p
Enter password:*******

mysql> use TUTORIALS;
Database changed

mysql> DROP TABLE tutorials_inf
Query OK, 0 rows affected (0.8 sec)

mysql>

PHP स्क्रिप्ट का उपयोग कर टेबल्स को छोड़ना

किसी भी डेटाबेस में मौजूदा तालिका को गिराने के लिए, आपको PHP फ़ंक्शन का उपयोग करना होगा mysqli_query()। आप तालिका को छोड़ने के लिए उचित SQL कमांड के साथ इसका दूसरा तर्क पारित करेंगे।

उदाहरण

<html>
   <head>
      <title>Dropping MySQLi Tables</title>
   </head>
   
   <body>
      <?php  
         $host = 'localhost:3306'; $user = 'root';  
         $pass = ''; $dbname = 'TUTORIALS';  
         $conn = mysqli_connect($host, $user, $pass,$dbname); if(!$conn) {  
            die('Could not connect: '.mysqli_connect_error());  
         }  
         echo 'Connected successfully<br/>';  
         $sql = "DROP TABLE tutorials_inf"; if(mysqli_query($conn, $sql)) { echo "Table is deleted successfully"; } else { echo "Table is not deleted successfully\n"; } mysqli_close($conn);  
      ?>  
   </body>
</html>

नमूना आउटपुट इस तरह होना चाहिए -

Connected successfully
Table is deleted successfully

MySQLi तालिका में डेटा डालने के लिए, आपको SQL का उपयोग करना होगा INSERT INTOआदेश। आप mysql> प्रॉम्प्ट का उपयोग करके या PHP जैसी किसी भी स्क्रिप्ट का उपयोग करके MySQLi तालिका में डेटा सम्मिलित कर सकते हैं।

वाक्य - विन्यास

यहाँ MySQLi table में डेटा डालने के लिए INSERT INTO कमांड का जेनेरिक SQL सिंटैक्स है:

INSERT INTO table_name 
   ( field1, field2,...fieldN )
   VALUES
   ( value1, value2,...valueN );

स्ट्रिंग डेटा प्रकार सम्मिलित करने के लिए, सभी मूल्यों को दोहरे या एकल उद्धरण में रखना आवश्यक है, उदाहरण के लिए: - "value"

कमांड प्रॉम्प्ट से डेटा सम्मिलित करना

यह MySQLi table tutorials_inf में डेटा डालने के लिए SQL INSERT INTO कमांड का उपयोग करेगा।

उदाहरण

निम्नलिखित उदाहरण 3 रिकॉर्ड बनाएंगे tutorials_tbl तालिका -

root@host# mysql -u root -p password;
Enter password:*******

mysql> use TUTORIALS;
Database changed

mysql> INSERT INTO tutorials_inf 
   ->(id, name)
   ->VALUES
   ->(10, "John Poul");
Query OK, 1 row affected (0.01 sec)

NOTE- कृपया ध्यान दें कि सभी तीर संकेत (->) SQL कमांड का हिस्सा नहीं हैं; वे एक नई लाइन का संकेत कर रहे हैं और वे कमांड के प्रत्येक लाइन के अंत में एक अर्धविराम दिए बिना एंटर कुंजी दबाते हुए MySQL प्रॉम्प्ट द्वारा स्वचालित रूप से बनाए जाते हैं।

PHP स्क्रिप्ट का उपयोग कर डेटा सम्मिलित करना

आप PHP फ़ंक्शन में उसी SQL INSERT INTO कमांड का उपयोग कर सकते हैं mysqli_query() MySQLi टेबल में डेटा डालने के लिए।

उदाहरण

यह उदाहरण उपयोगकर्ता से तीन पैरामीटर लेगा और उन्हें MySQLi तालिका में सम्मिलित करेगा -

<html>
   <head>
      <title>Add New Record in MySQLi Database</title>
      <link rel = "stylesheet" type = "text/css" href = "style.css">
   </head>
   
   <body>
      <div id = "main">
         <form action = "" method = "post">
            <label>Name :</label>
            <input type = "text" name = "name" id = "name" />
            <br />
            <br />
            <input type = "submit" value ="Submit" name = "submit"/>
            <br />
         </form>
      </div>
      
      <?php
         if(isset($_POST["submit"])){ $servername = "localhost:3306";
            $username = "root"; $password = "<Password here>";
            $dbname = "TUTORIALS"; // Create connection $conn = new mysqli($servername, $username, $password, $dbname);

            // Check connection
            if ($conn->connect_error) { die("Connection failed: " . $conn->connect_error);
            } 
            $sql = "INSERT INTO tutorials_inf(name)VALUES ('".$_POST["name"]."')";

            if (mysqli_query($conn, $sql)) {
               echo "New record created successfully";
            } else {
               echo "Error: " . $sql . "" . mysqli_error($conn);
            }
            $conn->close();
         }
      ?>
   </body>
</html>

नमूना आउटपुट इस तरह होना चाहिए -

New record created successfully

एसक्यूएल SELECTMySQLi डेटाबेस से डेटा लाने के लिए कमांड का उपयोग किया जाता है। आप इस कमांड का उपयोग mysql> प्रॉम्प्ट के साथ-साथ PHP जैसी किसी भी स्क्रिप्ट में कर सकते हैं।

वाक्य - विन्यास

यहाँ MySQLi table से डेटा लाने के लिए SELECT कमांड का जेनेरिक SQL सिंटैक्स है -

SELECT field1, field2,...fieldN table_name1, table_name2...
[WHERE Clause]
[OFFSET M ][LIMIT N]
  • आप WHERE क्लॉज़ का उपयोग करके विभिन्न स्थितियों को शामिल करने के लिए अल्पविराम द्वारा अलग की गई एक या एक से अधिक तालिकाओं का उपयोग कर सकते हैं, लेकिन WHERE क्लॉज़ SELECT कमांड का एक वैकल्पिक हिस्सा है।

  • आप एकल चयन कमांड में एक या अधिक फ़ील्ड ला सकते हैं।

  • आप फ़ील्ड के स्थान पर स्टार (*) निर्दिष्ट कर सकते हैं। इस स्थिति में, SELECT सभी फ़ील्ड लौटा देगा।

  • आप WHERE क्लॉज का उपयोग करके किसी भी शर्त को निर्दिष्ट कर सकते हैं।

  • आप एक ऑफसेट का उपयोग करके निर्दिष्ट कर सकते हैं OFFSETजहां से सेलेक्ट रिकॉर्ड वापस करने लगेगा। डिफ़ॉल्ट रूप से ऑफसेट शून्य है।

  • आप का उपयोग करके रिटर्न की संख्या को सीमित कर सकते हैं LIMIT विशेषता।

कमांड प्रॉम्प्ट से डेटा ला रहा है -

यह MySQLi table tutorials_tbl से डेटा लाने के लिए SQL SELECT कमांड का उपयोग करेगा

उदाहरण

निम्नलिखित उदाहरण से सभी रिकॉर्ड वापस आ जाएंगे tutorials_inf तालिका -

root@host# mysql -u root -p password;
Enter password:*******

mysql> use TUTORIALS;
Database changed

mysql> SELECT * from tutorials_inf;
+----+------+
| id | name |
+----+------+
|  1 | sai  |
|  2 | kit  |
|  3 | ram  |
+----+------+
3 rows in set (0.00 sec)

mysql>

PHP स्क्रिप्ट का उपयोग करके डेटा लाना

आप PHP फ़ंक्शन में उसी SQL SELECT कमांड का उपयोग कर सकते हैं mysqli_query()। इस फ़ंक्शन का उपयोग SQL कमांड और बाद में एक और PHP फ़ंक्शन को निष्पादित करने के लिए किया जाता हैmysqli_fetch_assoc()सभी चयनित डेटा लाने के लिए उपयोग किया जा सकता है। यह फ़ंक्शन एक सहयोगी सरणी, एक संख्यात्मक सरणी, या दोनों के रूप में पंक्ति देता है। यदि कोई और पंक्तियाँ नहीं हैं, तो यह फ़ंक्शन FALSE देता है।

नीचे से रिकॉर्ड लाने के लिए एक सरल उदाहरण है tutorials_inf तालिका।

उदाहरण

ट्यूटोरियल्स_इन टेबल से सभी रिकॉर्ड दिखाने के लिए निम्नलिखित उदाहरण देखें।

<html>
   <head>
      <title>Selecting Table in MySQLi Server</title>
   </head>

   <body>
      <?php
         $dbhost = 'localhost:3306';
         $dbuser = 'root'; $dbpass = '';
         $dbname = 'TUTORIALS'; $conn = mysqli_connect($dbhost, $dbuser, $dbpass,$dbname);
   
         if(! $conn ) { die('Could not connect: ' . mysqli_error()); } echo 'Connected successfully<br>'; $sql = 'SELECT name FROM tutorials_inf';
         $result = mysqli_query($conn, $sql); if (mysqli_num_rows($result) > 0) {
            while($row = mysqli_fetch_assoc($result)) {
               echo "Name: " . $row["name"]. "<br>"; } } else { echo "0 results"; } mysqli_close($conn);
      ?>
   </body>
</html>

पंक्तियों की सामग्री को चर $ पंक्ति को सौंपा गया है और फिर पंक्ति में मान मुद्रित किए गए हैं।

NOTE - हमेशा याद रखें कि जब आप किसी स्ट्रिंग मान को सीधे स्ट्रिंग में सम्मिलित करना चाहते हैं, तो घुंघराले ब्रैकेट लगाएं।

नमूना आउटपुट इस तरह होना चाहिए -

Connected successfully
Name: ram
Name: kit
Name: abc

हमने एसक्यूएल देखा है SELECTMySQLi तालिका से डेटा लाने के लिए कमांड। हम नामक एक सशर्त खंड का उपयोग कर सकते हैंWHEREपरिणामों को फ़िल्टर करने के लिए खंड। जहां क्लॉज का उपयोग करते हुए, हम एक तालिका से आवश्यक रिकॉर्ड का चयन करने के लिए चयन मानदंड निर्दिष्ट कर सकते हैं।

वाक्य - विन्यास

यहाँ MySQLi table से डेटा लाने के लिए WHECT क्लॉज़ के साथ SELECT कमांड का जेनेरिक SQL सिंटैक्स है -

SELECT field1, field2,...fieldN table_name1, table_name2...
[WHERE condition1 [AND [OR]] condition2.....
  • आप WHERE क्लॉज़ का उपयोग करके विभिन्न स्थितियों को शामिल करने के लिए अल्पविराम द्वारा अलग की गई एक या एक से अधिक तालिकाओं का उपयोग कर सकते हैं, लेकिन WHERE क्लॉज़ SELECT कमांड का एक वैकल्पिक हिस्सा है।

  • आप WHERE क्लॉज का उपयोग करके किसी भी शर्त को निर्दिष्ट कर सकते हैं।

  • आप एक से अधिक शर्तों का उपयोग करके निर्दिष्ट कर सकते हैं AND या OR ऑपरेटरों।

  • एक शर्त का उपयोग शर्त के साथ DELETE या UPDATE SQL कमांड के साथ भी किया जा सकता है।

WHEREखण्ड किसी भी प्रोग्रामिंग भाषा में एक शर्त की तरह काम करता है। इस खंड का उपयोग MySQLi तालिका में उपलब्ध फ़ील्ड मान के साथ दिए गए मूल्य की तुलना करने के लिए किया जाता है। यदि बाहर से दिया गया मान MySQLi तालिका में उपलब्ध फ़ील्ड मान के बराबर है, तो यह उस पंक्ति को लौटाता है।

यहां ऑपरेटरों की सूची दी गई है, जिनका उपयोग किया जा सकता है WHERE खंड।

फ़ील्ड A मानें 10 और फ़ील्ड B 20 रखता है, तो -

ऑपरेटर विवरण उदाहरण
= जाँच करता है कि दो ऑपरेंड के मान समान हैं या नहीं, यदि हाँ तो स्थिति सच हो जाती है। (ए = बी) सच नहीं है।
! = जाँच करता है कि दो ऑपरेंड के मान समान हैं या नहीं, यदि मान बराबर नहीं हैं तो स्थिति सत्य हो जाती है। (ए! = बी) सच है।
> यह जाँचता है कि क्या बाएं संकार्य का मान दाहिने संचालक के मान से अधिक है, यदि हाँ, तो स्थिति सत्य है। (ए> बी) सच नहीं है।
< यह जाँचता है कि क्या बाएं संकार्य का मान दाहिने संचालक के मान से कम है, यदि हाँ, तो स्थिति सही है। (ए <बी) सच है।
> = जाँच करता है कि क्या बाएं ऑपरेंड का मूल्य सही ऑपरेंड के मूल्य से अधिक या उसके बराबर है, यदि हाँ तो स्थिति सच हो जाती है। (ए> = बी) सच नहीं है।
<= जाँच करता है कि क्या बाएं संकार्य का मान दाहिने संचालक के मान से कम या उसके बराबर है, यदि हाँ तो स्थिति सत्य हो जाती है। (ए <= बी) सच है।

जब आप किसी तालिका से चयनित पंक्तियों को प्राप्त करना चाहते हैं, तो खासतौर पर जब आप उपयोग करते हैं, तो यह खंड बहुत उपयोगी है MySQLi Join। जोड़ों की चर्चा दूसरे अध्याय में की जाती है।

रिकॉर्ड का उपयोग करके खोज करना एक आम बात है Primary Key तेजी से खोज करने के लिए।

यदि दी गई स्थिति तालिका में किसी रिकॉर्ड से मेल नहीं खाती है, तो क्वेरी किसी भी पंक्ति में वापस नहीं आएगी।

कमांड प्रॉम्प्ट से डेटा ला रहा है

यह MySQLi table tutorials_inf से चयनित डेटा लाने के लिए WHERE क्लॉज़ के साथ SQL SELECT कमांड का उपयोग करेगा।

उदाहरण

निम्नलिखित उदाहरण से सभी रिकॉर्ड वापस आ जाएंगे tutorials_inf तालिका जिसके लिए नाम है sai -

root@host# mysql -u root -p password;
Enter password:*******

mysql> use TUTORIALS;
Database changed

mysql>SELECT * from tutorials_inf where name = 'sai';
+----+------+
| id | name |
+----+------+
|  1 | SAI  |
+----+------+
1 row in set (0.00 sec)

mysql>

जब तक प्रदर्शन नहीं किया जाता LIKEएक स्ट्रिंग पर तुलना, मामला संवेदनशील नहीं है। आप अपने खोज मामले को संवेदनशील बना सकते हैंBINARY कीवर्ड इस प्रकार है -

root@host# mysql -u root -p password;
Enter password:*******

mysql> use TUTORIALS;
Database changed

mysql> SELECT * from tutorials_inf \WHERE BINARY name = 'sai';
Empty set (0.02 sec)

mysql>

PHP स्क्रिप्ट का उपयोग करके डेटा लाना:

आप PHP फ़ंक्शन में WHAL CLAUSE के साथ उसी SQL SELECT कमांड का उपयोग कर सकते हैं mysqli_query()

उदाहरण

निम्नलिखित उदाहरण से सभी रिकॉर्ड वापस आ जाएंगे tutorials_inf तालिका जिसके लिए नाम है sai -

<?php
   $dbhost = 'localhost:3306';
   $dbuser = 'root'; $dbpass = '';
   $dbname = 'TUTORIALS'; $conn = mysqli_connect($dbhost, $dbuser, $dbpass,$dbname);
   
   if(! $conn ) { die('Could not connect: ' . mysqli_error()); } echo 'Connected successfully<br>'; $sql = 'SELECT * from tutorials_inf where name="sai"';
   $result = mysqli_query($conn, $sql); if (mysqli_num_rows($result) > 0) {
      while($row = mysqli_fetch_assoc($result)) {
         echo "Name: " . $row["name"]. "<br>"; } } else { echo "0 results"; } mysqli_close($conn);
?>

नमूना आउटपुट इस तरह होना चाहिए -

Connected successfully
Name: SAI

एक आवश्यकता हो सकती है जहां MySQLi तालिका में मौजूदा डेटा को संशोधित करने की आवश्यकता है। आप SQL का उपयोग करके ऐसा कर सकते हैंUPDATEआदेश। यह किसी भी MySQLi तालिका के किसी भी फ़ील्ड मान को संशोधित करेगा।

वाक्य - विन्यास

यहाँ MySQLi table में डेटा को संशोधित करने के लिए UPDATE कमांड का जेनेरिक SQL सिंटैक्स है -

UPDATE table_name SET field1 = new-value1, field2 = new-value2 [WHERE Clause]
  • आप एक या अधिक फ़ील्ड को पूरी तरह से अपडेट कर सकते हैं।

  • आप WHERE क्लॉज का उपयोग करके किसी भी शर्त को निर्दिष्ट कर सकते हैं।

  • आप एक बार में एक ही तालिका में मानों को अपडेट कर सकते हैं।

जब आप किसी तालिका में चयनित पंक्तियों को अपडेट करना चाहते हैं तो WHERE क्लॉज बहुत उपयोगी है।

कमांड प्रॉम्प्ट से डेटा अपडेट करना

यह MySQLi table tutorials_inf में चयनित डेटा को अपडेट करने के लिए WHERE क्लॉज के साथ SQL UPDATE कमांड का उपयोग करेगा।

उदाहरण

निम्नलिखित उदाहरण अद्यतन करेगा name tutorial_inf वाले रिकॉर्ड के लिए फ़ील्ड।

root@host# mysql -u root -p password;
Enter password:*******

mysql> use TUTORIALS;
Database changed

mysql> UPDATE tutorials_inf 
   -> SET name = 'johar' 
   -> WHERE name = 'sai';
Query OK, 1 row affected (0.04 sec)
Rows matched: 1  Changed: 1  Warnings: 0

mysql>

PHP स्क्रिप्ट का उपयोग कर डेटा को अद्यतन करना

SQL फ़ंक्शन के साथ या बिना PHP फ़ंक्शन में आप SQL UPDATE कमांड का उपयोग कर सकते हैं mysqli_query()। यह फ़ंक्शन SQL कमांड को उसी तरह निष्पादित करेगा जैसे यह mysql> प्रॉम्प्ट पर निष्पादित होता है।

उदाहरण

अद्यतन करने के लिए निम्न उदाहरण देखें name एक रिकॉर्ड के लिए क्षेत्र।

<?php
   $dbhost = 'localhost:3306'; $dbuser = 'root';
   $dbpass = ''; $dbname = 'TUTORIALS';
   $conn = mysqli_connect($dbhost, $dbuser, $dbpass,$dbname); if(! $conn ) {
      die('Could not connect: ' . mysqli_error());
   }
   echo 'Connected successfully<br>';
   $sql = ' UPDATE tutorials_inf SET name="althamas" WHERE name="ram"'; if (mysqli_query($conn, $sql)) { echo "Record updated successfully"; } else { echo "Error updating record: " . mysqli_error($conn);
   }
   mysqli_close($conn);
?>

नमूना आउटपुट इस तरह होना चाहिए -

Connected successfully
Record updated successfully

यदि आप किसी भी MySQLi तालिका से एक रिकॉर्ड हटाना चाहते हैं, तो आप SQL कमांड का उपयोग कर सकते हैं DELETE FROM। आप इस कमांड का उपयोग mysql> प्रॉम्प्ट के साथ-साथ PHP जैसी किसी भी स्क्रिप्ट में कर सकते हैं।

वाक्य - विन्यास

यहाँ एक MySQLi तालिका से डेटा को हटाने के लिए DELETE कमांड का सामान्य SQL सिंटैक्स है -

DELETE FROM table_name [WHERE Clause]
  • यदि क्लॉज निर्दिष्ट नहीं है, तो दिए गए MySQLi तालिका से सभी रिकॉर्ड हटा दिए जाएंगे।

  • आप WHERE क्लॉज का उपयोग करके किसी भी शर्त को निर्दिष्ट कर सकते हैं।

  • आप एक बार में एक ही तालिका में रिकॉर्ड हटा सकते हैं।

जब आप किसी तालिका में चयनित पंक्तियों को हटाना चाहते हैं तो WHERE क्लॉज बहुत उपयोगी है।

कमांड प्रॉम्प्ट से डेटा हटाना

यह MySQLi table tutorials_inf में चयनित डेटा को हटाने के लिए WHERE क्लॉज़ के साथ SQL DELETE कमांड का उपयोग करेगा।

उदाहरण

उदाहरण के बाद tutorial_inf में एक रिकॉर्ड हटा देगा जिसका नाम जौहर है।

root@host# mysql -u root -p password;
Enter password:*******

mysql> use TUTORIALS;
Database changed

mysql> DELETE FROM tutorials_inf where name = 'johar';
Query OK, 1 row affected (0.23 sec)

mysql>

PHP स्क्रिप्ट का उपयोग करके डेटा हटाना

आप SQL फ़ंक्शन के साथ या बिना PHP फ़ंक्शन में SQL DELETE कमांड का उपयोग कर सकते हैं mysqli_query()। यह फ़ंक्शन SQL कमांड को उसी तरह निष्पादित करेगा जैसे यह mysql> प्रॉम्प्ट पर निष्पादित होता है।

उदाहरण

जिसका नाम althamas है, tutorial_inf से रिकॉर्ड हटाने के लिए निम्नलिखित उदाहरण देखें।

<?php
   $dbhost = 'localhost:3306';
   $dbuser = 'root'; $dbpass = '';
   $dbname = 'TUTORIALS'; $conn = mysqli_connect($dbhost, $dbuser, $dbpass,$dbname);
   
   if(! $conn ) { die('Could not connect: ' . mysqli_error()); } echo 'Connected successfully<br>'; $sql = ' DELETE FROM tutorials_inf WHERE name = "althamas"';
   
   if (mysqli_query($conn, $sql)) {
      echo "Record deleted successfully";
   } else {
      echo "Error deleting record: " . mysqli_error($conn); } mysqli_close($conn);
?>

नमूना आउटपुट इस तरह होना चाहिए-

Connected successfully
Record deleted successfully

हमने एसक्यूएल देखा है SELECTMySQLi तालिका से डेटा लाने के लिए कमांड। हम एक सशर्त खंड का भी उपयोग कर सकते हैं जिसे कहा जाता हैWHERE आवश्यक रिकॉर्ड का चयन करने के लिए खंड।

समान चिह्न के साथ खंड (=) ठीक काम करता है जहां हम एक सटीक मिलान करना चाहते हैं। जैसे अगर "नाम = 'साईं"। लेकिन एक आवश्यकता हो सकती है जहां हम उन सभी परिणामों को फ़िल्टर करना चाहते हैं जिनमें नाम "जौहर" होना चाहिए। यह SQL का उपयोग कर संभाला जा सकता हैLIKE जहां क्लॉज के साथ क्लॉज।

यदि SQL LIKE क्लॉज का उपयोग% वर्णों के साथ किया जाता है, तो यह कमांड प्रॉम्प्ट पर सभी फाइलों या निर्देशिकाओं को सूचीबद्ध करते हुए UNIX में एक मेटा कैरेक्टर (*) की तरह काम करेगा।

एक% चरित्र के बिना, LIKE क्लॉज़ WHERE क्लॉज़ के साथ साइन के बराबर होता है।

वाक्य - विन्यास

यहाँ MySQLi table से डेटा लाने के लिए LIKE क्लॉज के साथ SELECT कमांड का जेनेरिक SQL सिंटैक्स है -

SELECT field1, field2,...fieldN table_name1, table_name2...
WHERE field1 LIKE condition1 [AND [OR]] filed2 = 'somevalue'
  • आप WHERE क्लॉज का उपयोग करके किसी भी शर्त को निर्दिष्ट कर सकते हैं।

  • आप WHIKE क्लॉज के साथ LIKE क्लॉज का उपयोग कर सकते हैं।

  • आप बराबर चिह्न के स्थान पर LIKE खंड का उपयोग कर सकते हैं।

  • जब LIKE का उपयोग% चिन्ह के साथ किया जाता है तो यह मेटा कैरेक्टर सर्च की तरह काम करेगा।

  • आप एक से अधिक शर्तों का उपयोग करके निर्दिष्ट कर सकते हैं AND या OR ऑपरेटरों।

  • एक शर्त ... एक शर्त को निर्दिष्ट करने के लिए DELETE या UPDATE SQL कमांड के साथ LIKE क्लॉज का उपयोग किया जा सकता है।

कमांड प्रॉम्प्ट पर LIKE क्लॉज का उपयोग करना

यह WHERE के साथ SQL SELECT कमांड का उपयोग करेगा ... MySQLi table tutorials_inf से चुनिंदा डेटा लाने के लिए LIKE क्लॉज।

उदाहरण

निम्नलिखित उदाहरण से सभी रिकॉर्ड वापस आ जाएंगे tutorials_inf तालिका जिसके लिए लेखक का नाम समाप्त होता है johar -

root@host# mysql -u root -p password;
Enter password:*******

mysql> use TUTORIALS;
Database changed

mysql> SELECT * from tutorials_inf 
   -> WHERE name LIKE '%johar';
+----+-------+
| id | name  |
+----+-------+
|  2 | johar |
+----+-------+
1 row in set (0.00 sec)

mysql>

PHP स्क्रिप्ट के अंदर LIKE क्लॉज का उपयोग करना

आप WHERE के समान सिंटैक्स का उपयोग कर सकते हैं ... PHP फंक्शन में LIKE क्लॉज mysqli_query()। इस फ़ंक्शन का उपयोग SQL कमांड और बाद में एक और PHP फ़ंक्शन को निष्पादित करने के लिए किया जाता हैmysqli_fetch_array() यदि चयनित सभी डेटा प्राप्त करने के लिए उपयोग किया जा सकता है ... तो LIKE क्लॉज का चयन SELECT कमांड के साथ किया जाता है।

लेकिन अगर यहां ... LIKE क्लॉज का उपयोग DELETE या UPDATE कमांड के साथ किया जा रहा है, तो आगे PHP फ़ंक्शन कॉल की आवश्यकता नहीं है।

उदाहरण

सभी रिकॉर्ड्स को वापस करने के लिए निम्नलिखित उदाहरण देखें tutorials_inf तालिका जिसमें नाम शामिल है johar -

<?php
   $dbhost = 'localhost:3306'; $dbuser = 'root';
   $dbpass = ''; $dbname = 'TUTORIALS';
   $conn = mysqli_connect($dbhost, $dbuser, $dbpass,$dbname); if(! $conn ) {
      die('Could not connect: ' . mysqli_error());
   }
   echo 'Connected successfully<br>';
   $sql = 'SELECT * FROM tutorials_inf WHERE name LIKE "%johar%"'; $result = mysqli_query($conn, $sql);
   $row = mysqli_fetch_array($result,MYSQLI_ASSOC);
   
   printf ("%s \n",$row["name"]); mysqli_free_result($result);
   mysqli_close($conn);
?>

नमूना आउटपुट इस तरह होना चाहिए -

Connected successfully
johar

हमने एसक्यूएल देखा है SELECTMySQLi तालिका से डेटा लाने के लिए कमांड। जब आप पंक्तियों का चयन करते हैं, तो MySQLi सर्वर उन्हें किसी भी क्रम में वापस करने के लिए स्वतंत्र है, जब तक कि आप इसे अन्यथा निर्देश न दें कि परिणाम को कैसे सॉर्ट करें। लेकिन आप उस क्रम या स्तंभ को जोड़कर सेट किए गए परिणाम को क्रमबद्ध करते हैं जिसे आप जिस कॉलम या कॉलम के आधार पर क्रमबद्ध करना चाहते हैं उसे नाम देते हैं।

वाक्य - विन्यास

यहाँ MySQL टेबल से डेटा सॉर्ट करने के लिए ORDER BY क्लर्क के साथ सेलेक्ट कमांड का जेनेरिक SQL सिंटैक्स है -

SELECT field1, field2,...fieldN table_name1, table_name2...
ORDER BY field1, [field2...] [ASC [DESC]]
  • आप किसी भी क्षेत्र पर वापस लौटे परिणाम को सॉर्ट कर सकते हैं बशर्ते कि दर्ज किया गया हो।

  • आप एक से अधिक फ़ील्ड पर परिणाम सॉर्ट कर सकते हैं।

  • आप आरोही या अवरोही क्रम में परिणाम प्राप्त करने के लिए कीवर्ड ASC या DESC का उपयोग कर सकते हैं। डिफ़ॉल्ट रूप से, यह आरोही क्रम है।

  • आप WHERE का उपयोग कर सकते हैं ... शर्त लगाने के लिए सामान्य तरीके से क्लॉज़ को लाइक करें।

आदेश प्रॉम्प्ट पर खंड द्वारा आदेश का उपयोग करना

यह MySQLi table tutorials_inf से डेटा लाने के लिए ORDER BY क्लॉज के साथ SQL SELECT कमांड का उपयोग करेगा।

उदाहरण

निम्नलिखित उदाहरण का प्रयास करें, जिसके परिणामस्वरूप अवरोही क्रम में वापसी होती है।

root@host# mysql -u root -p password;
Enter password:*******

mysql> use TUTORIALS;
Database changed

mysql> SELECT * from tutorials_inf ORDER BY id desc;
+----+-------+
| id | name  |
+----+-------+
|  4 | ram   |
|  3 | raghu |
|  2 | johar |
|  1 | sai   |
+----+-------+
4 rows in set (0.00 sec)

mysql>

सत्यापित करें कि सभी आईडी अवरोही क्रम में सूचीबद्ध हैं।

PHP स्क्रिप्ट के अंदर खंड द्वारा ORDER का उपयोग करना

आप PHP फ़ंक्शन में ORDER BY क्लॉज के समान सिंटैक्स का उपयोग कर सकते हैं mysqli_query()। इस फ़ंक्शन का उपयोग SQL कमांड और बाद में एक और PHP फ़ंक्शन को निष्पादित करने के लिए किया जाता हैmysqli_fetch_array() सभी चयनित डेटा लाने के लिए उपयोग किया जा सकता है।

उदाहरण

निम्नलिखित उदाहरण का प्रयास करें, जो ट्यूटोरियल लेखक के अवरोही क्रम में परिणाम देता है।

<?php
   $dbhost = 'localhost:3306';
   $dbuser = 'root'; $dbpass = '';
   $dbname = 'TUTORIALS'; $conn = mysqli_connect($dbhost, $dbuser, $dbpass,$dbname);
   
   if(! $conn ) { die('Could not connect: ' . mysqli_error()); } echo 'Connected successfully</br>'; $sql = 'SELECT * from tutorials_inf ORDER BY id desc';
   
   if($result = mysqli_query($conn, $sql)){ if(mysqli_num_rows($result) > 0){
         echo "<table>";
         echo "<tr>";
         echo "<th>id</th>";
         echo "<th>name</th>";
         echo "</tr>";
         
         while($row = mysqli_fetch_array($result)){
            echo "<tr>";
            echo "<td>" . $row['id'] . "</td>"; echo "<td>" . $row['name'] . "</td>";
            echo "</tr>";
         }
         echo "</table>";
         mysqli_free_result($result); } else { echo "No records matching your query were found."; } } else { echo "ERROR: Could not able to execute $sql. " . mysqli_error($conn); } mysqli_close($conn);
?>

नमूना आउटपुट इस तरह होना चाहिए -

Connected successfully
id	name
4	ram
3	raghu
2	johar
1	sai

इस प्रकार, अब तक हम एक समय में केवल एक तालिका से डेटा प्राप्त कर रहे हैं। यह साधारण ले के लिए ठीक है, लेकिन अधिकांश वास्तविक दुनिया MySQL उपयोग में, आपको अक्सर एक ही क्वेरी में कई तालिकाओं से डेटा प्राप्त करने की आवश्यकता होगी।

आप अपनी एकल SQL क्वेरी में कई तालिकाओं का उपयोग कर सकते हैं। MySQLi में शामिल होने का कार्य दो या अधिक तालिकाओं को एक ही तालिका में तोड़ना है।

आप MySQLi tables में शामिल होने के लिए SELECT, UPDATE और DELETE स्टेटमेंट में JOINS का उपयोग कर सकते हैं। हम LEFT JOIN का एक उदाहरण देखेंगे जो कि सरल MySQLi JOIN से अलग है।

कमांड प्रॉम्प्ट में जॉइन का उपयोग करना

मान लीजिए हमारे पास दो टेबल हैं tutorials_bks तथा tutorials_inf, TUTORIALS में। पूरी सूची नीचे दी गई है -

उदाहरण

निम्नलिखित उदाहरण देखें -

root@host# mysql -u root -p password;
Enter password:*******

mysql> use TUTORIALS;
Database changed

mysql> SELECT * FROM tcount_bks;
+----+---------+
| id | book    |
+----+---------+
|  1 | java    |
|  2 | java    |
|  3 | html    |
|  4 | c++     |
|  5 | Android |
+----+---------+
5 rows in set (0.00 sec)

mysql> SELECT * from tutorials_inf;
+----+-------+
| id | name  |
+----+-------+
|  1 | sai   |
|  2 | johar |
|  3 | raghu |
|  4 | ram   |
+----+-------+
4 rows in set (0.00 sec)

mysql>

अब हम इन दो तालिकाओं में शामिल होने के लिए SQL क्वेरी लिख सकते हैं। यह क्वेरी तालिका से सभी नामों का चयन करेगीtutorials_inf और ट्यूटोरियल से इसी संख्या को पिक करेगाtutorials_bks

mysql> SELECT a.id, a.name,b.id FROM tutorials_inf a,tutorials_bks b WHERE a.id = b.id;
+----+-------+----+
| id | name  | id |
+----+-------+----+
|  1 | sai   |  1 |
|  2 | johar |  2 |
|  3 | raghu |  3 |
|  4 | ram   |  4 |
+----+-------+----+
4 rows in set (0.00 sec)
mysql>

Tutorial_bks तालिका में, हमारे पास 5 रिकॉर्ड हैं लेकिन उपरोक्त उदाहरण में यह फ़िल्टर करता है और क्वेरी के अनुसार केवल 4 आईडी रिकॉर्ड देता है

PHP स्क्रिप्ट में Joins का उपयोग करना

आप PHP स्क्रिप्ट में उपर्युक्त SQL क्वेरी में से किसी का उपयोग कर सकते हैं। आपको केवल SQL फ़ंक्शन को PHP फ़ंक्शन में पास करना होगाmysqli_query() और फिर आप सामान्य तरीके से परिणाम प्राप्त करेंगे।

उदाहरण

निम्नलिखित उदाहरण देखें -

<?php
   $dbhost = 'localhost:3306'; $dbuser = 'root';
   $dbpass = ''; $dbname = 'TUTORIALS';
   $conn = mysqli_connect($dbhost, $dbuser, $dbpass,$dbname); if(! $conn ) {
      die('Could not connect: ' . mysqli_error());
   }
   echo 'Connected successfully</br>';
   $sql = 'SELECT a.id, a.name,b.id FROM tutorials_inf a,tutorials_bks b WHERE a.id = b.id'; if($result = mysqli_query($conn, $sql)) {
      if(mysqli_num_rows($result) > 0) { echo "<table>"; echo "<tr>"; echo "<th>id</th>"; echo "<th>name</th>"; echo "<th>id</th>"; echo "</tr>"; while($row = mysqli_fetch_array($result)){ echo "<tr>"; echo "<td>" . $row['id'] . "</td>";
            echo "<td>" . $row['name'] . "</td>"; echo "<td>" . $row['id'] . "</td>";
            echo "</tr>";
         }
         echo "</table>";
         mysqli_free_result($result); } else { echo "No records matching your query were found."; } } else { echo "ERROR: Could not able to execute $sql. " . mysqli_error($conn); } mysqli_close($conn);
?>

नमूना आउटपुट इस तरह होना चाहिए -

Connected successfully
id	name	id
1	sai	1
2	johar	2
3	raghu	3
4	ram	4

MySQL बाएँ शामिल हैं

एक MySQLi लेफ्ट जॉइन एक साधारण जॉइन से अलग है। एक MySQLi LEFT JOIN बाईं ओर स्थित तालिका पर अतिरिक्त विचार करता है।

यदि मैं एक LEFT JOIN करता हूं, तो मुझे उसी तरह से मेल खाने वाले सभी रिकॉर्ड मिलते हैं और ADDITION में मैं शामिल होने के बाएं टेबल में प्रत्येक बेजोड़ रिकॉर्ड के लिए एक अतिरिक्त रिकॉर्ड प्राप्त करता हूं - इस प्रकार यह सुनिश्चित करना (मेरे उदाहरण में) कि हर नाम प्राप्त होता है उल्लेख -

उदाहरण

लेफ्टिनेंट जोइन को समझने के लिए निम्नलिखित उदाहरण देखें -

root@host# mysql -u root -p password;
Enter password:*******

mysql> use TUTORIALS;
Database changed

mysql>SELECT a.id, a.name,b.id FROM tutorials_inf a LEFT JOIN tutorials_bks b ON a.id = b.id;

JOINS से ​​परिचित होने के लिए आपको अधिक अभ्यास करने की आवश्यकता होगी। यह MySQL / SQL में थोड़ी जटिल अवधारणा है और वास्तविक उदाहरण करते समय अधिक स्पष्ट हो जाएगी।

हमने एसक्यूएल देखा है SELECT साथ में आज्ञा WHERE MySQLi table से डेटा प्राप्त करने के लिए क्लॉज़, लेकिन जब हम एक शर्त देने की कोशिश करते हैं, जिसमें फ़ील्ड या कॉलम मान की तुलना की जाती है NULL, यह ठीक से काम नहीं करता है।

ऐसी स्थिति से निपटने के लिए MySQLi तीन ऑपरेटरों को प्रदान करता है

  • IS NULL - अगर कॉलम वैल्यू NULL है तो ऑपरेटर सही रिटर्न देता है।

  • IS NOT NULL - यदि कॉलम वैल्यू NULL नहीं है, तो ऑपरेटर सही है।

  • <=> - ऑपरेटर मूल्यों की तुलना करता है, जो (= ऑपरेटर के विपरीत) दो पूर्ण मूल्यों के लिए भी सही है।

NULL से जुड़ी शर्तें विशेष हैं। आप कॉलम में NULL मान देखने के लिए = NULL या! = NULL का उपयोग नहीं कर सकते। इस तरह की तुलना हमेशा विफल होती है क्योंकि यह बताना असंभव है कि वे सच हैं या नहीं। यहां तक ​​कि NULL = NULL विफल।

ऐसे कॉलम देखने के लिए जो NULL हैं या नहीं हैं, IS NULL या IS NOT NULL का उपयोग करें।

कमांड प्रॉम्प्ट पर NULL मान का उपयोग करना

मान लीजिए एक मेज tutorials_bks TUTORIALS डेटाबेस में और इसमें दो कॉलम होते हैं id तथा name, जहां एक NULL नाम इंगित करता है कि मान अज्ञात है -

उदाहरण

निम्नलिखित उदाहरण देखें -

root@host# mysql -u root -p password;
Enter password:*******

mysql> use TUTORIALS;
Database changed

mysql> INSERT INTO tutorials_bks (book) values('');
Query OK, 1 row affected (0.08 sec)

mysql> INSERT INTO tutorials_bks (book) values('');
Query OK, 1 row affected (0.08 sec)

mysql> INSERT INTO tutorials_bks (book) values('');
Query OK, 1 row affected (0.08 sec)

mysql> INSERT INTO tutorials_bks (book) values('NULL');
Query OK, 1 row affected (0.08 sec)

mysql> INSERT INTO tutorials_bks (book) values('NULL');
Query OK, 1 row affected (0.08 sec)

mysql> INSERT INTO tutorials_bks (book) values('NULL');
Query OK, 1 row affected (0.08 sec)

+----+---------+
| id | book    |
+----+---------+
|  1 | java    |
|  2 | java    |
|  3 | html    |
|  4 | c++     |
|  5 | Android |
|  6 |         |
|  7 |         |
|  8 |         |
|  9 | NULL    |
| 10 | NULL    |
| 11 | NULL    |
+----+---------+
11 rows in set (0.00 sec)

mysql>

रिकॉर्ड्स खोजने के लिए जहां नाम कॉलम है या NULL नहीं है, प्रश्नों को इस तरह लिखा जाना चाहिए -

mysql> SELECT * FROM tutorials_bks WHERE book = "null";
+----+------+
| id | book |
+----+------+
|  9 | NULL |
| 10 | NULL |
| 11 | NULL |
+----+------+
3 rows in set (0.00 sec)

mysql> SELECT * FROM tutorials_bks WHERE book ! = "null";
+----+---------+
| id | book    |
+----+---------+
|  1 | java    |
|  2 | java    |
|  3 | html    |
|  4 | c++     |
|  5 | Android |
|  6 |         |
|  7 |         |
|  8 |         |
+----+---------+
8 rows in set (0.00 sec)

mysql> SELECT * FROM tutorials_bks WHERE book = "";
+----+------+
| id | book |
+----+------+
|  6 |      |
|  7 |      |
|  8 |      |
+----+------+
3 rows in set (0.01 sec)

PHP स्क्रिप्ट में NULL मान को संभालना

यदि आप ... NULL मान के आधार पर क्वेरी तैयार करने के लिए शर्त का उपयोग कर सकते हैं ।

उदाहरण

निम्नलिखित उदाहरण बाहर से tutorial_count लेता है और फिर इसकी तुलना तालिका में उपलब्ध मूल्य से करता है।

<?php
   $dbhost = 'localhost:3036'; $dbuser = 'root';
   $dbpass = 'rootpassword'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) {
      die('Could not connect: ' . mysql_error());
   }
   if( isset($tutorial_count )) { $sql = 'SELECT tutorial_author, tutorial_count FROM  tcount_tbl
         WHERE tutorial_count = $tutorial_count'; } else { $sql = 'SELECT tutorial_author, tutorial_count
         FROM  tcount_tbl WHERE tutorial_count IS $tutorial_count'; } mysql_select_db('TUTORIALS'); $retval = mysql_query( $sql, $conn );
   
   if(! $retval ) { die('Could not get data: ' . mysql_error()); } while($row = mysql_fetch_array($retval, MYSQL_ASSOC)) { echo "Author:{$row['tutorial_author']}  <br> ".
         "Count: {$row['tutorial_count']} <br> ". "--------------------------------<br>"; } echo "Fetched data successfully\n"; mysql_close($conn);
?>

आपने MySQLi पैटर्न को मेल खाते हुए देखा है LIKE ...%। MySQLi नियमित अभिव्यक्तियों और के आधार पर एक अन्य प्रकार के पैटर्न मिलान ऑपरेशन का समर्थन करता हैREGEXPऑपरेटर। यदि आप PHP या PERL के बारे में जानते हैं, तो आपके लिए यह समझना बहुत सरल है क्योंकि यह मिलान नियमित स्क्रिप्टिंग के समान है।

निम्नलिखित पैटर्न की तालिका है, जिसका उपयोग किया जा सकता है REGEXP ऑपरेटर।

प्रतिरूप पैटर्न क्या मेल खाता है
^ स्ट्रिंग की शुरुआत
$ स्ट्रिंग का अंत
कोई एक ही पात्र
[...] वर्ग कोष्ठक के बीच सूचीबद्ध कोई भी वर्ण
[^ ...] वर्ग कोष्ठक के बीच कोई वर्ण सूचीबद्ध नहीं है
p1 | p2 | p3 प्रत्यावर्तन; किसी भी पैटर्न p1, P2, या p3 से मेल खाता है
* पूर्ववर्ती तत्व के शून्य या अधिक उदाहरण
+ पूर्ववर्ती तत्व का एक या अधिक उदाहरण
{N} n पूर्ववर्ती तत्व के उदाहरण
{मी, n} पूर्ववर्ती तत्व के n उदाहरणों के माध्यम से मी

उदाहरण

अब उपरोक्त तालिका के आधार पर, आप अपनी आवश्यकताओं को पूरा करने के लिए विभिन्न प्रकार के एसक्यूएल प्रश्नों को लिख सकते हैं। यहां, मैं आपकी समझ के लिए कुछ सूचीबद्ध कर रहा हूं। गौर कीजिए कि हमारे पास एक टेबल है, जिसे ट्यूटोरियल्स_फिन कहा जाता है और यह एक फील्ड है जिसका नाम है -

'सा' से शुरू होने वाले सभी नामों को खोजने की क्वेरी

mysql>  SELECT * FROM tutorials_inf WHERE name REGEXP '^sa';

नमूना आउटपुट इस तरह होना चाहिए -

+----+------+
| id | name |
+----+------+
|  1 | sai  |
+----+------+
1 row in set (0.00 sec)

'Ai' के साथ समाप्त होने वाले सभी नामों को खोजने की क्वेरी

mysql> SELECT * FROM tutorials_inf WHERE name REGEXP 'ai$';

नमूना आउटपुट इस तरह होना चाहिए -

+----+------+
| id | name |
+----+------+
|  1 | sai  |
+----+------+
1 row in set (0.00 sec)

सभी नामों को खोजने के लिए क्वेरी, जिसमें 'ए' है

mysql> SELECT * FROM tutorials_inf WHERE name REGEXP 'a';

नमूना आउटपुट इस तरह होना चाहिए -

+----+-------+
| id | name  |
+----+-------+
|  1 | sai   |
|  3 | ram   |
|  4 | johar |
+----+-------+
3 rows in set (0.00 sec)

एक स्वर से शुरू होने वाले सभी नामों को खोजने की क्वेरी

mysql>  SELECT * FROM tutorials_inf WHERE name REGEXP '^[aeiou]';

लेन-देन डेटाबेस हेरफेर संचालन का एक अनुक्रमिक समूह है, जो कि एक एकल कार्य इकाई के रूप में किया जाता है। दूसरे शब्दों में, एक लेनदेन कभी भी पूरा नहीं होगा जब तक कि समूह के भीतर प्रत्येक व्यक्तिगत ऑपरेशन सफल न हो। यदि लेन-देन के भीतर कोई भी संचालन विफल हो जाता है, तो संपूर्ण लेनदेन विफल हो जाएगा।

व्यावहारिक रूप से, आप एक समूह में कई एसक्यूएल प्रश्नों को क्लब करेंगे और आप एक लेनदेन के हिस्से के रूप में उन सभी को एक साथ निष्पादित करेंगे।

लेन-देन के गुण

लेन-देन में निम्नलिखित चार मानक गुण होते हैं, जिन्हें आमतौर पर संक्षिप्त ACID द्वारा संदर्भित किया जाता है -

  • Atomicity- यह सुनिश्चित करता है कि कार्य इकाई के भीतर सभी संचालन सफलतापूर्वक पूरा हो गए हैं; अन्यथा, विफलता के बिंदु पर लेन-देन निरस्त कर दिया जाता है और पिछले ऑपरेशनों को उनके पूर्व राज्य में वापस ले जाया जाता है।

  • Consistency - यह सुनिश्चित करता है कि डेटाबेस सफलतापूर्वक रूप से प्रतिबद्ध लेनदेन पर परिवर्तन करता है।

  • Isolation - लेनदेन को स्वतंत्र रूप से संचालित करने और एक दूसरे के लिए पारदर्शी बनाने में सक्षम बनाता है।

  • Durability - यह सुनिश्चित करता है कि प्रतिबद्ध लेनदेन का परिणाम या प्रभाव सिस्टम की विफलता के मामले में बना रहता है।

MySQL में, लेन-देन BEGIN WORK के साथ शुरू होता है और एक COMMIT या रोलबैक कथन के साथ समाप्त होता है। शुरुआत और अंत के बयानों के बीच SQLi आदेश लेन-देन के थोक बनाता है।

संचार और रोलबैक

ये दो कीवर्ड Commit तथा Rollback मुख्य रूप से MySQL लेनदेन के लिए उपयोग किया जाता है।

  • जब एक सफल लेनदेन पूरा हो जाता है, तो COMMIT आदेश जारी किया जाना चाहिए ताकि सभी शामिल तालिकाओं में परिवर्तन प्रभावी हो जाएं।

  • यदि कोई विफलता होती है, तो लेन-देन आदेश जारी किया जाना चाहिए ताकि लेन-देन में संदर्भित प्रत्येक तालिका को उसकी पिछली स्थिति में वापस किया जा सके।

आप सत्र चर नामक सेटिंग द्वारा लेनदेन के व्यवहार को नियंत्रित कर सकते हैं AUTOCOMMIT। यदि AUTOCOMMIT को 1 (डिफ़ॉल्ट) पर सेट किया जाता है, तो प्रत्येक SQL स्टेटमेंट (एक लेन-देन के भीतर या नहीं) को एक पूर्ण लेनदेन माना जाता है और इसे समाप्त होने पर डिफ़ॉल्ट रूप से प्रतिबद्ध किया जाता है। जब AUTOCOMMIT को 0 पर सेट किया जाता है, SET AUTOCOMMIT = 0 कमांड जारी करके, बाद की कथनों की श्रृंखला एक लेन-देन की तरह काम करती है और एक स्पष्ट COMMIT स्टेटमेंट जारी होने तक कोई गतिविधियां नहीं की जाती हैं।

आप इन SQL कमांड को PHP में प्रयोग करके निष्पादित कर सकते हैं mysqli_query() समारोह।

लेन-देन पर सामान्य उदाहरण

घटनाओं का यह क्रम उपयोग की जाने वाली प्रोग्रामिंग भाषा से स्वतंत्र है; जिस भी भाषा में आप अपने एप्लिकेशन को बनाने के लिए उपयोग करते हैं, तार्किक मार्ग बनाया जा सकता है।

आप इन SQL कमांड को PHP में प्रयोग करके निष्पादित कर सकते हैं mysqli_query() समारोह।

  • SQL कमांड जारी करके लेनदेन शुरू करें BEGIN WORK.

  • एक या एक से अधिक SQL कमांड जैसे SELECT, INSERT, UPDATE या DELETE जारी करें।

  • जांचें कि क्या कोई त्रुटि नहीं है और सब कुछ आपकी आवश्यकता के अनुसार है।

  • यदि कोई त्रुटि है, तो रोलबैक आदेश जारी करें, अन्यथा एक कमिट आदेश जारी करें।

MySQLi में Transaction-Safe Table Types

आप सीधे लेनदेन का उपयोग नहीं कर सकते, आप कर सकते हैं लेकिन वे सुरक्षित और गारंटीकृत नहीं होंगे। यदि आप अपने MySQLi प्रोग्रामिंग में लेनदेन का उपयोग करने की योजना बनाते हैं, तो आपको एक विशेष तरीके से अपनी तालिकाओं को बनाने की आवश्यकता है। कई प्रकार के टेबल हैं, जो लेनदेन का समर्थन करते हैं लेकिन सबसे लोकप्रिय हैInnoDB

MySQLi को स्रोत से संकलित करते समय InnoDB तालिकाओं के लिए समर्थन के लिए एक विशिष्ट संकलन पैरामीटर की आवश्यकता होती है। यदि आपके MySQLi संस्करण में InnoDB समर्थन नहीं है, तो अपने इंटरनेट सेवा प्रदाता को InnoDB तालिका प्रकारों के समर्थन के साथ MySQLi का एक संस्करण बनाने के लिए कहें या Windows या Linux / UNIX के लिए MySQL-Max बाइनरी वितरण को स्थापित करने और तालिका प्रकार के साथ काम करने के लिए कहें एक विकास का माहौल।

यदि आपकी MySQLi स्थापना InnoDB तालिकाओं का समर्थन करती है, तो बस a जोड़ें TYPE = InnoDBतालिका निर्माण कथन की परिभाषा। उदाहरण के लिए, निम्न कोड एक InnoDB तालिका बनाता है, जिसे tutorial_innodb कहा जाता है -

root@host# mysql -u root -p;
Enter password:*******

mysql> use TUTORIALS;
Database changed

mysql> create table tutorials_innodb
   -> (
   -> tutorial_author varchar(40) NOT NULL,
   -> tutorial_count  INT
   -> ) TYPE = InnoDB;
Query OK, 0 rows affected (0.02 sec)

अधिक जानकारी के लिए निम्न लिंक की जाँच करें - InnoDB

आप अन्य तालिका प्रकारों का उपयोग कर सकते हैं GEMINI या BDB, लेकिन यह आपकी स्थापना पर निर्भर करता है अगर यह इन दो प्रकारों का समर्थन करता है।

MySQLi ALTER जब आप अपनी तालिका का नाम बदलना चाहते हैं, तो कोई तालिका फ़ील्ड या यदि आप किसी तालिका में मौजूदा स्तंभ जोड़ना या हटाना चाहते हैं तो कमांड बहुत उपयोगी है।

आइए एक तालिका के निर्माण के साथ शुरू करें tutorials_alter

root@host# mysql -u root -p password;
Enter password:*******

mysql> use TUTORIALS;
Database changed

mysql> create table tutorials_alter
   -> (
   -> i INT,
   -> c CHAR(1)
   -> );
Query OK, 0 rows affected (0.27 sec)

mysql> SHOW COLUMNS FROM tutorials_alter;
+-------+---------+------+-----+---------+-------+
| Field | Type    | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| i     | int(11) | YES  |     | NULL    |       |
| c     | char(1) | YES  |     | NULL    |       |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.02 sec)

एक स्तंभ में जोड़ना, जोड़ना या पुनरावृत्ति करना

मान लीजिए कि आप किसी मौजूदा कॉलम को छोड़ना चाहते हैं i MySQLi तालिका के ऊपर से तब आप उपयोग करेंगे DROP साथ खंड ALTER आदेश निम्नानुसार है -

mysql> ALTER TABLE tutorials_alter  DROP i;

DROP काम नहीं करेगा यदि स्तंभ तालिका में केवल एक ही है।

स्तंभ जोड़ने के लिए, ADD का उपयोग करें और स्तंभ परिभाषा निर्दिष्ट करें। निम्न कथन पुनर्स्थापित करता हैi tutorial_alter पर कॉलम -

mysql> ALTER TABLE tutorials_alter ADD i INT;

इस कथन को जारी करने के बाद, वृषण में वही दो कॉलम होंगे जो उस समय थे जब आपने पहली बार तालिका बनाई थी, लेकिन इसमें समान संरचना नहीं होगी। ऐसा इसलिए क्योंकि डिफ़ॉल्ट रूप से तालिका के अंत में नए कॉलम जोड़े जाते हैं। तो इसके बावजूदi मूल रूप से mytbl में पहला कॉलम था, अब यह आखिरी है।

mysql> SHOW COLUMNS FROM tutorials_alter;
+-------+---------+------+-----+---------+-------+
| Field | Type    | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| c     | char(1) | YES  |     | NULL    |       |
| i     | int(11) | YES  |     | NULL    |       |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.01 sec)

यह इंगित करने के लिए कि आप तालिका के भीतर एक विशिष्ट स्थान पर एक स्तंभ चाहते हैं, या तो यह बताने के लिए कि पहले कॉलम या AFTER col_name बनाने के लिए पहले कॉलम का उपयोग करें ताकि नए कॉलम को col_name के बाद रखा जाए। हर एक के बाद कम रंगों का उपयोग करते हुए निम्न सारणी कथनों का उपयोग करके देखें कि प्रत्येक का क्या प्रभाव है -

ALTER TABLE testalter_tbl DROP i;
ALTER TABLE testalter_tbl ADD i INT FIRST;
ALTER TABLE testalter_tbl DROP i;
ALTER TABLE testalter_tbl ADD i INT AFTER c;

FIRST और AFTER निर्दिष्टकर्ता केवल ADD क्लॉज के साथ काम करते हैं। इसका मतलब यह है कि यदि आप किसी मौजूदा कॉलम को किसी तालिका के भीतर बदलना चाहते हैं, तो आपको पहले इसे डीआरओपी करना होगा और फिर इसे नए स्थान पर जोड़ना होगा।

स्तंभ की परिभाषा या नाम बदलना

स्तंभ की परिभाषा बदलने के लिए, का उपयोग करें MODIFY या CHANGEALTER कमांड के साथ क्लॉज। उदाहरण के लिए, कॉलम बदलने के लिएc CHAR (1) से CHAR (10) तक, यह करें -

mysql> ALTER TABLE tutorials_alter MODIFY c CHAR(10);

CHANGE के साथ, सिंटैक्स थोड़ा अलग है। CHANGE कीवर्ड के बाद, आप उस कॉलम को नाम देते हैं जिसे आप बदलना चाहते हैं, फिर नई परिभाषा निर्दिष्ट करें, जिसमें नया नाम शामिल है। निम्न उदाहरण देखें:

mysql> ALTER TABLE tutorials_alter CHANGE i j BIGINT;

यदि आप अब स्तंभ नाम बदले बिना BIGINT से INT में j कन्वर्ट करने के लिए CHANGE का उपयोग करते हैं, तो कथन अपेक्षित होगा -

mysql> ALTER TABLE tutorials_alter CHANGE j j INT;

अशक्त और डिफ़ॉल्ट मान विशेषताओं पर अन्य तालिका का प्रभाव -

जब आप किसी कॉलम को मोडिफाई या चेंज करते हैं, तो आप यह भी निर्दिष्ट कर सकते हैं कि कॉलम में NULL मान हो सकते हैं या नहीं और इसका डिफ़ॉल्ट मान क्या है। वास्तव में, यदि आप ऐसा नहीं करते हैं, तो MySQLi स्वचालित रूप से इन विशेषताओं के लिए मान प्रदान करता है।

यहाँ उदाहरण है, जहाँ NULL कॉलम में डिफ़ॉल्ट रूप से मान 100 नहीं होगा।

mysql> ALTER TABLE tutorials_alter 
   -> MODIFY j BIGINT NOT NULL DEFAULT 100;

यदि आप ऊपर दिए गए कमांड का उपयोग नहीं करते हैं, तो MySQLi सभी कॉलम में NULL मान भर देगा।

स्तंभ के डिफ़ॉल्ट मान को बदलना

आप ALTER कमांड का उपयोग करके किसी भी कॉलम के लिए एक डिफ़ॉल्ट मान बदल सकते हैं। निम्न उदाहरण देखें।

mysql> ALTER TABLE tutorials_alter ALTER j SET DEFAULT 1000;
mysql> SHOW COLUMNS FROM tutorials_alter;
+-------+------------+------+-----+---------+-------+
| Field | Type       | Null | Key | Default | Extra |
+-------+------------+------+-----+---------+-------+
| c     | char(10)   | YES  |     | NULL    |       |
| j     | bigint(20) | NO   |     | 1000    |       |
+-------+------------+------+-----+---------+-------+
2 rows in set (0.02 sec)

आप ALTER कमांड के साथ DROP क्लॉज का उपयोग करके किसी भी कॉलम से डिफ़ॉल्ट बाधा को हटा सकते हैं।

mysql> ALTER TABLE tutorials_alter ALTER j DROP DEFAULT;
mysql> SHOW COLUMNS FROM tutorials_alter;
+-------+------------+------+-----+---------+-------+
| Field | Type       | Null | Key | Default | Extra |
+-------+------------+------+-----+---------+-------+
| c     | char(10)   | YES  |     | NULL    |       |
| j     | bigint(20) | NO   |     | NULL    |       |
+-------+------------+------+-----+---------+-------+
2 rows in set (0.02 sec)

तालिका प्रकार बदलना

आप तालिका प्रकार का उपयोग करके उपयोग कर सकते हैं TYPE ALTER कमांड के साथ क्लॉज।

तालिका के वर्तमान प्रकार का पता लगाने के लिए, SHOW TABLE STATUS स्टेटमेंट का उपयोग करें।

mysql>  SHOW TABLE STATUS LIKE 'tutorials_alter'\G
*************************** 1. row ***************************
           Name: tutorials_alter
         Engine: InnoDB
        Version: 10
     Row_format: Compact
           Rows: 0
 Avg_row_length: 0
    Data_length: 16384
Max_data_length: 0
   Index_length: 0
      Data_free: 0
 Auto_increment: NULL
    Create_time: 2017-02-17 11:30:29
    Update_time: NULL
     Check_time: NULL
      Collation: latin1_swedish_ci
       Checksum: NULL
 Create_options:
        Comment:
1 row in set (0.00 sec)

एक तालिका का नाम बदलना

तालिका का नाम बदलने के लिए, का उपयोग करें RENAMEवैकल्पिक तालिका विवरण का विकल्प। नीचे दिए गए उदाहरण को आजमा कर देखें tutorial_alter को tutorials_bks का नाम बदलने के लिए।

mysql> ALTER TABLE tutorials_alter RENAME TO tutorials_bks;

MySQL फ़ाइल पर INDEX बनाने और छोड़ने के लिए आप ALTER कमांड का उपयोग कर सकते हैं। इस विशेषता को हम अगले अध्याय में देखेंगे।

एक डेटाबेस इंडेक्स एक डेटा संरचना है जो एक तालिका में संचालन की गति में सुधार करता है। अनुक्रमित एक या अधिक स्तंभों का उपयोग करके बनाया जा सकता है, जो तेजी से यादृच्छिक लुकअप और रिकॉर्ड तक पहुंच के कुशल आदेश दोनों के लिए आधार प्रदान करता है।

इंडेक्स बनाते समय, यह विचार किया जाना चाहिए कि एसक्यूएल क्वेरी बनाने के लिए और उन कॉलमों पर एक या अधिक इंडेक्स बनाने के लिए कौन से कॉलम का उपयोग किया जाएगा।

व्यावहारिक रूप से, इंडेक्स भी टेबल के प्रकार हैं, जो प्राथमिक कुंजी या इंडेक्स फ़ील्ड और प्रत्येक रिकॉर्ड को वास्तविक तालिका में एक संकेतक रखते हैं।

उपयोगकर्ता अनुक्रमित नहीं देख सकते हैं, उनका उपयोग केवल प्रश्नों को गति देने के लिए किया जाता है और बहुत तेजी से रिकॉर्ड का पता लगाने के लिए डेटाबेस सर्च इंजन द्वारा उपयोग किया जाएगा।

INSERT और UPDATE कथनों को अनुक्रमणिका वाले तालिकाओं पर अधिक समय लगता है, जहां उन तालिकाओं पर SELECT कथन तेजी से बनते हैं। कारण यह है कि इन्सर्ट या अपडेट करते समय, डेटाबेस को इंडेक्स मानों को भी सम्मिलित या अपडेट करने की आवश्यकता होती है।

सरल और अनोखा सूचकांक

आप एक तालिका पर एक अद्वितीय सूचकांक बना सकते हैं। एक अद्वितीय सूचकांक का मतलब है कि दो पंक्तियों में समान सूचकांक मान नहीं हो सकता है। यहां एक टेबल पर एक इंडेक्स बनाने का सिंटैक्स है।

CREATE UNIQUE INDEX index_name ON table_name ( column1, column2,...);

इंडेक्स बनाने के लिए आप एक या अधिक कॉलम का उपयोग कर सकते हैं। उदाहरण के लिए, हम NAME_INDEX का उपयोग करके tutorial_inf पर एक इंडेक्स बना सकते हैं।

CREATE UNIQUE INDEX NAME_INDEX ON tutorials_inf(name);

आप एक मेज पर एक साधारण सूचकांक बना सकते हैं। सरल इंडेक्स बनाने के लिए क्वेरी से बस UNIQUE कीवर्ड को छोड़ दें। सरल सूचकांक एक तालिका में डुप्लिकेट मानों की अनुमति देता है।

यदि आप किसी कॉलम में मूल्यों को अनुक्रमणित क्रम में अनुक्रमित करना चाहते हैं, तो आप कॉलम नाम के बाद आरक्षित शब्द DESC जोड़ सकते हैं।

mysql> CREATE UNIQUE INDEX NAME_INDEX ON tutorials_inf (name DESC);

INDEX को जोड़ने और छोड़ने के लिए ALTER कमांड

तालिका में अनुक्रमणिका जोड़ने के लिए चार प्रकार के कथन हैं -

  • ALTER TABLE tbl_name ADD PRIMARY KEY (column_list) - यह कथन एक प्राथमिक कुंजी जोड़ता है, जिसका अर्थ है कि अनुक्रमित मान अद्वितीय होना चाहिए और NULL नहीं हो सकता।

  • ALTER TABLE tbl_name ADD UNIQUE index_name (column_list) - यह कथन एक इंडेक्स बनाता है जिसके लिए मान अद्वितीय होने चाहिए (NULL मान के अपवाद के साथ, जो कई बार दिखाई दे सकते हैं)।

  • ALTER TABLE tbl_name ADD INDEX index_name (column_list) - यह एक साधारण सूचकांक जोड़ता है जिसमें कोई भी मूल्य एक से अधिक बार दिखाई दे सकता है।

  • ALTER TABLE tbl_name ADD FULLTEXT index_name (column_list) - यह एक विशेष FULLTEXT इंडेक्स बनाता है जो टेक्स्ट-सर्चिंग उद्देश्यों के लिए उपयोग किया जाता है।

मौजूदा तालिका में सूचकांक को जोड़ने का उदाहरण यहां दिया गया है।

mysql> ALTER TABLE tutorials_inf ADD INDEX (id);

आप ALTER कमांड के साथ DROP क्लॉज का उपयोग करके किसी भी INDEX को गिरा सकते हैं। ऊपर दिए गए इंडेक्स को छोड़ने के लिए निम्न उदाहरण देखें।

mysql> ALTER TABLE tutorials_inf DROP INDEX (c);

आप ALTER कमांड के साथ DROP क्लॉज का उपयोग करके किसी भी INDEX को गिरा सकते हैं। ऊपर दिए गए इंडेक्स को छोड़ने के लिए निम्न उदाहरण देखें।

प्राथमिक कुंजी जोड़ने और छोड़ने के लिए आदेश दें

आप उसी तरह से प्राथमिक कुंजी जोड़ सकते हैं। लेकिन यह सुनिश्चित करें कि प्राथमिक कुंजी स्तंभों पर काम करती है, जो पूर्ण नहीं हैं।

यहां मौजूदा तालिका में प्राथमिक कुंजी जोड़ने का उदाहरण है। यह एक कॉलम नॉट NULL बना देगा और फिर इसे एक प्राथमिक कुंजी के रूप में जोड़ देगा।

mysql>  ALTER TABLE tutorials_inf MODIFY id INT NOT NULL;
mysql> ALTER TABLE tutorials_inf ADD PRIMARY KEY (id);

आप निम्न प्रकार से एक प्राथमिक कुंजी को छोड़ने के लिए ALTER कमांड का उपयोग कर सकते हैं:

mysql> ALTER TABLE tutorials_inf DROP PRIMARY KEY;

एक इंडेक्स को छोड़ने के लिए जो एक प्राथमिक कुंजी नहीं है, आपको इंडेक्स नाम निर्दिष्ट करना होगा।

INDEX सूचना प्रदर्शित करना

तालिका से जुड़े सभी अनुक्रमित को सूचीबद्ध करने के लिए आप SHOW INDEX कमांड का उपयोग कर सकते हैं। वर्टिकल-फॉर्मेट आउटपुट (\ G द्वारा निर्दिष्ट) अक्सर इस कथन के साथ उपयोगी होता है, ताकि लंबी लाइन रैपराउंड से बचा जा सके -

निम्न उदाहरण देखें

mysql> SHOW INDEX FROM table_name\G
........

अस्थायी डेटा रखने के लिए कुछ मामलों में अस्थायी तालिकाएँ बहुत उपयोगी हो सकती हैं। अस्थायी तालिकाओं के लिए ज्ञात सबसे महत्वपूर्ण बात यह है कि वर्तमान ग्राहक सत्र समाप्त होने पर उन्हें हटा दिया जाएगा।

जैसा कि पहले कहा गया था, अस्थायी टेबल केवल तब तक चलेगी जब तक कि सत्र जीवित है। यदि आप एक PHP स्क्रिप्ट में कोड चलाते हैं, तो स्क्रिप्ट निष्पादित होने पर अस्थायी तालिका स्वचालित रूप से नष्ट हो जाएगी। यदि आप MySQLi क्लाइंट प्रोग्राम के माध्यम से MySQL डेटाबेस सर्वर से जुड़े हैं, तो अस्थायी टेबल तब तक मौजूद रहेगी जब तक आप क्लाइंट को बंद नहीं करते या मैन्युअल रूप से टेबल को नष्ट नहीं करते।

उदाहरण

यहाँ एक उदाहरण है जो आपको अस्थायी तालिका का उपयोग दिखा रहा है। PHP स्क्रिप्ट का उपयोग करके समान कोड का उपयोग किया जा सकता हैmysqli_query() समारोह।

mysql> CREATE TEMPORARY TABLE SalesSummary (
   -> product_name VARCHAR(50) NOT NULL
   -> , total_sales DECIMAL(12,2) NOT NULL DEFAULT 0.00
   -> , avg_unit_price DECIMAL(7,2) NOT NULL DEFAULT 0.00
   -> , total_units_sold INT UNSIGNED NOT NULL DEFAULT 0
   -> );
Query OK, 0 rows affected (0.00 sec)

mysql> INSERT INTO SalesSummary
   -> (product_name, total_sales, avg_unit_price, total_units_sold)
   -> VALUES
   -> ('cucumber', 100.25, 90, 2);

mysql> SELECT * FROM SalesSummary;
+--------------+-------------+----------------+------------------+
| product_name | total_sales | avg_unit_price | total_units_sold |
+--------------+-------------+----------------+------------------+
| cucumber     |      100.25 |          90.00 |                2 |
+--------------+-------------+----------------+------------------+
1 row in set (0.00 sec)

जब आप एक SHOW TABLES कमांड जारी करते हैं, तो आपकी अस्थायी तालिका सूची में बाहर सूचीबद्ध नहीं होगी। अब, यदि आप MySQLi सत्र से बाहर निकलेंगे और फिर आप SELECT कमांड जारी करेंगे, तो आपको डेटाबेस में उपलब्ध कोई डेटा नहीं मिलेगा। यहां तक ​​कि आपकी अस्थायी तालिका भी मौजूद नहीं होगी।

अस्थाई टेबलों को गिराना

डिफ़ॉल्ट रूप से, MySQLi द्वारा सभी अस्थायी तालिकाओं को हटा दिया जाता है जब आपका डेटाबेस कनेक्शन समाप्त हो जाता है। फिर भी यदि आप उन्हें बीच में हटाना चाहते हैं, तो आप DROP TABLE कमांड जारी करके ऐसा करते हैं।

निम्नलिखित एक अस्थायी तालिका छोड़ने पर उदाहरण है -

mysql> DROP TABLE SalesSummary;
mysql>  SELECT * FROM SalesSummary;
ERROR 1146: Table 'TUTORIALS.SalesSummary' doesn't exist

ऐसी स्थिति हो सकती है जब आपको किसी तालिका की सटीक प्रतिलिपि की आवश्यकता होती है और सृजन तालिका ... चयन आपके उद्देश्यों के अनुरूप नहीं होता है क्योंकि प्रतिलिपि में समान अनुक्रमित, डिफ़ॉल्ट मान और आगे शामिल होना चाहिए।

आप निम्न चरणों का पालन करके इस स्थिति को संभाल सकते हैं -

  • स्रोत तालिका की संरचना, अनुक्रमित और सभी को निर्दिष्ट करने वाली एक रचनात्मक तालिका कथन प्राप्त करने के लिए SHOW CREATE TABLE का उपयोग करें।

  • तालिका नाम को क्लोन तालिका में बदलने के लिए कथन को संशोधित करें और कथन को निष्पादित करें। इस तरह, आपके पास सटीक क्लोन तालिका होगी।

  • वैकल्पिक रूप से, यदि आपको तालिका की प्रतिलिपि बनाई गई सामग्री की आवश्यकता है, तो INSERT INTO ... चयन कथन भी जारी करें।

उदाहरण

के लिए एक क्लोन तालिका बनाने के लिए निम्नलिखित उदाहरण देखें tutorials_inf

चरण 1

तालिका के बारे में पूरी संरचना प्राप्त करें।

mysql> SHOW CREATE TABLE tutorials_inf \G;
*************************** 1. row ***************************
       Table: tutorials_inf
Create Table: CREATE TABLE `tutorials_inf` (
   `id` int(11) NOT NULL,
   `name` varchar(20) NOT NULL,
   PRIMARY KEY (`id`),
   UNIQUE KEY `AUTHOR_INDEX` (`name`),
   UNIQUE KEY `NAME_INDEX` (`name`),
   KEY `id` (`id`)
) ENGINE = InnoDB DEFAULT CHARSET = latin1
1 row in set (0.05 sec)

ERROR: No query specified

चरण 2

इस तालिका का नाम बदलें और दूसरी तालिका बनाएं।

mysql> CREATE TABLE tutorials_clone(
   -> id int(11) NOT NULL,
   -> name varchar(20) NOT NULL,
   -> PRIMARY KEY (id),
   > UNIQUE KEY AUTHOR_INDEX (name),
   -> UNIQUE KEY NAME_INDEX (name),
   ->  KEY id (id));
Query OK, 0 rows affected (1.80 sec)

चरण 3

चरण 2 को निष्पादित करने के बाद, आप अपने डेटाबेस में एक क्लोन तालिका बनाएंगे। यदि आप पुरानी तालिका से डेटा कॉपी करना चाहते हैं तो आप INSERT INTO ... सेलेक्ट स्टेटमेंट का उपयोग करके कर सकते हैं।

mysql> INSERT INTO tutorials_clone(id,name) SELECT id,name from tutorials_inf;
Query OK, 4 rows affected (0.19 sec)
Records: 4  Duplicates: 0  Warnings: 0

अंत में, आपके पास सटीक क्लोन तालिका होगी जैसा आप चाहते थे।

वहाँ तीन informations हैं, जो आप MySQLi से लेना चाहेंगे।

  • Information about the result of queries - इसमें किसी भी SELECT, UPDATE या DELETE स्टेटमेंट से प्रभावित रिकॉर्ड की संख्या शामिल है।

  • Information about tables and databases - इसमें टेबल और डेटाबेस की संरचना से संबंधित जानकारी शामिल है।

  • Information about the MySQLi server - इसमें डेटाबेस सर्वर की वर्तमान स्थिति, संस्करण संख्या आदि शामिल हैं।

यह सभी जानकारी mysqli प्रॉम्प्ट पर प्राप्त करना बहुत आसान है, लेकिन PERL या PHP APIs का उपयोग करते समय, हमें इन सभी सूचनाओं को प्राप्त करने के लिए स्पष्ट रूप से विभिन्न API को कॉल करने की आवश्यकता है। निम्नलिखित अनुभाग आपको दिखाएगा कि यह जानकारी कैसे प्राप्त करें।

एक क्वेरी से प्रभावित पंक्तियों की संख्या प्राप्त करना

पर्ल उदाहरण

DBI स्क्रिप्ट्स में, प्रभावित पंक्तियों की गिनती को () या निष्पादित () के आधार पर वापस किया जाता है, इस आधार पर कि आप क्वेरी को कैसे निष्पादित करते हैं -

# Method 1
# execute $query using do( ) my $count = $dbh->do ($query);
# report 0 rows if an error occurred
printf "%d rows were affected\n", (defined ($count) ? $count : 0);

# Method 2
# execute query using prepare( ) plus execute( )
my $sth = $dbh->prepare ($query); my $count = $sth->execute ( ); printf "%d rows were affected\n", (defined ($count) ? $count : 0);

PHP उदाहरण

PHP में, mysqli_affected_rows () फ़ंक्शन का पता लगाने के लिए कि कितनी पंक्तियों को एक क्वेरी में बदला गया है -

$result_id = mysqli_query ($query, $conn_id);
# report 0 rows if the query failed
$count = ($result_id ? mysqli_affected_rows ($conn_id) : 0); print ("$count rows were affected\n");

सूची सारणी और डेटाबेस

डेटाबेस सर्वर के साथ उपलब्ध सभी डेटाबेस और तालिकाओं को सूचीबद्ध करना बहुत आसान है। यदि आपके पास पर्याप्त विशेषाधिकार नहीं हैं तो आपका परिणाम शून्य हो सकता है।

नीचे दी गई विधि के अलावा, आप PHP या PERL में या तो तालिका या डेटाबेस की सूची प्राप्त करने के लिए SHOW TABLES या SHOW DATABASES प्रश्नों का उपयोग कर सकते हैं।

पर्ल उदाहरण

# Get all the tables available in current database.
my @tables = $dbh->tables ( ); foreach $table (@tables ){
   print "Table Name $table\n";
}

PHP उदाहरण

<?php
   $servername = "localhost:3306";
   $username = "root"; $password = "";
   $dbname = "TUTORIALS"; $conn = new mysqli($servername, $username, $password, $dbname);
   
   if ($conn->connect_error) { die("Connection failed: " . $conn->connect_error);
   } 
   echo"Database connected";
   $sql="SHOW DATABASES"; if (!($result = mysqli_query($conn,$sql))) {
      printf("Error: %s\n", mysqli_error($conn)); } while( $row = mysqli_fetch_row( $result ) ){ if (($row[0]!="information_schema") && ($row[0]!="mysql")) { echo $row[0]."\r\n";
      }
   }
   $conn->close();
?>

सर्वर मेटाडेटा प्राप्त करना

MySQL में निम्नलिखित कमांड हैं जिन्हें mysql प्रॉम्प्ट पर निष्पादित किया जा सकता है या डेटाबेस जैसी विभिन्न महत्वपूर्ण सूचना प्राप्त करने के लिए PHP जैसी किसी भी स्क्रिप्ट का उपयोग किया जा सकता है।

अनु क्रमांक। कमांड और विवरण
1

SELECT VERSION( )

सर्वर संस्करण स्ट्रिंग

2

SELECT DATABASE( )

वर्तमान डेटाबेस नाम (खाली यदि कोई नहीं)

3

SELECT USER( )

वर्तमान उपयोगकर्ता नाम

4

SHOW STATUS

सर्वर स्थिति संकेतक

5

SHOW VARIABLES

सर्वर कॉन्फ़िगरेशन चर

एक अनुक्रम पूर्णांक 1, 2, 3, का एक सेट है ... जो मांग पर क्रम में उत्पन्न होता है। अनुक्रम अक्सर डेटाबेस में उपयोग किए जाते हैं क्योंकि कई अनुप्रयोगों को एक अद्वितीय मूल्य वाले तालिका में प्रत्येक पंक्ति की आवश्यकता होती है और अनुक्रम उन्हें उत्पन्न करने का एक आसान तरीका प्रदान करते हैं। यह अध्याय बताता है कि MySQLi में दृश्यों का उपयोग कैसे किया जाता है।

AUTO_INCREMENT कॉलम का उपयोग करना

अनुक्रम का उपयोग करने के लिए MySQLi का सबसे सरल तरीका AUTO_INCREMENT के रूप में एक कॉलम को परिभाषित करना है और देखभाल करने के लिए बाकी चीजों को MySQLi पर छोड़ना है।

उदाहरण

निम्न उदाहरण देखें। यह तालिका बनाएगा और उसके बाद इस तालिका में कुछ पंक्तियाँ डालेगा जहाँ रिकॉर्ड आईडी देना आवश्यक नहीं है क्योंकि यह MySQLi द्वारा स्वतः संवर्धित है।

mysql>CREATE TABLE tutorials_auto(
   id INT UNSIGNED NOT NULL AUTO_INCREMENT, name VARCHAR(30) NOT NULL,PRIMARY KEY(id));
Query OK, 0 rows affected (0.28 sec)

mysql>INSERT INTO tutorials_auto(id,name) VALUES(NULL,'sai'),(NULL,'ram');
Query OK, 2 rows affected (0.12 sec)
Records: 2  Duplicates: 0  Warnings: 0

mysql> SELECT * FROM insect ORDER BY id;
+----+------+
| id | name |
+----+------+
|  1 | sai  |
|  2 | ram  |
+----+------+
2 rows in set (0.05 sec)

AUTO_INCREMENT मान प्राप्त करें

LAST_INSERT_ID () एक SQL फ़ंक्शन है, इसलिए आप इसे किसी भी क्लाइंट के भीतर से उपयोग कर सकते हैं जो समझता है कि SQL स्टेटमेंट कैसे जारी किया जाए। अन्यथा, PERL और PHP स्क्रिप्ट पिछले रिकॉर्ड के ऑटो वेतन वृद्धि मूल्य को पुनः प्राप्त करने के लिए विशेष कार्य प्रदान करते हैं।

पर्ल उदाहरण

क्वेरी द्वारा उत्पन्न AUTO_INCREMENT मान प्राप्त करने के लिए mysql_insertid विशेषता का उपयोग करें। यह विशेषता डेटाबेस हैंडल या स्टेटमेंट हैंडल के माध्यम से एक्सेस की जाती है, यह इस बात पर निर्भर करता है कि आप क्वेरी कैसे जारी करते हैं। निम्न उदाहरण इसे डेटाबेस हैंडल के माध्यम से संदर्भित करता है:

$dbh->do ("INSERT INTO tutorials_auto (name,date,origin)
VALUES('moth','2001-09-14','windowsill')");
my $seq = $dbh->{mysqli_insertid};

PHP उदाहरण

AUTO_INCREMENT मान उत्पन्न करने वाली क्वेरी जारी करने के बाद, mysql_insert_id () कॉल करके मान पुनः प्राप्त करें

mysql_query ("INSERT INTO tutorials_auto (name,date,origin)
VALUES('moth','2001-09-14','windowsill')", $conn_id); $seq = mysqli_insert_id ($conn_id);

एक मौजूदा अनुक्रम का नवीनीकरण

एक मामला हो सकता है जब आपने एक तालिका से कई रिकॉर्ड हटा दिए हों और आप सभी रिकॉर्डों को फिर से तैयार करना चाहते हों। यह एक सरल ट्रिक का उपयोग करके किया जा सकता है लेकिन आपको ऐसा करने में बहुत सावधानी बरतनी चाहिए यदि आपकी टेबल अन्य तालिका के साथ जुड़ रही है।

यदि आप यह निर्धारित करते हैं कि AUTO_INCREMENT कॉलम का आकार बदलना अपरिहार्य है, तो ऐसा करने का तरीका स्तंभ को तालिका से गिराना है, फिर इसे फिर से जोड़ें। निम्नलिखित उदाहरण से पता चलता है कि इस तकनीक का उपयोग करके कीट तालिका में आईडी मूल्यों को कैसे फिर से भरना है -

mysql> ALTER TABLE tutorials_auto DROP id;
mysql> ALTER TABLE tutorials_auto
   -> ADD id INT UNSIGNED NOT NULL AUTO_INCREMENT FIRST,
   -> ADD PRIMARY KEY (id);

एक विशेष मूल्य पर अनुक्रम शुरू करना

डिफ़ॉल्ट रूप से, MySQLi 1 से अनुक्रम शुरू करेगा, लेकिन आप तालिका निर्माण के समय किसी अन्य संख्या को भी निर्दिष्ट कर सकते हैं। निम्नलिखित उदाहरण है जहां MySQLi 100 से अनुक्रम शुरू करेगा।

mysql> CREATE TABLE tutorials_auto
   -> (
   -> id INT UNSIGNED NOT NULL AUTO_INCREMENT = 100,
   -> PRIMARY KEY (id),
   -> name VARCHAR(30) NOT NULL, 
   -> );

वैकल्पिक रूप से, आप तालिका बना सकते हैं और फिर ALTER TABLE के साथ प्रारंभिक अनुक्रम मान सेट कर सकते हैं।

mysql> ALTER TABLE tutorials_auto AUTO_INCREMENT = 100;

टेबल्स या परिणाम सेट में कभी-कभी डुप्लिकेट रिकॉर्ड होते हैं। कभी-कभी, इसकी अनुमति है लेकिन कभी-कभी डुप्लिकेट रिकॉर्ड को रोकने की आवश्यकता होती है। कभी-कभी, डुप्लिकेट रिकॉर्ड की पहचान करना और उन्हें तालिका से निकालना आवश्यक है। यह अध्याय वर्णन करेगा कि तालिका में होने वाले डुप्लिकेट रिकॉर्ड को कैसे रोका जाए और पहले से मौजूद डुप्लिकेट रिकॉर्ड को कैसे हटाया जाए।

तालिका में अनुलिपि से डुप्लिकेट रोकना

आप एक का उपयोग कर सकते हैं PRIMARY KEY या UNIQUEडुप्लिकेट रिकॉर्ड को रोकने के लिए उपयुक्त फ़ील्ड वाली तालिका पर अनुक्रमणिका। आइए एक उदाहरण लेते हैं: निम्न तालिका में ऐसी कोई अनुक्रमणिका या प्राथमिक कुंजी नहीं है, इसलिए यह पहले_नाम और अंतिम_नाम के लिए डुप्लिकेट रिकॉर्ड की अनुमति देगा।

CREATE TABLE person_tbl (
   first_name CHAR(20),
   last_name CHAR(20),
   sex CHAR(10)
);

इस तालिका में एक ही पहले और अंतिम नाम मानों के साथ कई रिकॉर्ड को रोकने के लिए, इसकी परिभाषा में एक प्राथमिक कुंजी जोड़ें। जब आप ऐसा करते हैं, तो अनुक्रमित स्तंभों को पूर्ण नहीं घोषित करना आवश्यक है, क्योंकि एक प्राथमिक कुंजी पूर्ण मानों की अनुमति नहीं देता है -

CREATE TABLE person_tbl (
   first_name CHAR(20) NOT NULL,
   last_name CHAR(20) NOT NULL,
   sex CHAR(10),
   PRIMARY KEY (last_name, first_name)
);

यदि आप तालिका में एक रिकॉर्ड सम्मिलित करते हैं जो स्तंभ या स्तंभों में मौजूदा रिकॉर्ड को डुप्लिकेट करता है, तो सूचकांक में एक अद्वितीय सूचकांक की उपस्थिति आम तौर पर एक त्रुटि का कारण बनती है।

उपयोग INSERT IGNORE बजाय INSERT। यदि कोई रिकॉर्ड मौजूदा रिकॉर्ड की नकल नहीं करता है, तो MySQLi इसे हमेशा की तरह सम्मिलित करता है। यदि रिकॉर्ड डुप्लिकेट है, तो IGNORE कीवर्ड MySQLi को त्रुटि उत्पन्न किए बिना इसे चुपचाप त्यागने के लिए कहता है।

निम्नलिखित उदाहरण में त्रुटि नहीं है और एक ही समय में यह डुप्लिकेट रिकॉर्ड नहीं डालेगा।

mysql> INSERT IGNORE INTO person_tbl (last_name, first_name)
   -> VALUES( 'Jay', 'Thomas');
Query OK, 1 row affected (0.00 sec)
mysql> INSERT IGNORE INTO person_tbl (last_name, first_name)
   -> VALUES( 'Jay', 'Thomas');
Query OK, 0 rows affected (0.00 sec)

उपयोग REPLACEINSERT के बजाय। यदि रिकॉर्ड नया है, तो इसे INSERT के समान ही डाला गया है। यदि यह एक डुप्लिकेट है, तो नया रिकॉर्ड पुराने को बदल देता है -

mysql> REPLACE INTO person_tbl (last_name, first_name)
   -> VALUES( 'Ajay', 'Kumar');
Query OK, 1 row affected (0.00 sec)

mysql> REPLACE INTO person_tbl (last_name, first_name)
   -> VALUES( 'Ajay', 'Kumar');
Query OK, 2 rows affected (0.00 sec)

INSERT IGNORE और REPLACE को आपके द्वारा अपनाए जाने वाले डुप्लिकेट-हैंडलिंग व्यवहार के अनुसार चुना जाना चाहिए। INSERT IGNORE डुप्लीकेट रिकॉर्ड्स के एक सेट को पहले रखता है और बाकी को डिस्क्राइब करता है। REPLACE डुप्लिकेट के एक सेट के अंतिम को रखता है और किसी भी पहले वाले को मिटा देता है।

विशिष्टता को लागू करने का दूसरा तरीका एक तालिका में एक प्राथमिक कुंजी के बजाय एक अद्वितीय सूचकांक जोड़ना है।

CREATE TABLE person_tbl (
   first_name CHAR(20) NOT NULL,
   last_name CHAR(20) NOT NULL,
   sex CHAR(10)
   UNIQUE (last_name, first_name)
);

गिनती और पहचान डुप्लिकेट

एक तालिका में first_name और last_name के साथ डुप्लिकेट रिकॉर्ड की गणना करने के लिए निम्नलिखित प्रश्न है।

mysql> SELECT COUNT(*) as repetitions, last_name, first_name
   -> FROM person_tbl
   -> GROUP BY last_name, first_name
   -> HAVING repetitions > 1;

यह क्वेरी person_tbl तालिका में सभी डुप्लिकेट रिकॉर्डों की सूची लौटाएगी। सामान्य तौर पर, डुप्लिकेट किए गए मानों के सेट की पहचान करने के लिए, निम्नलिखित करें -

  • निर्धारित करें कि कौन से कॉलम में ऐसे मान हैं जो डुप्लिकेट हो सकते हैं।

  • COUNT (*) के साथ कॉलम चयन सूची में उन कॉलमों को सूचीबद्ध करें।

  • समूह BY कॉलम में कॉलम को भी सूचीबद्ध करें।

  • एक HAVING क्लॉज जोड़ें जो समूह मानों को एक से अधिक होने की आवश्यकता के द्वारा अद्वितीय मानों को समाप्त करता है।

क्वेरी परिणाम से डुप्लिकेट को समाप्त करना:

आप उपयोग कर सकते हैं DISTINCT तालिका में उपलब्ध अद्वितीय अभिलेखों का पता लगाने के लिए सेलेक्ट स्टेटमेंट के साथ।

mysql> SELECT DISTINCT last_name, first_name
   -> FROM person_tbl
   -> ORDER BY last_name;

DISTINCT का एक विकल्प यह है कि आप जिन कॉलमों का चयन कर रहे हैं उनका नाम एक ग्रुप BY क्लॉज में जोड़ें। इसमें डुप्लिकेट को हटाने और निर्दिष्ट कॉलम में मूल्यों के केवल अद्वितीय संयोजनों का चयन करने का प्रभाव है -

mysql> SELECT last_name, first_name
   -> FROM person_tbl
   -> GROUP BY (last_name, first_name);

तालिका प्रतिस्थापन का उपयोग करके डुप्लिकेट को निकालना

यदि आपके पास किसी तालिका में डुप्लिकेट रिकॉर्ड हैं और आप उस तालिका से सभी डुप्लिकेट रिकॉर्ड निकालना चाहते हैं, तो यहां प्रक्रिया है -

mysql> CREATE TABLE tmp SELECT last_name, first_name, sex
   -> FROM person_tbl;
   -> GROUP BY (last_name, first_name);
mysql> DROP TABLE person_tbl;
mysql> ALTER TABLE tmp RENAME TO person_tbl;

किसी तालिका से डुप्लिकेट रिकॉर्ड को निकालने का एक आसान तरीका उस तालिका में एक INDEX या PRIMAY कुंजी जोड़ना है। यहां तक ​​कि अगर यह तालिका पहले से ही उपलब्ध है, तो आप इस तकनीक का उपयोग डुप्लिकेट रिकॉर्ड को हटाने के लिए कर सकते हैं और आप भविष्य में भी सुरक्षित रहेंगे।

mysql> ALTER IGNORE TABLE person_tbl 
   -> ADD PRIMARY KEY (last_name, first_name);