Uporaba pogledov MySQL v Debianu 7

Uporaba pogledov MySQL v Debianu 7

Uvod

MySQL ima odlično funkcijo, znano kot "pogledi". Pogledi so shranjene poizvedbe. Pomislite nanje kot vzdevek za sicer dolgo poizvedbo. V tem priročniku vam bom pokazal, kako uporabljati poglede za učinkovitejšo organizacijo podatkov.

Predpogoji

  • Oblačni strežnik Vultr SSD, naložen z Debianom 7.
  • Uporabnik s skrbniškimi (root) pravicami.
  • Osnovno poznavanje Linuxa, ukazne vrstice in SSH.

Prvi korak - Namestite strežnik MySQL

Namestitev MySQL v Debian 7.x je zelo enostavna. Najprej moramo zagotoviti, da so naši viri posodobljeni z izvajanjem:

sudo apt-get update

Nato lahko namestimo strežnik MySQL:

sudo apt-get install -y mysql-server

Prikazalo se bo pogovorno okno, ki vas bo pozvalo, da ustvarite geslo za "root" uporabnika. Prepričajte se, da si zapomnite to geslo.

Okrepimo varnost naše namestitve z izvedbo:

sudo mysql_secure_installation

Po izvedbi se vam bo predstavila vrsta pozivov. Spodaj je prikazan vsak od odgovorov, ki jih morate izbrati.

...
Enter current password for root (enter for none):
OK, successfully used password, moving on...
...
Set root password? [Y/n] y
New password:
Re-enter new password:
Password updated successfully!
Reloading privilege tables..
 ... Success!
...
Remove anonymous users? [Y/n] y
 ... Success!
...
Disallow root login remotely? [Y/n] y
 ... Success!
Remove test database and access to it? [Y/n] y
 - Dropping test database...
 ... Success!
...
Reload privilege tables now? [Y/n] y
 ... Success!
Cleaning up...

Drugi korak - Namestite vzorčno bazo podatkov

Trenutno na strežniku nimamo podatkov, s katerimi bi lahko eksperimentirali. Za to vadnico bomo uporabljali bazo podatkov zaposlenih, saj je z njo enostavno delati in je prosto dostopna na spletnem mestu MySQL.

sudo wget https://launchpad.net/test-db/employees-db-1/1.0.6/+download/employees_db-full-1.0.6.tar.bz2

Namestiti bzip2moramo, da lahko izvlečemo datoteko.

sudo apt-get install bzip2

Ekstrahirajte bazo podatkov. Datoteka je precej velika, zato lahko traja nekaj trenutkov.

sudo bzip2 -dfv employees_db-full-1.0.6.tar.bz2
sudo tar -xf employees_db-full-1.0.6.tar

Ko je datoteka ekstrahirana, boste imeli mapo z naslovom employees_db. Za namestitev baze podatkov se moramo pomakniti v ta imenik.

cd employees_db 
ls -l

Izhod bo videti takole:

-rw-r--r--. 1 501 games       752 Mar 30  2009 Changelog
-rw-r--r--. 1 501 games      6460 Oct  9  2008 employees_partitioned2.sql
-rw-r--r--. 1 501 games      7624 Feb  6  2009 employees_partitioned3.sql
-rw-r--r--. 1 501 games      5660 Feb  6  2009 employees_partitioned.sql
-rw-r--r--. 1 501 games      3861 Nov 28  2008 employees.sql
-rw-r--r--. 1 501 games       241 Jul 30  2008 load_departments.dump
-rw-r--r--. 1 501 games  13828291 Mar 30  2009 load_dept_emp.dump
-rw-r--r--. 1 501 games      1043 Jul 30  2008 load_dept_manager.dump
-rw-r--r--. 1 501 games  17422825 Jul 30  2008 load_employees.dump
-rw-r--r--. 1 501 games 115848997 Jul 30  2008 load_salaries.dump
-rw-r--r--. 1 501 games  21265449 Jul 30  2008 load_titles.dump
-rw-r--r--. 1 501 games      3889 Mar 30  2009 objects.sql
-rw-r--r--. 1 501 games      2211 Jul 30  2008 README
-rw-r--r--. 1 501 games      4455 Mar 30  2009 test_employees_md5.sql
-rw-r--r--. 1 501 games      4450 Mar 30  2009 test_employees_sha.sql

