【初學(xué)者必備】MySQL數(shù)據(jù)庫學(xué)習(xí)筆記-動力節(jié)點

MySQL介紹:

? ? MySQL是一種關(guān)系型數(shù)據(jù)庫管理系統(tǒng),關(guān)系數(shù)據(jù)庫將數(shù)據(jù)保存在不同的表中,而不是將所有數(shù)據(jù)放在一個大倉庫內(nèi),這樣就增加了速度并提高了靈活性。

? ? ? MySQL所使用的 SQL 語言是用于訪問數(shù)據(jù)庫的最常用標(biāo)準(zhǔn)化語言。MySQL 軟件采用了雙授權(quán)政策,分為社區(qū)版和商業(yè)版,由于其體積小、速度快、總體擁有成本低,尤其是開放源碼這一特點,一般中小型網(wǎng)站的開發(fā)都選擇 MySQL 作為網(wǎng)站數(shù)據(jù)庫。

相關(guān)視頻推薦:https://www.bilibili.com/video/BV1fx411X7BD

視頻簡介:? ? ??

本套是MySQL數(shù)據(jù)庫視頻教程是動力節(jié)點教學(xué)總監(jiān)杜老師講述,其中詳細講解了MySQL的相關(guān)知識,包括MySQL概述,MySQL應(yīng)用環(huán)境,MySQL系統(tǒng)特性,MySQL初學(xué)基礎(chǔ),MySQL管理工具,如何安裝MySQL及MySQL新特性,通過觀看本套Java視頻教程就可掌握MySQL全套知識。 (實驗環(huán)境:Redhat9.0,MySQL3.23.54)

文章分五大內(nèi)容分別是:

連接MySQL、MySQL管理與授權(quán)、數(shù)據(jù)庫簡單操作、數(shù)據(jù)庫的導(dǎo)入與導(dǎo)出、數(shù)據(jù)庫備份

一,連接MySQL

格式:mysql -h 遠程主機地址 -u 用戶名 -p 回車

輸入密碼進入:

mysql -u root -p 回車

Enter password: ,輸入密碼就可以進入

mysql> 進入了

退出命令:>exit 或者ctrl+D

二,MySQL管理與授權(quán)

1.修改密碼:

格式:mysqladmin -u 用戶名 -p 舊密碼 password 新密碼

2.增加新用戶:

>grant create,select,update….(授予相關(guān)的操作權(quán)限)

->on 數(shù)據(jù)庫.*

-> to 用戶名@登錄主機 identified by ‘密碼’

操作實例:

給root用戶添加密碼:

# mysqladmin -u root password 52netseek

因為開始root沒有密碼,所以-p舊密碼一項可以省略.

登陸測試:

# mysql -u root -p 回車

輸入密碼,成功登陸.

將原有的mysql管理登陸密碼52netseek改為52china.

# mysqladmin -u root -p 52netseek password ’52china’

創(chuàng)建數(shù)據(jù)庫添加用戶并授予相應(yīng)的權(quán)限:

mysql> create database phpbb;

Query OK, 1 row affected (0.02 sec)

mysql> use phpbb;

Database changed

mysql> grant create,select,update,insert,delete,alter

-> on phpbb.*

-> to phpbbroot@localhost identified by ’52netseek’;

Query OK, 0 rows affected (0.00 sec)

授予所有的權(quán)限:

>grant all privileges

>on bbs.*

>to bbsroot@localhost identified by ’52netseek’

回收權(quán)限:

revoke create,select,update,insert,delete,alter

on phpbb.*

from phpbbroot@localhost identified by ’52netseek’;

完全將phpbbroot這個用戶刪除:

>use mysql

>delete from user

where user=’phpbbroot’ and host=’localhost’;

>flush privileges; 刷新數(shù)據(jù)庫

三,數(shù)據(jù)庫簡單操作

1.顯示數(shù)據(jù)庫列表:

>show databases;

mysql

test

2.使其成為當(dāng)前操作數(shù)據(jù)庫

>use mysql; 打開數(shù)據(jù)庫.

>show tables; 顯示mysql數(shù)據(jù)庫中的數(shù)據(jù)表.

