MySQL --- MySQL数据库基础

MySQL数据库基础

一、数据库基础

1.1什么是数据库

我们熟知文件也是有一定的数据存储功能的,尽管如此文件保存数据有以下几个缺点:

(1)文件的安全性问题得不到保障

(2)文件不利于数据查询和管理、不利于存储海量数据

(3)文件在程序中控制不方便

为了解决上述问题,专家们设计出更加利于管理数据的东西------数据库,它能更有效的管理数据;数据库存储介质有:磁盘、内存;数据库的水平是衡量一个程序员水平的重要指标;

1.2基本使用

1.2.1mysql安装

我当前Linux系统是Ubuntu22.04发行版,直接使用qpt包管理器安装默认mysql即可,对与学习sql语句,创建库,表等操作就已经够用了。

直接在终端上输入下面的指令:

复制代码
apt install mysql-server -y

安装完成后mysql服务通常会自动启动。

1.2.2mysql介绍

mysql是一个基于C(mysql客户端) / S(mysqld服务端)模式的网络服务,通俗来将就是:

用户使用mysql客户端向mysqld服务端下达各种操作指令,由mysqld解析并进行对应的指令操作(比如说create database),最后再回显给客户端的一种网络服务模式,而我们常说的数据库就是mysqld在底层文件系统上维护的一系列文件(数据、索引、日志、元数据/属性),并且只能由mysqld来安全的进行读写。

1.2.3mysql基础使用

(1)启动mysql:systemctl start mysql

查看启动状态:systemctl status mysql

(2)登录mysql:mysql -h 登录IP地址 -P 端口号 -u 登录用户 -p

使用本地登录可以不选用前两个选项。

Ubuntu系统root用户没有进行密码设置,mysql8.0登录root账号时不用输入密码,出现Enter password时直接按下回车键即可登录成功。

(3)首次创建数据库以及表

创建数据库:
复制代码
create database 你的数据库名称;            
查看所有数据库:
复制代码
show databases;
使用数据库:
复制代码
use 你的数据库名称;
创建数据库表:
复制代码
create table 你的表名字(
	列名1 数据类型 约束,
	列名2 数据类型 约束,
	......
);
向表中插入数据:
复制代码
insert into student (id, name, gender) values (1, '张三', '男');
insert into student (id, name, gender) values (2, '李四', '男');
查询表数据:
复制代码
select * from student;

具体这些语句代表什么含义,怎么具体使用,后续博客会持续跟进学习的。

创建库,表的本质:

在Linux系统下,创建一个数据库,在库中创建表结构,本质上是在特定路径(/var/lib/mysql)下创建目录,在目录中创建文件。

对应刚刚show databases查看的所有数据库信息,hellomysql数据库就在其中。

(4)关闭mysql服务

若短时间内不需要使用mysql了,可以直接退出Liunx系统,占用小部分资源一直在后台运行;若长时间不会使用mysql了可以关闭mysql服务,下次使用重新启动即可:

复制代码
systemctl stop mysql;

1.3SQL分类

(1)DDL【data definition language】数据定义语言,用来维护存储数据的结构

代表指令: create, drop, alter

(2)DML【data manipulation language】数据操纵语言,用来对数据进行操作

代表指令:insert,delete,update

DML中又单独分了一个DQL,数据查询语言,代表指令:select

(3)DCL【Data Control Language】数据控制语言,主要负责权限管理和事务

代表指令:grant,revoke,commit

相关推荐
卡次卡次14 小时前
vibecoding起步注意点:插件、Skills、MCP、Hooks
服务器·数据库·python·oracle
Elastic 中国社区官方博客4 小时前
每次操作一个 API 调用:Elastic Cloud Hosted 如何让大规模部署管理变得可行
大数据·运维·数据库·elasticsearch·搜索引擎·serverless
清溪5495 小时前
pgAdmin4 <= 9.1_RCE(CVE-2025-2945)复现
数据库·后端
清溪5495 小时前
pgAdmin4后台Restore RCE(CVE-2025-13780)复现
数据库·后端
煎饼皮皮侠5 小时前
【设计】设计一个web版的数据库管理平台后端(之三) -- 多数据库通用分页
数据库·web数据库·查询平台
Rick19935 小时前
mysql联合索引经典实例
java·数据库·mysql
anew___5 小时前
《数据库原理》精要解读(七)—— 数据库设计:从蓝图到现实的系统工程
数据库·oracle
独隅5 小时前
MySQL 接入不同 AI 大模型进行数据管理的全面指南(MySQL + AI)
数据库·人工智能·mysql
go不是csgo6 小时前
GORM 上手:一个 main.go 跑通 Go 数据库增删改查
jvm·数据库·golang
lld9510276 小时前
(一)云回测:量化策略上线前的必经之路
java·服务器·数据库