Izvedite naslednji ukaz, da se povežete s strežnikom MySQL, ustvarite bazo podatkov in uvozite podatke:

sudo mysql -h localhost -u root -p -t < employees.sql

Prikaže se poziv, ki bo zahteval vaše root geslo. To je geslo, ki ste ga nastavili v prvem koraku.

Ker je baza podatkov precej velika, bo za popoln uvoz podatkov verjetno trajalo od 1 do 3 minute. Če je bilo vse opravljeno pravilno, boste videli naslednji rezultat.

+-----------------------------+
| INFO                        |
+-----------------------------+
| CREATING DATABASE STRUCTURE |
+-----------------------------+
+------------------------+
| INFO                   |
+------------------------+
| storage engine: InnoDB |
+------------------------+
+---------------------+
| INFO                |
+---------------------+
| LOADING departments |
+---------------------+
+-------------------+
| INFO              |
+-------------------+
| LOADING employees |
+-------------------+
+------------------+
| INFO             |
+------------------+
| LOADING dept_emp |
+------------------+
+----------------------+
| INFO                 |
+----------------------+
| LOADING dept_manager |
+----------------------+
+----------------+
| INFO           |
+----------------+
| LOADING titles |
+----------------+
+------------------+
| INFO             |
+------------------+
| LOADING salaries |
+------------------+

Zdaj se lahko prijavimo v MySQL in si ogledamo uvožene podatke.

sudo mysql -h localhost -u root -p

Vnesite korensko geslo, ki ste ga nastavili v prejšnjem razdelku.

Preverite seznam baz podatkov za našo novo ustvarjeno bazo podatkov zaposlenih .

show databases;

Izhod bo videti takole:

+--------------------+
| Database           |
+--------------------+
| information_schema |
| employees          |
| mysql              |
| performance_schema |
+--------------------+
4 rows in set (0.01 sec)

Uporabimo bazo zaposlenih .

use employees;

Preverite tabele v njej.

show tables;

To bo izpisalo:

+---------------------+
| Tables_in_employees |
+---------------------+
| departments         |
| dept_emp            |
| dept_manager        |
| employees           |
| salaries            |
| titles              |
+---------------------+
6 rows in set (0.01 sec)

Tretji korak - Ustvarjanje, uporaba in odstranjevanje pogledov

V tem koraku se boste naučili ustvarjati in uporabljati poglede. Ta korak sem razdelil na manjše dele za ujemanje podatkov in združevanje podatkov za organizacijo. Čas je, da začnemo komunicirati z našimi testnimi podatki.

Spajanje/ujemanje podatkov

Spodaj imam poizvedbo, ki prikazuje vse zaposlene, ki imajo letno plačo enako ali večjo od 50.000 $.

select * from salaries where salary >= 50000;

Izhod (okrnjeno):

+--------+--------+------------+------------+
| emp_no | salary | from_date  | to_date    |
+--------+--------+------------+------------+
|  10001 |  60117 | 1986-06-26 | 1987-06-26 |
|  10001 |  62102 | 1987-06-26 | 1988-06-25 |
|  10001 |  66074 | 1988-06-25 | 1989-06-25 |
|  10001 |  66596 | 1989-06-25 | 1990-06-25 |
|  10001 |  66961 | 1990-06-25 | 1991-06-25 |
(...)

Kot lahko vidite, to prikazuje samo številke zaposlenih. To bi lahko bila nadloga, ko poskušate hitro identificirati zaposlenega. Na srečo lahko ustvarimo pogled, ki bo shranil precej dolgo poizvedbo, ki lahko poveže številke zaposlenih z imeni zaposlenih, tako da povlečemo in primerjamo podatke iz več tabel. Poizvedba je prikazana spodaj.

select employees.first_name,employees.last_name,employees.emp_no,salaries.salary,salaries.to_date,salaries.from_date from employees, salaries where employees.emp_no = salaries.emp_no;

Upoštevajte, kako sem izpustil >= 50000poizvedbo. To vrednost bomo uporabili, ko bo naš pogled ustvarjen.

Za ustvarjanje pogleda preprosto dodamo create view view_name aspoizvedbi. V tem primeru bom ustvaril pogled z imenom named_salaries .

