对于数据库的操作以及配置
目录
一、数据库基础
1.什么是数据库**
1.什么是数据库:用来存储数据的仓库,管理数据文件的系统 - 安装某种管理数据的系统 - 管理的对象本质是文件
2.存储数据的位置:在硬盘及内存中存储数据
3.什么是系统:运行在硬件基础上,管理其他软件
4.数据库的组成
库:存放多张表 - 文件夹
表:包含多条相同结构的记录(表结构文件,表数据文件(索引文件)) - 文件
记录:(数据的本体)包含多个key-value键值对的一条数据 - 二进制数据
字段:(数据的描述)描述信息 - 信息本身 == key-value - 二进制数据
例如:
stu
id name age gender
1 Bob 18 男
2 Tom 17 女
...
teacher
...
5. 数据库与文件存储数据区别
数据库本质也是通过文件来存储数据, 数据库的概念就是系统的管理存储数据的文件
2.数据库介绍
数据库服务器端: 存放数据库的主机集群
数据库客户端: 可以连接数据库的任意客户端
数据库管理员: DBA
# socket套接字的C/S架构应用
3.数据库基本概念(组成)
# 重要性: ***
库: 多表构建一个数据库, 本质就是文件夹
表: 多条相同结构的记录(数据), 本质就是文件
记录: 包含多个key-value键值对的一条数据, 本质就是文件中一条条数据记录,并且为二进制数据
字段:描述信息 - 信息本身 == key-value - 二进制数据
(字段)id, name, age, gender...一个老师的数据 => 一条数据记录
例如:
stu
id name age gender
1 Bob 18 男
2 Tom 17 女
...
teacher
...
4.数据库分类**
分类:效率问题(内存>硬盘,非关系>关系,key-value>sql)
# 重要性: ***
1)关系型数据库:数据库中表与表之间又联系 - mysql
1.有表的概念
2.以表中一条条记录存储数据
mysql oracle sqlServer access db2
2)非关系型数据库:没有表的概念-redis,mongodb(介于关系与非关系之间)
1.没有表的概念
2.通过key-value键值对方式存储数据
mongodb redis memcache
3)内存与硬盘(内存>硬盘)
硬盘:数据可以永久存储 - mysql、mongodb
内存:数据的存取效率极高 - redis、memcache
4)sql与nosql
sql:数据库操作通过sql语句
nosql:数据库操作就是key-value形式(value就是一条记录)
stu - {'name': 'Bob', 'age': 18}
stus - [{'name': 'Bob', 'age': 18}, {'name': 'Tom', 'age': 18}]
name - 'Jerry'
5.数据库安装
1、解压免安装版本(5.6 - 没有初始密码)
2、配置环境变量:数据库绝对路径下的bin
3、配置服务:
启动管理员终端:mysqld --install [nmysql]
# 安装server端与client端
# 如何启动server? 如果通过client连接server
管理员的身份运行cmd或者powershell
6.数据库卸载
前提)启动终端,输入 mysql,如果不是提示 不是内部或外部命令,代表已安装数据库
1)直接连入
i 搜索:服务,检索mysql服务,有
停止服务,并移除服务 - 启动管理员终端:mysqld --remove
ii 搜索:服务,检索mysql服务,无 (mysql使用命令启动)
停止服务,启动管理员终端
tasklist | findstr mysql
taskkill /pid 进程pid /f
2)连接超时
搜索:服务,检索mysql服务,移除服务即可
3)移除环境变量
总结:如果能连入,先停止服务 | 如果添加了服务,就移除服务 | 取消环境变量配置
7.数据库启动与连接**
数据库的连接:主机、端口、账号、密码、数据库
# 前提:配置环境变量
# 了解
1.前往数据库安装路径,bin文件夹下,cmd执行 mysqld 启动mysql服务器端
2.前往数据库安装路径,bin文件夹下,cmd执行 mysql 启动mysql客户端连接服务器端
# 掌握***
# 将mysql服务器添加到系统服务,在系统服务中启动mysql, 命令: mysqld --install
# 进入系统服务: win+r => services.msc => 找到mysql服务手动启动或关闭
# 连接数据库:mysql -hlocalhost -P3306 -uroot -p
1)游客登陆(不一定能登入,登入了也啥都不能干)
>: mysql
2)账号密码登录
>: mysql -u root -p
再输入密码,没有任何提示,没有密码直接回车
3)连接指定服务器的mysql
>: mysql -h ip地址 -P 端口号 -u 账号 -p
回车后敲入密码
eg:
>: mysql -hlocalhost -P3306 -uroot -p
4)退出数据库
>: quit
>: exit
# 通过最高权限进入数据库, 要采用root用户进入, 连入本地数据库: mysql -uroot -p
二、数据库操作
8.用户信息查看
1)查看当前登录的用户
mysql>: select user();
2)root权限下可以查看所有用户信息
mysql>: select * from mysql.user;
mysql>: select * from mysql.user \G
mysql>: select user,password,host from mysql.user;
3)root登录下,删除游客(操作后要重启mysql服务)
mysql>: delete from mysql.user where user='';
4)root登录下,修改密码(操作后要重启mysql服务)
mysql>: update mysql.user set password=password('12345678') where host='localhost';
5)没有登录
>: mysqladmin -u用户名 -p旧密码 -h域名 password "新密码"
eg>: mysqladmin -uroot -p12345678 -hlocalhost password "root"
6)root登录下,创建用户
mysql>:grant 权限们 on 数据库名.表名 to 用户名@主机名 identified by '密码';
9.用户操作与管理(重点)(新创建用户)***
创建对指定数据库权限的用户:grant 权限们 on 数据库.表 to 用户名@'主机名' identified by '密码';
# 操作前提:登录root用户
1.重要字段
Host | User | Password
2.新建用户
create user 用户名@主机名 identified by '密码'; # 正确
create user zero@localhost identified by 'zero';
3. 为特定的数据库分配有该数据库 操作权限 的用户
mysql>: grant 权限们 on 数据库.表 to 用户名@'主机名' identified by '密码';
方法1
# 1)all:所有权限
# 2)oldboy.*:oldboy数据库下所有表
# 3)oldboy@'localhost':本机可以通过oldboy用户登入
# 4)identified by 'Oldboy123':密码为Oldboy123
eg>: grant all on oldboy.* to oldboy@'localhost' identified by 'Oldboy123';
方法2
# 1)select,delete,update,insert,drop,alter:指定的权限
# 2)oldboy.*:oldboy数据库下所有表
# 3)oldboy@'%':任何机器可以通过oldboy用户登入
# 4)identified by 'Oldboy123':密码为Oldboy123
eg>: grant select,delete,update,insert,drop,alter on oldboy.* to oldboy@'%' identified by 'Oldboy123';
注:数据库名,表名可以用*替换,代表所有
注:设置权限时如果没有当前用户,会自动创建用户,提倡使用
4. 撤销权限
mysql>: revoke 权限1,权限2,... on 数据库名.表名 from 用户名@'主机名';
# 禁掉本地oldboy用户对oldboy数据库的所有表的drop权限
eg:> revoke drop on oldboy.* from oldboy@'localhost';
5.修改密码
set password for 用户名@主机名 = password('新密码');
set password for owen@localhost = password('123');
6. 删除用户
drop user 用户名@'主机名';
10.数据库的密码操作
修改密码: mysqladmin -uroot -p旧密码 password "新密码"
11.数据库的配置(统一字符编码)
# 查看数据库配置信息: \s => 统一编码 => 防止乱码(读取不方便,数据丢失)
# 在mysql安装根目录下:创建my.ini (my.cnf) (命令:type nul>文件名.文件后缀)
# 通过配置文件统一配置的目的:统一管理 服务端(mysqld) 、客户端(client)
# 配置了 mysqld(服务端) 的编码为utf8,那么再创建的数据库,默认编码都采用utf8
# 配置流程
# 1)在mysql安装根目录下,创建配置文件:my.ini
# mac下配置文件名叫 my.cnf
# 2)设置配置文件内容并保存
[mysqld] # 服务器配置
port=3306 # 可以修改数据库默认端口(如果数据库端口被其他软件占用)
character-set-server=utf8 # 编码格式
collation-server=utf8_general_ci # 排序方式(默认跟编码格式走)
[client] # mysql自己的客户端叫[mysql],配置[client]即配置了[mysql],也配置了其他存在方式的客户端,比如Navicat可视化客户端
default-character-set=utf8 # 编码格式
# 3)重启数据库服务
###直接复制粘贴
[mysqld]
character-set-server=utf8
collation-server=utf8_general_ci
[mysql]
default-character-set=utf8
[client]
default-character-set=utf8
[mysqld]
character-set-server=utf8
collation-server=utf8_general_ci
[mysql]
default-character-set=utf8
##########加入免登录
user=root
password=root
[client]
default-character-set=utf8
11.数据库修改(字符编码)信息
#修改字符编码
mysql>:alter database 数据库名 charset=编码格式;
12.库的基本操作
# 前提: 连接上数据库
1.查看mysql版本:
mysql>select version();
2.查看当前用户:
mysql>select user();
3.查看mysqld下的(当前用户可以操作的)所有数据库:
mysql>show databases;
4.选择数据库
mysql>:use 数据库名;
mysql>use db1;
5.查看当前所在数据库:
mysql>:select database();
6.增,创建数据库
mysql>:create database 数据库名 [charset="编码格式"];
# 采用默认编码集:
mysql>create database db1; # db1为数据库名
# 自定义编码集:
mysql>create database db1 charset="gbk";
7.查,查看数据库全部信息
mysql>:show create database 数据库名;
# 详细信息:
mysql>show create database db1;
8.改,修改数据库编码集
mysql>alter database db1 charset="utf8";
9.删, 移除数据库
mysql>:drop database 数据库名;
mysql>drop database db1;
10. 退出
mysql>exit
mysql>quit
13.数据库模式(安全模式和非安全模式)
# sql_mode: 反映数据库的全局变量
# 数据库模式限制的是客户端对服务器操作数据的方式(是否严格)
# mysql 5.7 以后默认都是安全模式
# mysql 5.6 版本
sql_model=no_engine_substitution # 非安全性,默认
sql_model=strict_trans_tables # 安全性
# 查看当前数据库模式:
show variables like "%sql_mode%"; # %匹配0~n个任意字符 => 模糊查询
# 临时设置为安全模式,服务重启后会被重置
mysql>: set global sql_mode="strict_trans_tables"; # 在root用户登录状态下
# 在设置后,quit断开数据库连接后(服务器不重启)就会进入安全模式
# 安全模式下,非安全模式下sql执行的警告语句,都会抛异常
eg>: create table t1(name char(2));
eg>: insert into t1 values ("ab") # 正常
eg>: insert into t1 values ("owen") # 错误 Data too long for column 'name' at row 1
14.库的远程连接
15.查看库的文件以及结束进程
设置时区
继续输入 show variables like'%time_zone'; (注意不要漏掉后面的分号),回车,如图:
显示 SYSTEM 就是没有设置时区啦。
3,现在我们来设置时区。
输入set global time_zone = '+8:00'; 注意不要漏掉后面的分号),回车,如图:
这便是设置成功啦!
这时你重新连接下数据库,也许能连接成功!如果没有,就继续往下走!