ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

数据库

2022-08-14 18:30:27  阅读:271  来源: 互联网

标签:mysql 数据库 表名 MySQL 数据 服务端


目录

数据存取演变史

一、文本文件

​ 文件路径可能不一致: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 筛选条件 按照条件删除数据

标签:mysql,数据库,表名,MySQL,数据,服务端
来源: https://www.cnblogs.com/Zhang614/p/16585972.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有