create view named_salaries as select employees.first_name,employees.last_name,employees.emp_no,salaries.salary,salaries.to_date,salaries.from_date from employees, salaries where employees.emp_no = salaries.emp_no;

Podatke iz pogleda prikažemo na enak način kot podatke iz tabele.

select * from named_salaries

Če je bil pogled pravilno ustvarjen, boste videli naslednji izhod (podatki so bili skrajšani):

+------------+-----------+--------+--------+------------+------------+
| first_name | last_name | emp_no | salary | to_date    | from_date  |
+------------+-----------+--------+--------+------------+------------+
| Georgi     | Facello   |  10001 |  60117 | 1987-06-26 | 1986-06-26 |
| Georgi     | Facello   |  10001 |  62102 | 1988-06-25 | 1987-06-26 |
| Georgi     | Facello   |  10001 |  66074 | 1989-06-25 | 1988-06-25 |
| Georgi     | Facello   |  10001 |  66596 | 1990-06-25 | 1989-06-25 |
| Georgi     | Facello   |  10001 |  66961 | 1991-06-25 | 1990-06-25 |
| Georgi     | Facello   |  10001 |  71046 | 8  1992-06-24 | 1991-06-25 |
(...)

Ker lahko s pogledi komuniciramo na enak način kot s tabelo, je mogoče vzeti >= 50000izvirno poizvedbo in jo uporabiti za pogled.

select * from named_salaries where salary >= 50000;

Izhod (okrnjeno):

+------------+-----------+--------+--------+------------+------------+
| first_name | last_name | emp_no | salary | to_date    | from_date  |
+------------+-----------+--------+--------+------------+------------+
| Georgi     | Facello   |  10001 |  60117 | 1987-06-26 | 1986-06-26 |
(...)
| Bezalel    | Simmel    |  10002 |  65828 | 1997-08-03 | 1996-08-03 |
(...)
| Chirstian  | Koblick   |  10004 |  50594 | 1992-11-29 | 1991-11-30 |
(...)
| Kyoichi    | Maliniak  |  10005 |  78228 | 1990-09-12 | 1989-09-12 |
(...)
| Anneke     | Preusig   |  10006 |  53747 | 1998-08-03 | 1997-08-03 |
(...)
+------------+-----------+--------+--------+------------+------------+

Kot lahko vidite, je poizvedba obravnavala pogled tako kot tradicionalno tabelo.

Uporabimo pogled v drugem primeru. Spodaj imam precej dolgo poizvedbo, ki navaja vodje oddelkov, njihova imena/priimke, številke zaposlenih, njihova imena oddelkov in številke oddelkov. Poizvedba zbere podatke iz več različnih tabel.

select employees.first_name,employees.last_name,employees.emp_no,dept_manager.to_date,dept_manager.from_date,departments.dept_name,departments.dept_no from employees, dept_manager, departments where employees.emp_no = dept_manager.emp_no AND departments.dept_no = dept_manager.dept_no;

Izhod (okrnjeno):

+-------------+--------------+--------+------------+------------+--------------------+---------+
| first_name  | last_name    | emp_no | to_date    | from_date  | dept_name          | dept_no |
+-------------+--------------+--------+------------+------------+--------------------+---------+
| Tonny       | Butterworth  | 111692 | 1988-10-17 | 1985-01-01 | Customer Service   | d009    |
| Marjo       | Giarratana   | 111784 | 1992-09-08 | 1988-10-17 | Customer Service   | d009    |
| Xiaobin     | Spinelli     | 111877 | 1996-01-03 | 1992-09-08 | Customer Service   | d009    |
| Yuchang     | Weedman      | 111939 | 9999-01-01 | 1996-01-03 | Customer Service   | d009    |
| DeForest    | Hagimont     | 110511 | 1992-04-25 | 1985-01-01 | Development        | d005    |
| Leon        | DasSarma     | 110567 | 9999-01-01 | 1992-04-25 | Development        | d005    |
(...)

Kot lahko vidite, bi bilo nekoliko neprijetno vnašati to poizvedbo vsakič, ko bi morali pridobiti seznam vodij oddelkov. Ustvarimo pogled, da bo lažje. Pogled bom poimenoval "upravljanje".

