MySQL - प्रशासन

चल रहा है और 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: ******

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

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 - MySQL SQL कमांड के अंत में एक अर्ध उपनिवेश (?) देने तक एक कमांड को समाप्त नहीं करता है।

/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

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

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

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

  • USE Databasename - यह MySQL workarea में एक डेटाबेस का चयन करने के लिए इस्तेमाल किया जाएगा।

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

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

  • SHOW COLUMNS FROM tablename: किसी तालिका के लिए NULL अनुमति, चूक, और अन्य जानकारी के गुण, प्रकार, महत्वपूर्ण जानकारी दिखाता है।

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

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

अगले अध्याय में, हम चर्चा करेंगे कि MySQL में PHP सिंटैक्स का उपयोग कैसे किया जाता है।