当前位置: 首页 > news >正文

【MySQL】数据库基础 -- 详解

一、什么是数据库

存储数据用文件就可以了,为什么还要弄个数据库?

一般的文件确实提供了数据的存储功能,但是文件并没有提供非常好的数据(内容)的管理能力(用户角度)。

文件保存数据有以下几个缺点:
  • 文件的安全性问题
  • 文件不利于数据查询和管理
  • 文件不利于存储海量数据
  • 文件在程序中控制不方便 

数据库的本质:对数据内容存储的一套解决方案,mysql 客户端给我字段或者要求,我直接给 mysql 客户端结果就行。(“我”:在磁盘上存储的数据库文件 + mysql 客户端)

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

  • mysql 是数据库服务的客户端
  • mysqld 是数据库服务的服务器端。 

  • mysql 本质:基于 C(mysql) S(mysqld) 模式的一种网络服务

(可以查看到 mysql 所绑定的端口号:3306)

mysql 是一套提供数据存取的服务的网络程序。

口语上:

数据库特指:在磁盘或者内存中存储的特定结构组织的数据 -- 将来在磁盘上存储的一套数据库方案

数据库服务:mysqld


二、主流数据库

  • SQL Sever: 微软的产品,.Net 程序员的最爱,中大型项目。
  • Oracle: 甲骨文产品,适合大型项目,复杂的业务逻辑,并发一般来说不如 MySQL。
  • MySQL:世界上最受欢迎的数据库,属于甲骨文,并发性好,不适合做复杂的业务。主要用在电商,SNS,论坛。对简单的 SQL 处理效果好。
  • PostgreSQL :加州大学伯克利分校计算机系开发的关系型数据库,不管是私用,商用,还是学术研究使用,可以免费使用,修改和分发。
  • SQLite: 是一款轻型的数据库,是遵守 ACID 的关系型数据库管理系统,它包含在一个相对小的 C 库中。它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K 的内存就够了。
  • H2: 是一个用 Java 开发的嵌入式数据库,它本身只是一个类库,可以直接嵌入到应用项目中。

三、基本使用

1、MySQL 安装

【MySQL】在 Centos7 环境安装 MySQL -- 详细完整教程-CSDN博客


2、连接服务器

输入:

mysql -h 127.0.0.1 -P 3306 -u root -p

登陆选项的认识: 

输出:

Enter password:Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.7.21-log MySQL Community Server (GPL)Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.mysql>
注意
  • 如果没有写 -h 127.0.0.1 默认是连接本地。
  • 如果没有写 -P 3306 默认是连接 3306 端口号。

3、服务器管理

执行 win+r 输入 services.msc 打开服务管理器
通过下图左侧停止,暂停,重启动按钮进行服务管理


4、服务器,数据库,表关系

  • 所谓安装数据库服务器,只是在机器上安装了一个数据库管理系统程序,这个管理程序可以管理多个数据库一般开发人员会针对每一个应用创建一个数据库
  • 为保存应用中实体的数据,一般会在数据库中创建多个表,以保存程序中实体的数据。
  • 数据库服务器、数据库和表的关系如下:


5、数据库的使用

使用 mysql 建立一个数据库,建立一张表结构,插入一些数据 -- 对比一下 mysql 在 Linux 中是如何表现的。

  1. 建立数据库,本质就是 Linux 下的一个目录。
  2. 在数据库内建立表,本质就是在 Linux 下创建对应的文件即可。

以上工作是 mysqld 服务做的。

注意

数据库的本质也是文件只不过这些文件并不由程序员直接操作,而是由数据库服务帮我们进行操作。


(1)创建数据库
create database helloworld;


(2)使用数据库
use helloworld;


(3) 创建数据库表


(4)表中插入数据
insert into student (name, age, gender) values ("张三", 20, '男');
insert into student (name, age, gender) values ("李四", 22, '男');

(5)查询表中的数据
select * from student;

(6)数据逻辑存储


四、MySQL架构

MySQL 是一个可移植的数据库,几乎能在当前所有的操作系统上运行,如 Unix/Linux、 Windows Mac 和 Solaris。各种系统在底层实现方面各有不同,但是 MySQL 基本上能保证在各个平台上的物理体系结构的一致性。


五、SQL 语句分类

  • DDLdata definition language数据定义语言,用来维护存储数据的结构