3.顯示數(shù)據(jù)表的表結(jié)構(gòu):

>describe 表名;

>describe user; 顯示user表的表結(jié)構(gòu):

4.創(chuàng)建數(shù)據(jù)庫,建表

>create database 數(shù)據(jù)庫名;

>use 數(shù)據(jù)庫名;

>create table 表名(字段設(shè)定列表)

5.刪除數(shù)據(jù)庫,冊除表

>drop database 數(shù)據(jù)庫名;

>drop table 表名;

6.顯示表中的記錄;

select * from 表名;

7.修改數(shù)據(jù)庫結(jié)構(gòu):

增加字段:alter table dbname add column

修改字段:alter table dbname change

刪除字段:alter table dbname drop column

實例操作:

>create database office;

>use office;

mysql> create table personal(

-> member_no char(5) not null,

-> name char(,

-> birthday date,

-> exam_score tinyint,

-> primary key(member_no)

-> );

Query OK, 0 rows affected (0.01 sec)

>desc personal; 顯示表結(jié)構(gòu):

+————+————+——+—–+———+——-+

| Field | Type | Null | Key | Default | Extra |

+————+————+——+—–+———+——-+

| member_no | char(5) | | PRI | | |

| name | char( | YES | | NULL | |

| birthday | date | YES | | NULL | |

| exam_score | tinyint(4) | YES | | NULL | |

+————+————+——+—–+———+——-+

4 rows in set (0.00 sec)

insert into personal values (‘001′,’netseek’,’1983-03-15′,’95’);

insert into personal values (‘002′,’heihei’,’1982-02-24′,’90’);

insert into personal values (‘003′,’gogo’,’1985-05-21′,’85’);

insert into personal values (‘004′,’haha’,’1984-02-25′,’84’);

insert into personal values (‘005′,’linlin’,’1982-04-28′,’85’);

您正在看的MySQL教程是:MySQL數(shù)據(jù)庫學(xué)習(xí)筆記。 insert into personal values (‘006′,’xinxin’,’1985-03-15′,’75’);

mysql> select * from personal;

+———–+———+————+————+

| member_no | name | birthday | exam_score |

+———–+———+————+————+

| 001 | netseek | 1983-03-15 | 95 |

| 002 | heihei | 1982-02-24 | 90 |

| 003 | gogo | 1985-05-21 | 85 |

| 004 | haha | 1984-02-25 | 84 |

| 005 | linlin | 1982-04-28 | 85 |

| 006 | xinxin | 1985-03-15 | 75 |

+———–+———+————+————+

修改數(shù)據(jù)庫表:

要求: 在birthday這后增加一個為height的字段,數(shù)據(jù)類型為tinyint.

將字段exam_score 改名為scores,數(shù)據(jù)類型不變

>alter table personal

->add column height tinyint after birthday,

->change column exam_score scores tinyint;

mysql> select * from personal;

+———–+———+————+——–+——–+

| member_no | name | birthday | height | scores |

+———–+———+————+——–+——–+

| 001 | netseek | 1983-03-15 | NULL | 95 |

| 002 | heihei | 1982-02-24 | NULL | 90 |

| 003 | gogo | 1985-05-21 | NULL | 85 |

| 004 | haha | 1984-02-25 | NULL | 84 |

| 005 | linlin | 1982-04-28 | NULL | 85 |

| 006 | xinxin | 1985-03-15 | NULL | 75 |

+———–+———+————+——–+——–+

給表中插入數(shù)據(jù):

>update personal set scores=95+5 where name=’netseek’;

>select scores from personal where name=’netseek’;

+——–+

| scores |

+——–+

| 100 |

+——–+

刪除表名字為’gogo’所有的信息中的的:

> delete from personal where name=’gogo’;

冊除數(shù)據(jù)庫中的表:

mysql>drop table if exists personal;

四,數(shù)據(jù)庫的導(dǎo)入與導(dǎo)出

導(dǎo)出:

使用select into outfile ‘filename’語句

使用mysqldump實用程序

使用select into outfile ‘filename’語句

1.只能處理單個表,輸出文件只有數(shù)據(jù),沒有表結(jié)構(gòu)

我們要將office,其中有一個表為personal,現(xiàn)在要把personal卸成文本文件out.txt:

>use office;

>select * from personal into outfile ‘out.txt’; 可以看在/var/lib/mysql/office/目錄下有out.txt

select * from personal into outfile ‘./out.txt’; 可以看在out.txt 在/var/lib/mysql/目錄下用out.txt

2.使用mysqldump實用程序(可以輕松處理多個表)

# cd /var/lib/mysql

導(dǎo)出建立相關(guān)表的建表命令和插入指令

# mysqldump bbs >bbs.sql 將數(shù)據(jù)庫bbs導(dǎo)入到bbs.sql中

如果要將bbs.sql導(dǎo)入數(shù)據(jù)庫可以使用:

mysql> create database bbstest; 先建立一個名為office 的數(shù)據(jù)庫.

# mysql bbstest

只想導(dǎo)出建表指令:

# mysqldump -d bbs >bbscreate.sql

只想導(dǎo)出插入數(shù)據(jù)的sql指令:

# mysqldump -t bbs >bbsinsert.sql

同時導(dǎo)出數(shù)據(jù)庫中建表指令和表中的數(shù)據(jù):

# mysqldump -T./ bbs cdb_admingroups (其中./表示當(dāng)前目錄,cdb_admingroups為bbs數(shù)據(jù)庫其中的一個表)

#ls

cdb_admingroups.sql 導(dǎo)出了建表指令

cdb_admingroups.txt 導(dǎo)出了表中的數(shù)據(jù)

導(dǎo)入:

從文件中加載數(shù)據(jù)庫:

mysql>load data infile “/tmp/name.txt” into table names;

mysql>select * from names;

五、數(shù)據(jù)庫備份

1.手動拷貝備份:

MySQL數(shù)據(jù)庫的文件保存在目錄/var/lib/mysql中,數(shù)據(jù)庫為每個庫建立一個目錄,所有的數(shù)據(jù)庫文件都在這些目錄中.

[root@linuxhero mysql]#ls

[root@linuxhero mysql]#servcie mysqld stop 先停止數(shù)據(jù)庫

bbs mysql mysql.sock phpbb test office 顯示其中的數(shù)據(jù)庫.

如果我們要將現(xiàn)在的數(shù)據(jù)庫目錄備份為mysql.bak .

[root@linuxhero lib]# cp -rf mysql mysql.bak

如果數(shù)據(jù)庫遭到了破壞,現(xiàn)在要將數(shù)據(jù)庫恢復(fù):

[root@linuxhero lib]# cp -rf mysql.bak/* mysql

恢復(fù)數(shù)據(jù)庫以后,var/lib/mysql中的文件已改變了,要更改文件的所屬權(quán)限必須改變MySQL數(shù)據(jù)庫的用戶讀寫權(quán)限。

所以我們得啟動和運行mysql,并登陸數(shù)據(jù)庫:

[root@linuxhero lib]# /etc/init.d/mysqld start

[root@linuxhero lib]# mysql

您正在看的MySQL教程是:MySQL數(shù)據(jù)庫學(xué)習(xí)筆記。-u root -p

Enter password:輸入密碼成功登陸.

mysql> show databses;

2.利用mysqldump來備份數(shù)據(jù)庫

[root@linuxhero mysql]# mysqldump –opt bbs -u root -p > bbs.sql

Enter password:

注:–opt添加備份的其它選項,bb為其中一個數(shù)據(jù)庫名,

上面的意思是:使用重定向輸出將備份寫入到文件bb.sql中.

[root@linuxhero mysql] #less bbs.sql

如果要恢復(fù)bb這個數(shù)據(jù)庫,則進行如下操作:

[root@linuxhero mysql] #mysql bbs -u root -p < bbs.sql

如果要備份所有數(shù)據(jù)庫:

[root@linuxhero mysql] #mysqldump –opt –all-databases -u root -p >mysql.bak

Enetr password:輸入密碼即可

恢復(fù)所有數(shù)據(jù)庫,不用輸入數(shù)據(jù)庫的名字:

[root@linuxhero mysql] #mysql -u root -p < mysql.bak

Enetr password: 輸入密碼即可

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容