INFORMATICS

The Best

Przełącznik języka

Zaproś mnie na KAWE

Jeżeli podoba Ci się strona i chcesz wspomóc projekt!

Postaw mi kawę na buycoffee.to

This Site

Płatnik

CMS

Hardware

Uncategorised

Emulators

Powershell

Storage Array

DNS

FORTINET

Antivirus program

Licznik

3.png0.png7.png1.png4.png5.png9.png
Today101
Yesterday863
This week3974
This month21972
Total3071459

Visitor Info

  • IP: 13.59.68.161
  • Browser: Unknown
  • Browser Version:
  • Operating System: Unknown

Who Is Online

2
Online

środa, 25 grudzień 2024 02:15

Komendy MYSQL

Ocena użytkowników: 3 / 5

Gwiazdka aktywnaGwiazdka aktywnaGwiazdka aktywnaGwiazdka nieaktywnaGwiazdka nieaktywna
 

SQL jest językiem 4-generacji (4GL) jest niezależny od platform i produktu jest językiem strukturalnym
 
Podstawowe komendy do pracy z MySQL:
Logowanie z unix shell użyj opcji -h
     # [mysql dir]/bin/mysql -h hostname -u user -p 

Po zalogowaniu otrzymasz linię zachęty ze znakiem

mysql>

Tworzenie nowej bazy

Przykład komendy gdzie logującym się jest user - root

mysql -h localhost -u root -p

Zakończenie pracy z konsolą

mysql> \q lub

mysql> quit

mysql> \help     - podstawowe komendy - pomoc

mysql> \s         - sprawdzenie statusu serwera

Przydatne zapytania:

SELECT version();

lub zapytanie bardziej złożone:

SELECT Version(), Now(), user(), current_date():

Rozpoczynamy pracę z bazą danych
     mysql> create database [nazwabazy];
Pokaż wszystkie zapisane bazy
     mysql> show databases;
Tworzenie tabeli
  mysql> CREATE table [nazwa tabeli];
  Przykład:
      mysql> CREATE TABLE example (
         id INT,
         data VARCHAR(100)
       );

 Wybór bazy danych - przełączanie pomiędzy bazami
     mysql> use [db name];
 Pokaż tabele w wybranej bazie danych
     mysql> show tables;