代表指令: create,drop,alter

  • DMLdata manipulation language数据操纵语言,用来数据进行操作
代表指令: insert delete update
  • DML中又单独分了一个DQL,数据查询语言,代表指令: select

  • DCLData Control Language数据控制语言,主要负责权限管理和事务
代表指令: grant revoke commit

六、存储引擎

1、存储引擎

存储引擎:数据库管理系统如何存储数据、如何为存储的数据建立索引和如何更新、查询数据等技术的实现方法。

MySQL  的核心就是插件式存储引擎,支持多种存储引擎。

2、查看存储引擎

show engines;


3、存储引擎对比 

相关文章:

【MySQL】数据库基础 -- 详解

一、什么是数据库 存储数据用文件就可以了,为什么还要弄个数据库? 一般的文件确实提供了数据的存储功能,但是文件并没有提供非常好的数据(内容)的管理能力(用户角度)。 文件保存数据有以下几个缺点&…...

零基础学Python之整合MySQL

Python 标准数据库接口为 Python DB-API,Python DB-API为开发人员提供了数据库应用编程接口。 不同的数据库你需要下载不同的DB API模块,例如你需要访问Oracle数据库和Mysql数据,你需要下载Oracle和MySQL数据库模块。 DB-API 是一个规范. 它…...

股票均线的使用方法和实战技术,看涨看空的均线形态与案例教学

一、教程描述 本套教程讲解了14种均线的特殊形态,通过直观图形以及大量案例的教学,将深奥、繁琐的均线变得生动与具体,广大投资者在认真学习以后,可以学会均线的使用方法,掌握最强的均线应用实战技术。本套教程不仅适…...

服务器被黑,安装Linux RootKit木马

前言 疫情还没有结束,放假只能猫家里继续分析和研究最新的攻击技术和样本了,正好前段时间群里有人说服务器被黑,然后扔了个样本在群里,今天咱就拿这个样本开刀,给大家研究一下这个样本究竟是个啥,顺便也给…...

【数据结构与算法】【腾讯阿里链表面试题】算法题--链表易懂版讲解

🎉🎉欢迎光临🎉🎉 🏅我是苏泽,一位对技术充满热情的探索者和分享者。🚀🚀 🌟特别推荐给大家我的最新专栏《Spring 狂野之旅:底层原理高级进阶》 &#x1f680…...

3d渲染100农场如何使用?渲染100邀请码1a12