create view management as select employees.first_name,employees.last_name,employees.emp_no,dept_manager.to_date,dept_manager.from_date,departments.dept_name,departments.dept_no from employees, dept_manager, departments where employees.emp_no = dept_manager.emp_no AND departments.dept_no = dept_manager.dept_no;

Zdaj lahko preprosto vnesemo, select * from management;da pridobimo iste podatke. Seveda lahko za to uporabimo tudi dodatne parametre - tako kot tradicionalno mizo. Recimo, da želimo prikazati samo vodje oddelkov za »Storitev za stranke«.

select * from management where dept_name = 'Customer Service';

Izhod:

+------------+-------------+--------+------------+------------+------------------+---------+
| first_name | last_name   | emp_no | to_date    | from_date  | dept_name        | dept_no |
+------------+-------------+--------+------------+------------+------------------+---------+
| Tonny      | Butterworth | 111692 | 1988-10-17 | 1985-01-01 | Customer Service | d009    |
| Marjo      | Giarratana  | 111784 | 1992-09-08 | 1988-10-17 | Customer Service | d009    |
| Xiaobin    | Spinelli    | 111877 | 1996-01-03 | 1992-09-08 | Customer Service | d009    |
| Yuchang    | Weedman     | 111939 | 9999-01-01 | 1996-01-03 | Customer Service | d009    |
+------------+-------------+--------+------------+------------+------------------+---------+

Ali pa morda želimo "Storitev za stranke" in "Človeški viri":

select * from management where dept_name = 'Customer Service' OR dept_name = 'Human Resources';

Izhod:

+------------+--------------+--------+------------+------------+------------------+---------+
| first_name | last_name    | emp_no | to_date    | from_date  | dept_name        | dept_no |
+------------+--------------+--------+------------+------------+------------------+---------+
| Tonny      | Butterworth  | 111692 | 1988-10-17 | 1985-01-01 | Customer Service | d009    |
| Marjo      | Giarratana   | 111784 | 1992-09-08 | 1988-10-17 | Customer Service | d009    |
| Xiaobin    | Spinelli     | 111877 | 1996-01-03 | 1992-09-08 | Customer Service | d009    |
| Yuchang    | Weedman      | 111939 | 9999-01-01 | 1996-01-03 | Customer Service | d009    |
| Shirish    | Ossenbruggen | 110183 | 1992-03-21 | 1985-01-01 | Human Resources  | d003    |
| Karsten    | Sigstam      | 110228 | 9999-01-01 | 1992-03-21 | Human Resources  | d003    |
+------------+--------------+--------+------------+------------+------------------+---------+

Odstranjevanje pogleda

Brisanje pogleda je zelo preprosto. Podobno kot pri odstranjevanju tabele bi vnesli drop view view_name;. Na primer, če želimo izbrisati pogled named_salaries , bi bil ukaz: drop view named_salaries;.


Kako nastaviti nenadzorovane nadgradnje na Debian 9 (raztegni)

Kako nastaviti nenadzorovane nadgradnje na Debian 9 (raztegni)

Uporaba drugega sistema? Če kupite strežnik Debian, morate vedno imeti najnovejše varnostne popravke in posodobitve, ne glede na to, ali spite ali ne

Nastavite svoj DNS strežnik na Debian/Ubuntu

Nastavite svoj DNS strežnik na Debian/Ubuntu

Ta vadnica pojasnjuje, kako nastaviti strežnik DNS z uporabo Bind9 v Debianu ali Ubuntuju. V celotnem članku ustrezno nadomestite your-domain-name.com. Ob th

Prevedite in namestite Nginx z modulom PageSpeed ​​na Debian 8

Prevedite in namestite Nginx z modulom PageSpeed ​​na Debian 8

V tem članku bomo videli, kako prevesti in namestiti Nginx mainline iz uradnih virov Nginxa z modulom PageSpeed, ki vam omogoča

Kako namestiti Kanboard na Debian 9

Kako namestiti Kanboard na Debian 9

Uporaba drugega sistema? Uvod Kanboard je brezplačen in odprtokodni program za vodenje projektov, ki je zasnovan za olajšanje in vizualizacijo

Kako namestiti Giteo na Debian 9

Kako namestiti Giteo na Debian 9