Wynik
mysql> SHOW CREATE TABLE example;
+---------+------------------------------------------------+
| Table   | Create Table                                   |
+---------+------------------------------------------------+
| example | CREATE TABLE `example` (
  `id` int(11) default NULL,
  `data` varchar(100) default NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin2 |
+---------+------------------------------------------------+
1 row in set (0.00 sec)

Pokaż strukturę tabeli - formaty pól
    mysql> describe [nazwa tabeli];
    mysql> explain  [nazwa tabeli];
Wynik
+-------+--------------+------+-----+---------+-------+
| Field | Type         | Null | Key | Default | Extra |
+-------+--------------+------+-----+---------+-------+
| id    | int(11)      | YES  |     | NULL    |       |
| data  | varchar(100) | YES  |     | NULL    |       |
+-------+--------------+------+-----+---------+-------+
2 rows in set (0.00 sec)

Usunięcie bazy danych
    mysql> drop database [nazwa bazy];
Usunięcie tabeli
    mysql> drop table [table name];

Przeglądanie danych MYSQL

Przykłady SELECT
WHERE
SELECT * FROM pracownik WHERE pensja > 2500
SELECT * FROM pracownik WHERE (pensja >= 1500) AND (pensja <

2500)
LIKE
SELECT * FROM nazwa_tabeli WHERE nazwa_kolumny LIKE wyrażenie
SELECT * FROM pracownik WHERE nazwisko LIKE ‘Kwia%’ - wyświetla

nazwiska zaczynające się na Kwia
SELECT * FROM pracownik WHERE id_pracownika LIKE ‘%ski'

wyświetla nazwiska kończące sią na ski
SELECT * FROM pracownik WHERE imie LIKE ‘_ar%’ - wyświetla

imiona których 3 i 4 litera to "ar"

Znaki specjalne z polecenia SELECT
"_" - zastępuje dowolny pojedynczy znak - przykład LIKE '_ar_'

oznacza że szukane wyrażenie posiada dowolną pierwszą i ostatną

literę a środkowe litery to "ar"
"%" - dowolny ciąg znaków o dowolnej długości również zerowej -

przykład LIKE 'ar%' oznacza wszystkie wyraz rozpoczynające się

na "ar" łącznie z wyrazem "ar"
"[]" - dowolny ciąg znaków z określonego zakresu - przykład LIKE

'[a-c]%' - oznacza wszystkie wyrazy o dowolnej długości

rozpoczynające się od litery z przedziału a-c
"^" - dowolny ciąg znaków nie pasujący do zakresu - przykład

LIKE '[^a-c]%' - oznacza wszystkie wyrazy o dowolnej długości

których pierwsza litera nie jest literą z przedziału "a-c"

BETWEEN - pozwala określić zakres z operatorem WHERE
SELECT * FROM nazwa_tabeli WHERE (nazwa_kolumny BETWEEN x AND y)
SELECT * FROM pracownik WHERE (id_pracownika BETWEEN 1 AND 220)
Przykład wyświetla rekordy z zakresu gdzie id_pracownika jest pomiędzy 1 a 220


IN - pozwala wskazać rekordy należące do określonego zbioru
SELECT * FROM pracownik WHERE (id_pracownika IN (22, 33))
Wyświetli pracowników których "id_pracownika" to 22 oraz 33

 COUNT - zwraca liczbę rekordów określonych frazą WHERE

select count(*) from LOKAL where CENA<9000;

Zapytanie złożone

select
count(distinct if(CENA<9000, ID, null))
as liczba_aut_tanszych,
avg(if(CENA<100000, CENA, null))
as srednia_cena_pojaut_tanszych,
count(distinct if(CENA>9000, ID, null))
as liczba_aut_drozszych,
avg(if(CENA>9000, CENA, null))
as srednia_cena_pojaut_drozszych
from LOKAL;

 

Pokaż wszystkie dane w tabeli
    mysql> SELECT * FROM [table name];
Pokaż informacje o kolumnach w wybranej tabeli
    mysql> show columns from [nazwa tabeli];
Pokaż wybrane rzędy tabeli z wartościa “xxxx”
    mysql> SELECT * FROM [table name] WHERE [field name] =

"xxxx";
Pokaż wszystkie rekordy zawierające wartość Anton  i numer

telefonu '601673345'.
    mysql> SELECT * FROM [table name] WHERE name = "Anton" AND

phone_number =   '60167336666';
Pokaż wszystkie rekordy które nie zawierają nazwy „Anton” i

numeru telefonu”6016666” porządkując je polem phone_number
    mysql> SELECT * FROM [table name] WHERE name != "Bob" AND

phone_number = '67343434' order by phone_number;
Pokaż wszystkie rekordy rozpoczynające się literą ‘An’ i numerem

telefonu ‘60432452’.
    mysql> SELECT * FROM [table name] WHERE name like "An%" AND

phone_number = '65326453';
Pokaż wszystkie rekordy rozpoczynające się z litery “An” i

numeru telefonu ‘6016666’ ograniczając rekord 1 z 5
    mysql> SELECT * FROM [table name] WHERE name like "Bob%" AND

phone_number = '64563345' limit 1,5;
Użyj regularnego wyrażenia by znaleźć rekord. Używając “REGECP

BINARY” w celu zwiększenia czułości oraz znalezienia dowolnych

rekordow zaczynajacych się od „a”
    mysql> SELECT * FROM [table name] WHERE rec RLIKE "^a";
Pokaż unikalne rekordy
    mysql> SELECT DISTINCT [column name] FROM [table name];
Pokaż wybrane rekordy sortowane rosnąco (asc) lub malejąco

(desc)
    mysql> SELECT [col1],[col2] FROM [table name] ORDER BY

[col2] DESC;
Zwróć liczbę rzędów
    mysql> SELECT COUNT(*) FROM [table name];
Suma kolumn
    mysql> SELECT SUM(*) FROM [table name];
Dołącz do tabel wspólne kolumny
    mysql> select lookup.illustrationid,

lookup.personid,person.birthday from lookup left join person on

lookup.personid=person.personid=statement to join birthday in

person table with primary illustration id;
 
Tworzenie nowego użytkownika logując się jako root.
Połącz sie do bazy mysql i uaktualnij uprawnienia
    # mysql -u root -p
    mysql> use mysql;
    mysql> INSERT INTO user (Host,User,Password) VALUES

('%','username',PASSWORD  ('password'));
    mysql> flush privileges;
Zmień hasło użytkownika z powłoki unixa
    # [mysql dir]/bin/mysqladmin -u username -h

hostname.blah.org -p password 'new-password'
Zmień hasło użytkownika z MySQL prompt zaloguj się jako root

oraz ustaw hasło. Odśwież uprawnienia
    # mysql -u root -p
    mysql> SET PASSWORD FOR 'user'@'hostname' = PASSWORD

('passwordhere');
    mysql> flush privileges;
Odzyskaj hasło roota z MySQL zatrzymaj proces serwera uruchom

ponownie bez uprawnień do tabeli załoguj się ponownie do MySQL

jako root. Ustaw nowe hasło potem wyjdź z MySQL i urochom

ponownie serwer.
    # /etc/init.d/mysql stop
   #  mysqld_safe --skip-grant-tables &
    # mysql -u root
    mysql> use mysql;
    mysql> update user set password=PASSWORD("newrootpassword")

where User='root';
    mysql> flush privileges;
    mysql> quit
    # /etc/init.d/mysql stop
    # /etc/init.d/mysql start
Utwórz nowe hasło użytkownika root będąc zalogowany jako root
    # mysqladmin -u root password newpassword
Zmień hasło użytkownika root
    # mysqladmin -u root -p oldpassword newpassword
Pozwól aby użytkownik "bob" połączył się do serwera z  localnego

hosta używając hasła  "passwd". Logując się jako root przełącz

do bazy MySQL dodaj oraz uaktualnij uprawnienia.
    # mysql -u root -p
    mysql> use mysql;
    mysql> grant usage on *.* to bob@localhost identified by

'passwd';
    mysql> flush privileges;
Przydziel użytkownikowi uprawnienia dla bazy Zaloguj się jako

root przełącz do bazy MySQL, przyznaj oraz uaktualnij

uprawnienia
    # mysql -u root -p
    mysql> use mysql;
    mysql> INSERT INTO user

(Host,Db,User,Select_priv,Insert_priv,Update_priv,Delete_priv,Cr

eate_priv,Drop_priv) VALUES

('%','databasename','username','Y','Y','Y','Y','Y','N');
mysql> flush privileges;  or      mysql> grant all privileges on

databasename.* to username@localhost;
    mysql> flush privileges;
Uaktualnij informacje zawarte w tabeli
    mysql> UPDATE [table name] SET Select_priv = 'Y',Insert_priv

= 'Y',Update_priv = 'Y' where     [field name] = 'user';
Usuń rząd z tabeli
    mysql> DELETE from [table name] where [field name] =

'whatever';

Odśwież uprawnienia dostępy
    mysql> flush privileges;

Usuń kolumne
    mysql> alter table [table name] drop column [column name];

Dodaj kolumne do bazy.
    mysql> alter table [table name] add column [new column name]

varchar (20);

Zmień nazwę kolumny.
    mysql> alter table [table name] change [old column name]

[new column name] varchar (50);

Wykonaj unikalną kolumnę aby zabezpieczyć się przed oszustwem.
    mysql> alter table [table name] add unique ([column name]);
Zwiększ rozmiar kolumny.
    mysql> alter table [table name] modify [column name]

VARCHAR(3);

Usuń unikalną tabelę.
    mysql> alter table [table name] drop index [colmn name];

Wczytaj pliki CSV do tabeli
    mysql> LOAD DATA INFILE '/tmp/filename.csv' replace INTO

TABLE [table name] FIELDS TERMINATED BY ',' LINES TERMINATED BY

'\n' (field1,field2,field3);

Wykonaj backup WSZYSTKICH baz danych. Plik backupu jest SQL

komenda odtworzenia całej bazy
    # [mysql dir]/bin/mysqldump -u root -p password --opt

>/tmp/alldatabases.sql

Zrzuć jedną baze danych do backupu.
    # [mysql dir]/bin/mysqldump -u username -p password --

databases databasename   >/tmp/databasename.sql

Zrzuć tabelę z bazy.
    # [mysql dir]/bin/mysqldump -c -u username -p password

databasename tablename  > /tmp/databasename.tablename.sql

Odzyskaj bazę lub tabele z backupu.
    # [mysql dir]/bin/mysql -u username -p password databasename

< /tmp/databasename.sql

Utwórz tabele przykład 1.
    mysql> CREATE TABLE [table name] (firstname VARCHAR(20),

middleinitial VARCHAR(3),   lastname VARCHAR(35),suffix VARCHAR

(3),officeid VARCHAR(10),userid VARCHAR (15),username VARCHAR

(8),email VARCHAR(35),phone VARCHAR(25), groups VARCHAR

(15),datestamp DATE,timestamp time,pgpemail VARCHAR(255));

Utwórz tabelę przykład 2.
mysql> create table [table name] (personid int(40) not null

auto_increment primary key,firstname varchar(35),middlename

varchar(40),lastnamevarchar(40) default 'bato'); 

Przykład 3.
mysql -u[tutaj wpisz użytkownika z pełnym dostępem do bazy] -p
Enter password:[podaj hasło]
mysql> CREATE DATABASE projekt CHARACTER SET utf8 COLLATE

utf8_polish_ci;
mysql> GRANT USAGE ON projekt.* TO projekt@localhost;
mysql> GRANT ALL ON projekt.* TO projekt@localhost IDENTIFIED BY

'twoje_hasło';
mysql> flush privileges;
mysql> use projekt;

Wykonywanie komend w trybie wsadowym:
mysql> mysql < FilaName;

 

 

 

Search