Java教程

数据库

本文主要是介绍数据库,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

目录
  • 数据存取演变史
    • 一、文本文件
    • 二、软件开发目录
    • 三、数据库服务
  • 数据库软件应用史
    • 一、单机游戏
    • 二、网络游戏
  • 数据库的本质
    • 一、底层原理角度
    • 二、站在现实应用角度
    • 三、在不做特殊说明的情况下
  • 数据库的分类
    • 一、关系型数据库
      • 1.数据的组织方式有明确的表结构
      • 2.表与表之间可以建立数据库层面的关系
      • 3.对应的软件
    • 二、非关系型数据库
      • 1.数据的组织方式没有明确的表结构,是以k:v键值对的形式组织的
      • 2.数据之间无法直接建立数据库层面的关系
      • 3.对应的软件
  • MySQL简介
    • 一、前提
    • 二、MySQL版本问题
    • 三、下载与安装
      • 1.下载步骤
      • 2.解压安装
      • 3.主要文件介绍
    • 四、基本使用
      • 1.先启动服务器
      • 2.查找mysqld文件位置
      • 3.再次开启新的cmd窗口
      • 4.用户名密码登录
      • 5.退出
    • 五、系统服务制作
      • 1.如何解决每次都需要切换路径查找文件的缺陷
      • 2.将mysql服务端制作成系统服务(随着计算机的开启而启动,关闭而关闭)
    • 六、密码相关操作
      • 1.修改密码mysqladmin命令
        • 通用方式:直接在cmd里写
        • 偏门方法(有些版本无法使用):需要先登录
      • 2.忘记密码
    • 七、SQL与NoSQL
      • 1.SQL:操作关系型数据库的语法
      • 2.NoSQL:操作非关系型数据库的语法
      • 3.相关知识
        • 3.1.数据库的服务端支持各种语言充当客户端
        • 3.2.为了能够兼容所有类型的客户端,有两种策略
    • 八、数据库重要概念
    • 九、针对库的基本SQL语句
      • 1.常识

数据存取演变史

一、文本文件

​ 文件路径可能不一致:C:\aaa.txt D:\aaa\a.txt

​ 数据格式也可能不一致:jason|123 sd$123

二、软件开发目录

​ 规定了数据文件的大致存储位置:db文件夹

​ 针对数据格式还是没有完全统一:比如统一json文件但是内部键值对不同

三、数据库服务

​ 统一了存取位置,也统一了数据格式(完全统一)

数据库软件应用史

一、单机游戏

​ 不同的计算机上的相同程,数据无法共享

​ 数据库服务全部在本地完成

二、网络游戏

​ 不同的计算机上的相同程序,数据可以共享

​ 数据库服务单独在网络架设(远程数据库服务)

数据库的本质

一、底层原理角度

​ 数据库是指:专门用于操作数据的进程

​ eg:运行在内存中的代码

二、站在现实应用角度

​ 数据库是指:拥有操作界面的应用程序

​ eg:用于操作进程的界面

三、在不做特殊说明的情况下

​ 数据库是指:数据库软件

​ 数据库软件:本质上是一款cs架构的应用程序

​ 也就是说理论上,每个程序员都可以编写数据库软件

数据库的分类

一、关系型数据库

1.数据的组织方式有明确的表结构

​ ID name password

​ ps:关系型数据库存取数据的方式可以看成是表格

2.表与表之间可以建立数据库层面的关系

​ eg:用户表 房屋表

​ ps:只要获取到用户表的一条数据,就可以获取到与之相关的其他表的数据

3.对应的软件

​ MySQL、PostgreSQL、MariaDB、Oracle、sqlite、db2、sqlsever

软件 特点
MySQL 开源、使用最广泛、数据库学习必学
PostgreSQL 开源、支持二次开发
MariaDB 开源、与MySQL是同一个作者,用法也极其相似
Oracle 收费,安全性极高、主要用于银行及各大重要机关
sqlite 小型数据库,主要用于本地测试(Django框架自带带该数据库)

二、非关系型数据库

1.数据的组织方式没有明确的表结构,是以k:v键值对的形式组织的

​ {'name':'jason'}

​ {'username':'kevin','pwd':123}

2.数据之间无法直接建立数据库层面的关系

3.对应的软件

​ redis、mongoDB、memcache

软件 特点
redis 目前最火、使用频率最高的缓存型数据库
MongoDB 稳定性数据库、最像关系型的非关系型、主要用于爬虫、大数据
memcache 已经被redis淘汰了

MySQL简介

一、前提

​ 虽然数据库软件各式各样,但是底层操作几乎都是一样的,学会一个其他的都可以快速上手