Uporaba drugega sistema? Gitea je alternativni odprtokodni sistem za nadzor različic, ki ga poganja Git. Gitea je napisana v Golangu in je

Namesti Lynis na Debian 8

Namesti Lynis na Debian 8

Uvod Lynis je brezplačno, odprtokodno orodje za revizijo sistema, ki ga uporabljajo številni sistemski skrbniki za preverjanje integritete in utrjevanje svojih sistemov. jaz

Kako namestiti Thelia 2.3 na Debian 9

Kako namestiti Thelia 2.3 na Debian 9

Uporaba drugega sistema? Thelia je odprtokodno orodje za ustvarjanje spletnih strani e-poslovanja in upravljanje spletnih vsebin, napisanih v PHP. Izvorna koda Thelia i

Ustvarjanje omrežja strežnikov Minecraft z BungeeCord na Debian 8, Debian 9 ali CentOS 7

Ustvarjanje omrežja strežnikov Minecraft z BungeeCord na Debian 8, Debian 9 ali CentOS 7

Kaj potrebujete Vultr VPS z vsaj 1 GB RAM-a. SSH dostop (z root/administrativnimi pravicami). 1. korak: Namestitev BungeeCord Najprej najprej

Kako namestiti Golang 1.8.3 na CentOS 7, Ubuntu 16.04 in Debian 9

Kako namestiti Golang 1.8.3 na CentOS 7, Ubuntu 16.04 in Debian 9

Golang je programski jezik, ki ga je razvil Google. Zahvaljujoč svoji vsestranskosti, preprostosti in zanesljivosti je Golang postal eden najbolj priljubljenih

Ponastavite korensko geslo MySQL na Debian/Ubuntu

Ponastavite korensko geslo MySQL na Debian/Ubuntu

Če ste pozabili korensko geslo MySQL, ga lahko ponastavite tako, da sledite korakom v tem članku. Postopek je precej preprost in deluje na njih

Nastavitev Counter Strike: Source v Debianu

Nastavitev Counter Strike: Source v Debianu

V tem priročniku bomo postavili strežnik iger Counter Strike: Source na Debian 7. Ti ukazi so bili preizkušeni v Debianu 7, vendar bi morali delovati tudi o

Kako namestiti Unturned 2.2.5 na Debian 8

Kako namestiti Unturned 2.2.5 na Debian 8

V tem priročniku se boste naučili, kako nastaviti strežnik Unturned 2.2.5 na Vultr VPS z Debianom 8. Opomba: To je urejena različica Unturned, ki ne

Kako namestiti Cachet na Debian 8

Kako namestiti Cachet na Debian 8

V tej vadnici se boste naučili, kako namestiti Cachet v Debian 8. Cachet je zmogljiv odprtokodni sistem strani s stanjem. Namestitev Ta vadnica se nadaljuje

Samodejno varnostno kopirajte več baz podatkov MySQL ali MariaDB

Samodejno varnostno kopirajte več baz podatkov MySQL ali MariaDB

Uvod V tem zapisu si oglejte, kako varnostno kopirati več baz podatkov MySQL ali MariaDB, ki se nahajajo na istem računalniku z uporabo bash skripta po meri.

Nastavitev Chroota v Debianu

Nastavitev Chroota v Debianu

Ta članek vas bo naučil, kako nastaviti chroot jail v Debianu. Predvidevam, da uporabljate Debian 7.x. Če uporabljate Debian 6 ali 8, bo to morda delovalo, bu

How to Install Reader Self 3.5 RSS Reader on a Debian 9 LAMP VPS

How to Install Reader Self 3.5 RSS Reader on a Debian 9 LAMP VPS

Using a Different System? Reader Self 3.5 is a simple and flexible, free and open source, self-hosted RSS reader and Google Reader alternative. Reader Sel

Kako namestiti Backdrop CMS 1.8.0 na Debian 9 LAMP VPS

Kako namestiti Backdrop CMS 1.8.0 na Debian 9 LAMP VPS

Uporaba drugega sistema? Backdrop CMS 1.8.0 je preprost in prilagodljiv, mobilnim prijazen, brezplačen in odprtokoden sistem za upravljanje vsebine (CMS), ki nam omogoča

Kako namestiti SteamCMD na vaš VPS

Kako namestiti SteamCMD na vaš VPS

