|
Много често се налага да се изпълняват част от функциите на MySQL от конзолата. Това може единствено да направите, в случай че имате достап чрез SSH до вашия MySQL сървър. Но в какви случай се налага да използваме тези команди по този начин. Има много причини за тази работа. Ако искате да изпълните cronjob, да тествате дадена заявка, да прилистите активните процеси, да промените структората на дадена таблица, да преименувате дадена таблица в работен режим и много други ... .
Чрез този урок имам намерение да разгледам някой от тези примери и да създам един малък наръчник на програмистите, чрез който всеки желаещ може директно с Copy&Paste и правилните данни за достъп да изпълни командите, без да се пита, дали няма да направя нещо грешно в момета, като изпълня тази заявка, защото честно казано и аз си задавам винаги този въпрос, като изпълнявам команди от конзолата в работем режим на базата за данни. Просто се налага по някога, но всеки трябва да е подготвен за това. Ще разгледаме стъпка по стъпка различни видове примери като започнем от началото. Разбира се информация за всяка една команда може да получите в подробната документация на MySQL: http://dev.mysql.com/doc/mysql/en/index.html . Свързване с базата за данни CODE
С тази конада, чрез предаване на необходимите параметри:
се свързвате с MySQL сървъра и чак тогава можете да изпълнявате команди от конзолата. То е абсолютно същата работа, като използвате MySQL във вашите скриптове. Винаги преди изпълнение на заявка, трябва да се свържете с базата за данни. Важно! След като сте свързан с MySQL сървъра, не забравяйте след всяка команда да сложите символа ";". Показване статуса на базата за данни CODE
Чрез тази команда може да се сдобиете с информация за някои от особенностите на базата ви за данни. Показване на текущите процеси CODE
Чрез тази команда ви се показват текущите процеси и заявки към MySQL сървъра. Това често се използва, когато забележите че вашия сървър е затормозен и искате да видите какво точно в момента се изпълнява. В случай, че видите нещо странно и решите да успокоите малко сървъра, то тогава може да прекратите даден процес с командата kill CODE
<pid> е текущия номер на процеса Id, който стои от ляво в първата колона на таблицата. Изпълнение на заявка Изпълнението на заявката става съвсем нормално както го правите във вашите скриптове. (CREATE, SELECT, INSERT, UPDATE, REPLACE), предимството тук, е че получавате директна информация за случилото се, докато в скриптовете се надявате да не се появи грешка, която да подразни вашите потребители. Примерна заявка е: CODE
Като получавате съответно резултата в структурирана таблица с наименованията на полетата. +--------------+----------+----------+-----+ | <pole> | <pole> | +--------------+----------+----------+-----+ | xxx | xxx | | xxx | xxx | | xxx | xxx | | xxx | xxx | +--------------+----------+----------+-----+ 4 rows in set (0.00 sec) Преименуване на таблица Преименуването на таблица е много ефикасно, защото може да се извърши в реално време без да имате загуба на информация или сриване на сървъра. То се изпълнява с командата rename. CODE
Промяна с alter Промяната на структората на таблица се извършва с командата ALTER. Като пример ще въведем ново поле в някоя таблица: CODE
Създаване на dump, копие на таблица Създаването на dump (копие), може да стане за една отделна таблица или за цялата база за данни. Има няколко варианта за създаването на копие на таблица: Създаване на копие на цяла база за данни: CODE
Създаване копие на отделна таблица от базата за данни: CODE
Ако в горните два примера използвате опцията --opt, то тогава вашето копие, няма да съдържа отделни INSERT команди, а само един общ INSERT. В случай, че искате да копирате само информацията на една таблица или само структората на таблицата може да използвате следните опции: --no-create-info - създава копие без информация за структората на таблицата --no-data - създава копие само на структората, без информацията от таблицата.
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||









