MySQLi - प्रशासन

चल रहा है और MySQLi सर्वर को बंद कर रहा है

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 - 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

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

प्रशासनिक 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 प्रदर्शन और आँकड़ों का विवरण।