V tej vadnici bomo namestili SteamCMD. SteamCMD lahko uporabite za prenos in namestitev številnih strežnikov za igre Steam, kot je Counter-Strike: Global Offensiv

Nadgradite Python na Debian

Nadgradite Python na Debian

Kot morda veste, se skladišča Debian posodabljajo zelo počasi. V času pisanja sta izdani različici Pythona na 2.7.12 in 3.5.2, vendar v skladišču Debian 8

Kako nastaviti Sambo z blokovnim pomnilnikom v Debianu 9

Kako nastaviti Sambo z blokovnim pomnilnikom v Debianu 9

Samba je odprtokodna rešitev, ki uporabnikom omogoča hitro in varno nastavitev skupne rabe datotek in tiska. V tem članku bom obravnaval, kako nastaviti Samba wit

Vzpon strojev: aplikacije AI v resničnem svetu

Vzpon strojev: aplikacije AI v resničnem svetu

Umetna inteligenca ni v prihodnosti, tukaj je prav v sedanjosti. V tem blogu preberite, kako so aplikacije umetne inteligence vplivale na različne sektorje.

DDOS napadi: kratek pregled

DDOS napadi: kratek pregled

Ste tudi vi žrtev DDOS napadov in ste zmedeni glede načinov preprečevanja? Preberite ta članek, če želite rešiti svoja vprašanja.

Ste se kdaj vprašali, kako hekerji zaslužijo denar?

Ste se kdaj vprašali, kako hekerji zaslužijo denar?

Morda ste že slišali, da hekerji zaslužijo veliko denarja, a ste se kdaj vprašali, kako zaslužijo takšen denar? razpravljajmo.

Revolucionarni Googlovi izumi, ki vam bodo olajšali življenje.

Revolucionarni Googlovi izumi, ki vam bodo olajšali življenje.

Ali želite videti revolucionarne izume Googla in kako so ti izumi danes spremenili življenje vsakega človeka? Nato preberite v blogu in si oglejte Googlove izume.

Friday Essential: Kaj se je zgodilo z avtomobili, ki jih poganja umetna inteligenca?

Friday Essential: Kaj se je zgodilo z avtomobili, ki jih poganja umetna inteligenca?

Koncept samovozečih avtomobilov, ki zapeljejo na ceste s pomočjo umetne inteligence, so sanje, ki jih imamo že nekaj časa. A kljub številnim obljubam jih ni nikjer. Preberite ta blog, če želite izvedeti več…

Tehnološka singularnost: oddaljena prihodnost človeške civilizacije?

Tehnološka singularnost: oddaljena prihodnost človeške civilizacije?

Ker se znanost hitro razvija in prevzame veliko naših prizadevanj, se povečuje tudi tveganje, da se podvržemo nerazložljivi singularnosti. Preberite, kaj bi za nas lahko pomenila singularnost.

Razvoj shranjevanja podatkov – Infografika

Razvoj shranjevanja podatkov – Infografika

Metode shranjevanja podatkov so se lahko razvijale od rojstva podatkov. Ta blog pokriva razvoj shranjevanja podatkov na podlagi infografike.

Funkcionalnosti slojev referenčne arhitekture velikih podatkov

Funkcionalnosti slojev referenčne arhitekture velikih podatkov

Preberite blog, če želite na najpreprostejši način spoznati različne plasti v arhitekturi velikih podatkov in njihove funkcionalnosti.

6 neverjetnih prednosti pametnih naprav za dom v našem življenju

6 neverjetnih prednosti pametnih naprav za dom v našem življenju

V tem digitalno vodenem svetu so pametne naprave za dom postale ključni del življenja. Tukaj je nekaj neverjetnih prednosti pametnih naprav za dom o tem, kako naredijo naše življenje vredno življenja in poenostavijo.

Posodobitev dodatka macOS Catalina 10.15.4 povzroča več težav kot jih rešuje

Posodobitev dodatka macOS Catalina 10.15.4 povzroča več težav kot jih rešuje

Pred kratkim je Apple izdal macOS Catalina 10.15.4 dopolnilno posodobitev za odpravo težav, vendar se zdi, da posodobitev povzroča več težav, ki vodijo do opečenja računalnikov Mac. Preberite ta članek, če želite izvedeti več