​ 学习了MySQL基本上就可以快速上手所有的关系型数据库,甚至是非关系型数据库

二、MySQL版本问题

虽然版本有区别,但是在操作上区别不大,主要体现在底层运作

版本 特点
5.6X 前几年使用频率最高的版本
5.7X 最近尝试迁移的版本(频率↑)
8.0X 最新版,功能强大,但是线上环境几乎不用(本地用非常好用)

三、下载与安装

1.下载步骤

​ 1.1.访问官网https://www.mysql.com/

​ 1.2.点击DOWNLOADS

image

​ 1.3.点击GPL

image

​ 1.4.点击community server

image

​ 1.5.点击archives

image

image

​ 1.6.点击download

image

2.解压安装

​ 上述方式下载的压缩包里含有服务端和客户端,支持本地操作

3.主要文件介绍

文件 内容
bin文件夹 mysqld.exe服务端 mysql.exe客户端
data文件夹 存取数据
my-default.ini 默认配置文件

四、基本使用

1.先启动服务器

​ 可能会报错:拷贝关键信息去百度

2.查找mysqld文件位置

​ 启动mysql

​ cmd窗口就是服务端,不要关闭

3.再次开启新的cmd窗口

​ 输入mysql运行

​ 直接回车进入游客模式,功能很少

4.用户名密码登录

​ myaql -u 用户名 -p 密码

​ mysql默认管理员账户:

​ 用户名:root 密码:空

5.退出

​ exit()

​ quit

五、系统服务制作

1.如何解决每次都需要切换路径查找文件的缺陷

​ 添加环境变量

image

2.将mysql服务端制作成系统服务(随着计算机的开启而启动,关闭而关闭)

1.以管理员身份打开cmd窗口
2.执行系统服务命令
	mysql --install
3.启动服务端两种方式
	在服务里直接启动
    命令启动:net start mysql
'''
1.查看系统服务
	service.msc
2.关闭mysql服务端
	net stop mysql
3.移除系统服务
	先确保服务已经关闭
	执行移除命令:mysqld --remove

'''

image

六、密码相关操作

1.修改密码mysqladmin命令

通用方式:直接在cmd里写

mysqladmin -u用户名 -p原密码 password 新密码
# 第一次修改(初始用户名:root 初始密码:空)
mysqladmin -uroot -p password 123

偏门方法(有些版本无法使用):需要先登录

set password=PASSWORD(新密码);

2.忘记密码

直接重装/拷贝对应文件

先关闭服务端,然后以不需要校验用户身份的方式欺负,再修改,最后再安装正常方式启动

1.net stop mysql
2.mysqld --skip-grant-tables
3.mysql -uroot -p
4.updata mysql.user set password=password(123) where Host='localhost' and User='root';
5.net stop mysql
6.net start mysql

七、SQL与NoSQL

1.SQL:操作关系型数据库的语法

2.NoSQL:操作非关系型数据库的语法

ps:SQL有时候也用来表示关系型数据库,NoSQL也用来表示非关系型数据库

3.相关知识

3.1.数据库的服务端支持各种语言充当客户端

​ eg:以MySQL服务端为例

​ MySQL客户端、python代码编写的客户端、Java代码编写的客户端

3.2.为了能够兼容所有类型的客户端,有两种策略

​ 服务端兼容:不合理,消耗数据库服务端资源!!

​ 制定统一标准:SQL语句、NoSQL语句

八、数据库重要概念

​ 为了更好地理解,以类比来形容

​ 库 ==== 文件夹

​ 表 ==== 文件夹里的文件

​ 记录 ==== 文件里的一行行的数据

九、针对库的基本SQL语句

1.常识

SQL结束符:; 取消SQL语句的执行:\c

语句 功能
create database 库名; 增库
show databases;
show create database 库名;
查库
alter database 库名 charset='gbk'; 改库
drop database 库名; 删库
create table 表名(字段名 字段类型,字段名 字段类型) 新建表
select * from mysql.user; 查看user表里面的所有记录
show tables; 查看所有表
show creat table 表名;
describe 表名;
desc 表名;
查指定表
after table 旧表名 rename 新表名; 改表名
drop table 表名; 删表
insert into 表名 values(数据,数据); 添加一条数据
insert into 表名 values(数据,数据),(数据,数据),(数据,数据); 在同一个表添加多条数据
select * from 表名; 查看所有字段
select 字段1,字段2 from 表名;
ps:如果表中字段较多出现了错乱,结尾可以写\G
查找指定字段
updata 表名 set 字段名=新数据 where 筛选条件; 该记录数据
delete from 表名; 删除表中所有数据
delete from 表名 where 筛选条件 按照条件删除数据
这篇关于数据库的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!