zoukankan      html  css  js  c++  java
  • 对于数据库的操作以及配置

    一、数据库基础

    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'; 注意不要漏掉后面的分号),回车,如图:

    这便是设置成功啦!

    这时你重新连接下数据库,也许能连接成功!如果没有,就继续往下走!

  • 相关阅读:
    如何让一个对话框全屏对话框
    学习网络请求返回json对应的model
    学习网络请求返回json对应的model
    android获取未安装APK签名信息及MD5指纹
    android获取未安装APK签名信息及MD5指纹
    Android stadio 模板 liveTemplate不管用
    Android stadio 模板 liveTemplate不管用
    android 事件传递机制
    android systemtrace 报错
    我今天的收获,必备stadio 插件
  • 原文地址:https://www.cnblogs.com/SkyOceanchen/p/11594599.html
Copyright © 2011-2022 走看看