关于mysql:MySQL数据库学习笔记通俗易通

2次阅读

共计 5233 个字符,预计需要花费 14 分钟才能阅读完成。

文章分五大内容别离是:

连贯 MySQL、MySQL 治理与受权、数据库简略操作、数据库的导入与导出、数据库备份

杜聚宾(杜公公)独家 MySQL 数据库根底实战视频教程指路:

https://www.bilibili.com/vide…

视频目录:

视频简介:

本套是 MySQL 数据库视频教程是能源节点教学总监杜老师讲述,其中具体解说了 MySQL 的相干常识,包含 MySQL 概述,MySQL 应用环境,MySQL 零碎个性,MySQL 初学根底,MySQL 管理工具,如何装置 MySQL 及 MySQL 新个性,通过观看本套 Java 视频教程就可把握 MySQL 全套常识。(试验环境:Redhat9.0,MySQL3.23.54)

一,连贯 MySQL

格局:mysql -h 近程主机地址 -u 用户名 -p 回车

输出明码进入:

mysql -u root -p 回车

Enter password: , 输出明码就能够进入

mysql> 进入了

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

二,MySQL 治理与受权

1. 批改明码:

格局:mysqladmin -u 用户名 -p 旧明码 password 新密码

2. 减少新用户:

grant create,select,update….(授予相干的操作权限)

->on 数据库.*

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

创立数据库增加用户并授予相应的权限:

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)

授予所有的权限:

grant all privileges

on bbs.*

to bbsroot@localhost identified by’52netseek’

回收权限:

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; 刷新数据库

三,数据库简略操作

1. 显示数据库列表:

show databases;

mysql

test

2. 使其成为以后操作数据库

use mysql; 关上数据库.

show tables; 显示 mysql 数据库中的数据表.

3. 显示数据表的表构造:

describe 表名;

describe user; 显示 user 表的表构造:

4. 创立数据库, 建表

create database 数据库名;

use 数据库名;

create table 表名 (字段设定列表)

5. 删除数据库,册除表

drop database 数据库名;

drop table 表名;

6. 显示表中的记录;

select * from 表名;

7. 批改数据库构造:

减少字段:

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; 显示表构造:

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

| 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 数据库学习笔记。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 |

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

批改数据库表:

要求: 在 birthday 这后减少一个为 height 的字段, 数据类型为 tinyint.

将字段 exam_score 改名为 scores,数据类型不变

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 |

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

给表中插入数据:

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

册除数据库中的表:

mysql>drop table if exists personal;

四,数据库的导入与导出

导出:

应用 select into outfile‘filename’语句

应用 mysqldump 实用程序

应用 select into outfile‘filename’语句

1. 只能解决单个表,输入文件只有数据,没有表构造

咱们要将 office, 其中有一个表为 personal, 当初要把 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

导出建设相干表的建表命令和插入指令

mysqldump bbs >bbs.sql 将数据库 bbs 导入到 bbs.sql 中

如果要将 bbs.sql 导入数据库能够应用:

mysql> create database bbstest; 先建设一个名为 office 的数据库.

mysql bbstest

只想导出建表指令:

mysqldump -d bbs >bbscreate.sql

只想导出插入数据的 sql 指令:

mysqldump -t bbs >bbsinsert.sql

同时导出数据库中建表指令和表中的数据:

mysqldump -T./ bbs cdb_admingroups (其中./ 示意当前目录,cdb_admingroups 为 bbs 数据库其中的一个表)

ls

cdb_admingroups.sql 导出了建表指令

cdb_admingroups.txt 导出了表中的数据

导入:

从文件中加载数据库:

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

mysql>select * from names;

五、数据库备份

1. 手动拷贝备份:

MySQL 数据库的文件保留在目录 /var/lib/mysql 中, 数据库为每个库建设一个目录, 所有的数据库文件都在这些目录中.

[root@linuxhero mysql]#ls

[root@linuxhero mysql]#servcie mysqld stop 先进行数据库

bbs mysql mysql.sock phpbb test office 显示其中的数据库.

如果咱们要将当初的数据库目录备份为 mysql.bak .

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

如果数据库受到了毁坏,当初要将数据库复原:

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

复原数据库当前,var/lib/mysql 中的文件已扭转了,要更改文件的所属权限必须扭转 MySQL 数据库的用户读写权限。

所以咱们得启动和运行 mysql,并登陆数据库:

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

[root@linuxhero lib]# mysql

您正在看的 MySQL 教程是:MySQL 数据库学习笔记。-u root -p

Enter password: 输出明码胜利登陆.

mysql> show databses;

2. 利用 mysqldump 来备份数据库

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

Enter password:

注:–opt 增加备份的其它选项,bb 为其中一个数据库名,

下面的意思是:应用重定向输入将备份写入到文件 bb.sql 中.

[root@linuxhero mysql] #less bbs.sql

如果要复原 bb 这个数据库,则进行如下操作:

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

如果要备份所有数据库:

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

Enetr password: 输出明码即可

复原所有数据库, 不必输出数据库的名字:

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

Enetr password: 输出明码即可

正文完
 0