MySQL介绍:
MySQL是一种关系型数据库管理系统,关系数据库将数据保留在不同的表中,而不是将所有数据放在一个大仓库内,这样就减少了速度并进步了灵活性。
MySQL所应用的 SQL 语言是用于拜访数据库的最罕用标准化语言。MySQL 软件采纳了双受权政策,分为社区版和商业版,因为其体积小、速度快、总体领有成本低,尤其是开放源码这一特点,个别中小型网站的开发都抉择 MySQL 作为网站数据库。
文章分五大内容别离是:
连贯MySQL、MySQL治理与受权、数据库简略操作、数据库的导入与导出、数据库备份
杜聚宾(杜公公)独家MySQL数据库根底实战视频教程
视频简介:
本套是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用户增加明码:
因为开始root没有明码,所以-p旧明码一项能够省略.
登陆测试:
输出明码,胜利登陆.
将原有的mysql治理登陆密码52netseek改为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实用程序(能够轻松解决多个表)
导出建设相干表的建表命令和插入指令
如果要将bbs.sql导入数据库能够应用:
mysql> create database bbstest; 先建设一个名为office 的数据库.
只想导出建表指令:
只想导出插入数据的sql指令:
同时导出数据库中建表指令和表中的数据:
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: 输出明码即可