一、数据库管理系统DBMS
软件,存储数据
认证,授权,限制
SqlServer --- 微软(收费)
Oracle,sqlite,access...MySQL
服务端和客户端
想要使用MySQL来存储并操作数据,则需要做几件事情:
a. 安装MySQL服务端
b. 安装MySQL客户端
b. 【客户端】连接【服务端】
c. 【客户端】发送命令给【服务端MySQL】服务的接受命令并执行相应操作(增删改查等)
二、MySQL安装
WIN版本安装:
1、下载:http://dev.mysql.com/downloads/mysql/
2、解压:如果想要让MySQL安装在指定目录,那么就将解压后的文件夹移动到指定目录,如:C:mysql-5.7.16-winx64
3、MySQL解压后的 bin 目录下有一大堆的可执行文件,执行如下命令初始化数据:
cd c:mysql-5.7.16-winx64in
mysqld --initialize-insecure # 初始化数据库,会做很多初始化操作,包括创建一个root用户,密码为空
4、启动MySQL服务:在bin文件夹下执行命令:mysqld
5、启动MySQL客户端(在bin路径下启动)并连接MySQL服务:
mysql -u root -p # 回车,由于密码为空,再回车!
启动优化:
将mysql服务制做成windows服务
# 制作MySQL的Windows服务,在终端执行此命令: C:UsersLowry>C:mysql-5.7.21-winx64inmysqld --install # 如果在bin目录下,只要执行mysqld --install就可以了 # 移除MySQL的Windows服务,在终端执行此命令: mysqld --remove
注册成服务之后,以后再启动和关闭MySQL服务时,仅需执行如下命令:
# 启动MySQL服务 net start mysql # 关闭MySQL服务 net stop mysql
三、MySQL数据库
1、概念:
数据库:文件夹
数据表:文件
数据行:文件中的一行
2、数据库基本操作:
显示数据库:show databases; # 命令后面一定要加;号,代表命令结束
创建数据库:create database 数据库名称; # 这个database没有s
创建指定编码的数据库:
# utf8
create database 数据库名称 default charset utf8 collate utf8_general_ci;
# GBK
create database 数据库名称 default charset gbk collate gbk_chinese_ci;
进入数据库:use 数据库名称; # 个人感觉可能数据库的视图比较少,所以没有返回命令,show databases是全局命令,想改变数据库直接use就可以了。
删除数据库:drop database 数据库名称;
----------------------------------------------------------------------------------------------------------------------------------
显示数据表:show tables;
创建数据库表:create table 表名(nid int,name varchar(20), pwd varchar(64));
查看表中所有数据:select * from 表名;
插入数据:insert into 表名(nid,name,pwd) value(1,"alex","123");
删除数据表:drop table 表名;
清空表数据:delete from 表名; truncate table 表名;
查看表结构:desc 表名;
3、用户管理:
创建用户:create user "用户名"@"IP地址" identified by "密码";
create user wpuser@192.168.6.130 identified by "magedu.com";
删除用户:drop user "用户名"@"IP地址"
修改用户名:rename user "用户名"@"IP地址" to "新用户名"@"IP地址";
修改密码:set password for "用户名"@"IP地址" = Password("新密码")
用户相关数据保存在mysql数据库的user表中,所以也可以直接对其操作(不建议)
4、授权管理:
查看用户权限:show grants for "用户名"@"IP地址"
给用户授权:grant 权限 on 数据库.表 to "用户名"@"IP地址"
取消用户授权:revoke 权限 on 数据库.表 from "用户名"@"IP地址"
flush privileges,将数据读取到内存中,从而立即生效。(直接在命令行中输入此命令)
权限列表:
all privileges 除grant外的所有权限 select 仅查权限 select,insert 查和插入权限 ... usage 无访问权限 alter 使用alter table alter routine 使用alter procedure和drop procedure create 使用create table create routine 使用create procedure create temporary tables 使用create temporary tables create user 使用create user、drop user、rename user和revoke all privileges create view 使用create view delete 使用delete drop 使用drop table execute 使用call和存储过程 file 使用select into outfile 和 load data infile grant option 使用grant 和 revoke index 使用index insert 使用insert lock tables 使用lock table process 使用show full processlist select 使用select show databases 使用show databases show view 使用show view update 使用update reload 使用flush shutdown 使用mysqladmin shutdown(关闭MySQL) super 使用change master、kill、logs、purge、master和set global。还允许mysqladmin调试登陆 replication client 服务器位置的访问 replication slave 由复制从属使用
对于目标数据库以及内部其他:
数据库名.* 数据库中的所有
数据库名.表 指定数据库中的某张表
数据库名.存储过程 指定数据库中的存储过程
*.* 所有数据库
IP地址的写法:
用户名@IP地址 用户只能在改IP下才能访问 用户名@192.168.1.% 用户只能在改IP段下才能访问(通配符%表示任意) 用户名@% 用户可以再任意IP下访问(默认IP地址为%)
4、数据表操作:
创建表:
create table 表名(
列名 类型 是否可以为空 default 缺省值,
列名 类型 是否可以为空 default 缺省值)ENGINE=InnoDB DEFAULT CHARSET=utf8;
是否为空:默认允许为空,not null设置为不允许为空,如果将列设置为主键,将自动设置为not null
default:如果不设置,默认值为null
auto-increment:
(1)默认不自增,如果想要设置成自增加上auto_increment。
(2)一张表中只能有一个自增列,自增列必须是数字且必须是key(索引),否则报错!
(3)如果把某列设置成自增列,插入数据时可以不设置该列值,默认自增;但是也可以手工设置为某个值,这个值可以比当前最大的值大,也可以比最大的值小,只要不重复就OK。
唯一列:
(1)一张表可以有多个唯一列
(2)唯一,不重复
(3)可以为Null
primary key:一种特殊的唯一索引
(1)一张表只能有一个主键
(2)唯一,不重复
(3)不能为空
(4)不能为Null
create table tb3(
nid int,
name varchar(10),
primary key(nid,name)); # 把两列设置成一个主键,这个命令必须要写在列名称括号中!!
foreign key:一种特殊的索引
修改表: