数据库-MySQL

文章介绍了数据库从早期的文件存储到集中式管理的演变,强调了数据库在网络通信中的角色。重点讨论了MySQL,包括其服务端和客户端,以及SQL语句的基础知识,如增删改查操作。此外,还提到了数据库的安装、环境变量配置、系统服务制作和密码管理等实践内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

数据库

存储数据的演变过程

  • 随意的存到一个文件中,数据格式也是千差万别的
  • 软件开发目录规范
"""
​bin 启动文件
​conf  配置文件
​core 业务逻辑(核心代码)
​lib    公共方法
​db   存储数据
​readme.txt 阅读指南	
"""

假设上述是一个单机游戏

那么每个人的游戏记录只会在自己的计算机上面保存

注册登录的账号也只能在自己的计算机上有效

  • 如何将单机变成联网
"""
将数据库保存部分全部统一起来
所有人操作数据都来一个地方操作
"""

数据库的本质

"""
本质就是一款基于网络通信的应用程序
每个人都可以开发一款数据库软件 因为他仅仅就是一个基于网络
通信的应用程序
也就意味者数据库软件有很多
	关系型数据库
		MySQL,Oracle,db2,access,SQL,server
	非关系型数据库
		redis,mongodb,memcache
		
"""
# 关系型
	1.数据之间彼此有关系或者约束
     	男生表和前女友表
    2.存储数据的表现形式通常是以表格存储
    	name   password    hobby
        tan		123			学习
        wei		123  		美女
        每个字段还会有存储类型的限制
        比如名字只能存字符串...
# 非关系型
	存储数据通常都是以k,v键值对的形式
    

MySQL

"""
任何基于网络通信的应用程序底层用的都是socket

-服务端
	-基于socket通信
	-收发消息

-客户端
	-基于socket通信
	-收发消息
"""
MySQL不单支持自己的MySQL客户端app还支持其他编程语言来充当客服端操作
	怎样解决语言沟通的障碍?
	# 1.让服务端兼容所有的语言(一个人精通多国语言)
    # 2.采用统一的语言(SQL语句)
    

重要概念介绍

"""
库   == 文件夹
表   == 文件
记录  == 文件内一行行的数据
		name   password    hobby
        tan		123			学习
        wei		123  		美女
表头			   表格的第一行字段
字段			   name   password    hobby
"""

MySQL的安装

"""
在IT界 一般都不会轻易使用最新版本的软件,因为新版本可能会出现各种问题
小段子:
	更新完没事 那么你还是一个普通员工
	更新完出事 那么你就是一名"烈士"
"""

MySQL服务端与客户端

"""
服务端
mysqld.exe
客户端
mysql.exe
"""

启动

"""
常见软件的默认端口号
	MySQL 3306
	redis 6379
	mongodb 27017
	django 8000
	flask 5000
	tomcat 8080
MySQL第一次以管理员身份进入不需要密码 直接回车

客户端连接服务端完整命令
	mysql -h 192.168.0.101 -p 3300 -uroot -p
	
"""

sql语句初识

"""
1.MySQL中的sql语句是以分号作为结束的标志

2 基本命令
	show databases;  查看所有的库名
3.连接服务端的命令可以简写
	mysql -uroot -p
4.当输入的命令不对 又不想让服务端执行并返回报错信息 可以用\c取消
	错误命令 \c
5.客户端退出 退出命令加不加分号都可以执行
	quit exit
6 当你在连接服务端的时候 发现只输入MySQL也能连接
	但你不是管理员身份 而是游客模式
"""

环境变量配置及系统服务制作

小知识点补充

"""
1 如何查看当前具体进程
	tasklist
	tasklist |findstr mysql
2 如何杀死具体进程
	taskkill /F /PID PID号
"""

环境变量配置

"""
将MySQL所在的文件路径添加到系统环境变量中
"""
将MySQL服务端制作成系统服务(开机自启动)
"""
查看当前计算机的运行进程数
	service.msc
	
将MySQL制作成系统服务
	MySQL --install
移除MySQL系统服务
	MySQL --remove
"""

设置密码

"""
mysqladmin -uroot -p原密码 password 新密码
该命令直接在终端输入即可 无需进入客户端

示范:mysqladmin -uroot -p password 123
"""

破解密码

"""
可以将MySQL获取用户名和密码校验的功能看成是一个装饰器
装饰在了客户端请求访问的功能上

我们如果将该装饰器移除 那么MySQL服务端就不会校验用户名和密码了
"""
# 1 先关闭当前MySQL服务端
    命令行的方式启动(让MySQL跳过用户名密码验证功能)
    mysql --skip-grant-tables
# 2 直接以无密码的方式连接
	mysql -uroot -p 直接回车
# 3 修改当前用户的密码
	update mysql.user set password=password(123456) where user='root' and host='localhost'"""
真正存储用户表的密码字段 存储的肯定是密文
只有用户自己知道明文是什么 其他人都不知道 这样更加的安全
密码比对也只能比对密文
"""
# 4 立刻将修改数据刷到硬盘
	flush privileges;
# 5 关闭当前服务端 如何以正常校验授权表的形式启动

统一编码

  • mysql默认的配置文件
"""
my-default.ini
ini结尾的一般都是配置文件

程序启动会先加载配置文件中的配置之后才真正的启动
"""
[mysqld]  # 一旦服务端启动立刻加载下面的配置
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES 
[mysql]  # 一旦客户端启动立刻加载下面的配置
...
[client]  # 其他客户端
...
# 需要你自己新建一个my.ini的配置文件

# 验证配置文件是否真的会自动加载
[mysql]
print('hello world')

# 修改配置文件之后重启生效

# 将管理员的用户名和密码也添加到配置文件中
[mysql]
character-set-server=utf8
collation-server=utf8_general_ci
[client]
default-character-set-utf8
[mysql]
user="root"
password=
default-character-set=utf8

基本SQL语句

ps:大部分程序的业务逻辑其实都是增删改查

"""
辛辛苦苦一个月 只为了一条SQL语句(将自己账户的钱修改一下)
"""
针对库的增删改查(文件夹)
# 增
create database db1;
create database db2 charset='gbk';  # 指定字符编码
# 查
show databases;  # 查所有
show create database db1;  # 查单个
# 改
alter database db1 charset='utf8';
# 删
drop database db1;
针对表的增删改查(文件)
"""
在操作表(文件)的时候 需要指定所在的库(文件夹)
"""
# 查看当前所在的库的名字
select database();
# 切换库
use db1;
# 增
create table t1(id int,name char(4));
# 查
show tables;  # 查看当前库下面所有的表名
show create table t1;  # 查看单个库名
describe t1;  # 简写 desc t1;
# 改
alter table t1 modify name char(16);
# 删
drop table t1;  
# create table db1.t1(id int);  # 也可以用绝对路径的形式操作不同的库
针对数据的增删改查(一行行数据)
"""
一定要先有库 有表 最后才能操作记录
"""
# 增
insert into t1 values(1,'tan')
insert info t1 values(1,'tan'),(2,'wei'),(3,'tw')
# 查
select * from t1;  # 该命令当数据量特别大的时候不建议使用
select name from t1;  # 拿出所有名字
# 改
update t1 set name='DSB' where id > 1;
# 删
delete from t1 where id > 1;
delete from t1 where name='tan'
# 将所有的数据清空
delete from t1;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值