3d渲染农场通常用于电影、动画或视觉效果的渲染,本文以广受好评的渲染100农场为例,来讲解它的使用方法。 1、注册账号 前往渲染100官网(http://www.xuanran100.com/?ycode1a12)注册账号, 新用户注册记得填邀请码1a12,有30元大礼…...

【数据结构和算法】--- 基于c语言排序算法的实现(2)

目录 一、交换排序1.1 冒泡排序1.2 快速排序1.2.1 hoare法1.2.2 挖坑法1.2.3 前后指针法 1.3 快速排序优化1.3.1 三数取中法选key1.3.2 递归到小的子区间使用插入排序 1.4 快排非递归版 二、归并排序2.1 归并排序2.1.1 递归版2.1.2 非递归版 一、交换排序 基本思想&#xff1a…...

ORACLE的 软 软 软 解析!

在海鲨数据库架构师精英群里,有位朋友说ORACLE 有 软软软解析. 就是把执行计划缓存在客户端里,从而避免去服务端找执行计划. 他给了个设置方法, Weblogic console->datasource->connectionPool Statement Cache Type >LRU Statement Cache Size100 CURSOR_NUMBER …...

【模板】k 短路 / [SDOI2010] 魔法猪学院

题目背景 注:对于 k k k 短路问题,A* 算法的最坏时间复杂度是 O ( n k log ⁡ n ) O(nk \log n) O(nklogn) 的。虽然 A* 算法可以通过本题原版数据,但可以构造数据,使得 A* 算法在原题的数据范围内无法通过。事实上&#xff0c…...

【Make编译控制 08】CMake动静态库

目录 一、编译动静态库 二、链接静态库 三、链接动态库 前情提示:【Make编译控制 07】CMake常用命令-CSDN博客 有些时候我们编写的源代码并不需要将他们编译生成可执行程序,而是生成一些静态库或动态库提供给第三方使用,所以我们需要用到…...

05 06 Verilog基础语法与应用讲解

05. 1. 位操作 计数器实验升级&#xff0c;设计8个LED灯以每个0.5s的速率循环闪烁&#xff08;跑马灯&#xff09; 1.1 方法1&#xff1a;使用移位操作符<<来控制led灯的循环亮灭 设计代码 Verilog中&#xff0c;判断操作的时候不加位宽限定是可以的&#xff0c;比如i…...

css2复合选择器

一.后代&#xff08;包含&#xff09;选择器&#xff08;一样的标签可以用class命名以分别&#xff09; 空格表示 全部后代 应用 二.子类选择器 >表示 只要子不要孙 应用 三.并集选择器 &#xff0c;表示 代表和 一般竖着写 应用 四.伪类选择器&#xff08;包括伪链接…...

新版MQL语言程序设计:键盘快捷键交易的设计与实现

文章目录 一、什么是快捷键交易二、使用快捷键交易的好处三、键盘快捷键交易程序设计思路四、键盘快捷键交易程序具体实现1.界面设计2.键盘交易事件机制的代码实现 一、什么是快捷键交易 操盘中按快捷键交易是指在股票或期货交易中&#xff0c;通过使用快捷键来进行交易操作的…...

数据结构之基数排序

基数排序的思想是按组成关键字的各个数位的值进行排序&#xff0c;它是分配排序的一种。在该排序方法中把一个关键字 Ki看成一个 d 元组&#xff0c;即       K1i,K2i,,Kdi 其中&#xff0c;0≤ Kji<r&#xff0c;i1~ n&#xff0c;j1~d。这里的r 称为基数。若关键字是…...

区间dp 笔记

区间dp一般是先枚举区间长度&#xff0c;再枚举左端点&#xff0c;再枚举分界点&#xff0c;时间复杂度为 环形石子合并 将 n 堆石子绕圆形操场排放&#xff0c;现要将石子有序地合并成一堆。 规定每次只能选相邻的两堆合并成新的一堆&#xff0c;并将新的一堆的石子数记做该…...

MySQL-SQL优化

文章目录 1. SQL性能分析1.1 SQL执行频率1.2 慢查询日志1.3 profile详情1.4 explain 2. SQL优化2.1 Insert 优化2.2 Group By 优化2.3 Order By 优化2.4 Limit 优化2.5 Count() 优化2.6 Update 优化 3. 拓展3.1 请你说一下MySQL中的性能调优的方法&#xff1f;3.2 执行 SQL 响应…...

详细了解ref和reactive.

这几天看到好多文章标题都是类似于&#xff1a; 不用 ref 的 xx 个理由不用 reactive 的 xx 个理由历数 ref 的 xx 宗罪 我就很不解&#xff0c;到底是什么原因导致有这两批人&#xff1a; 抵触 ref 的人抵触 reactive 的人 看了这些文章&#xff0c;我可以总结出他们的想法…...

使用Linux docker方式快速安装Plik并结合内网穿透实现公网访问

文章目录 1. Docker部署Plik2. 本地访问Plik3. Linux安装Cpolar4. 配置Plik公网地址5. 远程访问Plik6. 固定Plik公网地址7. 固定地址访问Plik 本文介绍如何使用Linux docker方式快速安装Plik并且结合Cpolar内网穿透工具实现远程访问&#xff0c;实现随时随地在任意设备上传或者…...

Redis Centos7 安装到启动

文章目录 安装Redis启动redis查看redis状况连接redis服务端 安装Redis 1.下载scl源 yum install centos-release-scl-rh2.下载redis yum install rh-redis5-redis 3. 创建软连接 1.cd /usr/bin 2. In -s /opt/rh/rh-redis5/root/usr/bin/redis-server ./redis-server 3. …...

「数据结构」二叉搜索树1:实现BST

&#x1f387;个人主页&#xff1a;Ice_Sugar_7 &#x1f387;所属专栏&#xff1a;Java数据结构 &#x1f387;欢迎点赞收藏加关注哦&#xff01; 实现BST &#x1f349;二叉搜索树的性质&#x1f349;实现二叉搜索树&#x1f34c;插入&#x1f34c;查找&#x1f34c;删除 &am…...

Llama-3.2V-11B-cot应用场景:文化遗产数字化中壁画破损区域逻辑复原

Llama-3.2V-11B-cot应用场景&#xff1a;文化遗产数字化中壁画破损区域逻辑复原 1. 项目背景与价值 壁画作为人类文明的重要载体&#xff0c;在长期保存过程中常面临褪色、剥落、破损等问题。传统修复工作依赖专家经验&#xff0c;存在效率低、成本高、主观性强等痛点。Llama…...

三维智能分割技术:从行业痛点到落地实践的全面解析

三维智能分割技术&#xff1a;从行业痛点到落地实践的全面解析 【免费下载链接】SAMPart3D SAMPart3D: Segment Any Part in 3D Objects 项目地址: https://gitcode.com/gh_mirrors/sa/SAMPart3D 问题场景&#xff1a;三维模型处理的现实困境 建筑设计行业&#xff1a;…...

OpenClaw+GLM-4-7-Flash科研助手:自动整理文献与生成综述

OpenClawGLM-4-7-Flash科研助手&#xff1a;自动整理文献与生成综述 1. 为什么需要自动化科研助手 作为一名经常需要阅读大量文献的研究者&#xff0c;我发现自己花费在文献整理上的时间越来越多。每次打开文件夹看到几十篇PDF文献时&#xff0c;那种"从哪里开始"的…...

低成本AI实验:OpenClaw+nanobot学生方案

低成本AI实验&#xff1a;OpenClawnanobot学生方案 1. 为什么学生需要关注OpenClaw 作为一名计算机专业的学生&#xff0c;我一直在寻找既能满足课程项目需求又不会让钱包"大出血"的AI解决方案。直到发现了OpenClawnanobot这个组合&#xff0c;它完美解决了我在机器…...

效率对比测试:OpenClaw+nanobot vs 手动完成重复工作

效率对比测试&#xff1a;OpenClawnanobot vs 手动完成重复工作 1. 为什么需要自动化效率测试 作为一名数据分析师&#xff0c;我每天都要处理大量重复性工作&#xff1a;整理Excel文件、录入数据、清洗表格、生成报告。这些工作虽然简单&#xff0c;但极其耗时且容易出错。最…...

基于ChatGPT GPTs的AI辅助开发实战:从零构建智能代码生成器

背景痛点&#xff1a;传统开发流程中的效率瓶颈 作为一名开发者&#xff0c;我们每天都在与代码打交道。但你是否也经常遇到这些令人头疼的场景&#xff1f; 需求理解偏差&#xff1a;产品经理用自然语言描述了一个复杂功能&#xff0c;你花了大半天时间反复沟通&#xff0c;…...

星图平台双镜像方案:OpenClaw与百川2-13B的隔离部署技巧

星图平台双镜像方案&#xff1a;OpenClaw与百川2-13B的隔离部署技巧 1. 为什么需要双镜像隔离部署 去年我在尝试将OpenClaw接入本地大模型时&#xff0c;踩过一个典型的坑&#xff1a;当模型需要更新或维护时&#xff0c;整个自动化流程就会中断。最严重的一次&#xff0c;模…...

嵌入式开发调试技巧与宏应用详解

嵌入式软件开发调试技巧全解析 1. 调试基础宏的使用 1.1 编译器内置调试宏 在嵌入式开发中&#xff0c;GCC编译器提供了一系列内置宏用于调试&#xff0c;这些宏会在编译时自动展开&#xff1a; __FILE__ // 当前源文件名 (char*) __FUNCTION__ // 当前函数名 (char*) _…...

伏特台风(Volt Typhoon):针对关键基础设施的无文件攻击与潜伏技术深度剖析

前言 技术背景&#xff1a;在现代网络攻击与防御&#xff08;Cybersecurity&#xff09;的宏大叙事中&#xff0c;高级持续性威胁&#xff08;APT&#xff09;代表了最高级别的对抗。而“伏特台风”&#xff08;Volt Typhoon&#xff09;组织所采用的**无文件攻击&#xff08;F…...

AI辅助开发实战:基于Chatbot和Copilot的智能编程优化方案

AI辅助开发实战&#xff1a;基于Chatbot和Copilot的智能编程优化方案 在快节奏的软件开发世界里&#xff0c;我们常常陷入一种循环&#xff1a;写重复的样板代码、调试琐碎的边界条件、查阅冗长的API文档。这些看似必要的工作&#xff0c;实际上占用了我们大量的创造性时间。作…...