轻松上手MYSQL:MYSQL初识(上)

在这里插入图片描述
​🌈 个人主页:danci_
🔥 系列专栏:《MYSQL入门》
💪🏻 制定明确可量化的目标,坚持默默的做事。


轻松上手MYSQL:从零开始构建你的数据库世界 🚀

🚀欢迎来到MySQL世界的探索之旅🚀
 
    大家好👋!今天,我们要深入探讨的,是MYSQL这颗在数据库宇宙中耀眼的星星✨。作为技术探索者,我们会发现MYSQL不仅是一款功能强大的数据库管理系统,它还拥有着令人着迷的核心特性,让无数开发者和公司为之倾倒。接下来,就让我们一一揭开MYSQL的秘密面纱,深入其核心特性的奥秘吧!🔍


文章目录

  • 一、MYSQL初识 🎯
    • `📚 简介`
    • `🌐 开源与灵活性`
    • `⏰ 性能与安全性`
    • `🚦 扩展性与生态`
    • `🎨 MySQL HeatWave`
    • `🤔 你读对了吗`
  • 二、MYSQL特性 🚀
    • `✨ MYSQL内部机制与可移植性`
    • `💫 MYSQL数据类型`
    • `🌟 MYSQL语句`
    • `🚀 MYSQL函数`
  • 🌟 最后的小贴士📢

 

一、MYSQL初识 🎯

 
在这里插入图片描述

📚 简介

 
    MySQL是最流行的开源SQL数据库管理系统,由Oracle公司支持。它采用关系型数据库模型,通过表存储数据,并利用SQL语言进行数据操作。MySQL以其快速、可靠、可扩展和易用性受到广大用户的青睐。无论是台式机、笔记本电脑还是大型服务器集群,MySQL都能提供高效的数据库服务。
 

🌐 开源与灵活性

 
    MySQL软件采用开源模式,任何人都可以免费下载和使用,并可根据需要修改源代码。这种开放性使得MySQL拥有广泛的社区支持和丰富的功能扩展。
 

⏰ 性能与安全性

 
    MySQL数据库服务器具有出色的性能和安全性,能够处理大量数据,并保证数据的一致性和完整性。通过客户端/服务器或嵌入式系统架构,MySQL能够方便地集成到各种应用中,为互联网应用提供高效的数据访问服务。
 

🚦 扩展性与生态

 
    MySQL拥有丰富的API和编程接口,支持多种后端和客户端程序。同时,大量第三方工具和贡献的MySQL软件可用,使得MySQL生态系统更加完善。
 

🎨 MySQL HeatWave

 
    MySQL HeatWave是一个完全托管的数据库服务,结合交易和实时数据分析,提供机器学习功能,可在不同云服务平台上使用。
 

🤔 你读对了吗

    “MySQL”的官方发音是“My Ess Que Ell”(而不是“my sequel”),但我们不介意你把它读成“my sequel”或其他一些本地化的方式。
 

二、MYSQL特性 🚀

 
在这里插入图片描述

✨ MYSQL内部机制与可移植性

 
    MYSQL是一个功能强大的关系型数据库管理系统,其内部机制设计精巧,可移植性极佳,使得用户能够在多种环境和场景下轻松部署和应用。下面我们将深入剖析MYSQL的内部机制,并探讨其出色的可移植性。
 
    MYSQL结构清晰,易于管理
 
    MYSQL采用关系模型来组织数据,通过表、行和列来存储和管理数据。每个表都有一个唯一的名称,并且由若干列组成,每列都有相应的数据类型和约束条件。这种结构化的数据存储方式使得数据之间的关系清晰明了,便于查询和管理。
 
    存储引擎多样,满足各种业务需求
 
    在存储机制方面,MYSQL采用了多种存储引擎,如InnoDB、MyISAM等,以满足不同场景下的需求。这些存储引擎在数据的存储、索引、并发控制等方面都有各自的特点和优势。例如,InnoDB存储引擎支持事务处理和行级锁定,能够提供高并发和高可靠性的数据库服务;而MyISAM存储引擎则提供了全文索引和压缩功能,适用于需要快速读取和存储大量数据的应用场景。
 
    SQL语言强大,查询高效
 
    MYSQL的查询语言——SQL(结构化查询语言)是其内部机制的重要组成部分。通过SQL语言,用户可以方便地执行数据的增删改查操作,实现复杂的数据分析和处理任务。MYSQL的查询优化器会对用户的SQL语句进行优化,选择最佳的执行计划,以提高查询效率和性能。
 
    事务处理保证数据完整
 
    在事务处理方面,MYSQL提供了ACID(原子性、一致性、隔离性、持久性)保证的事务处理机制。通过事务处理,用户可以确保一系列操作的原子性,即要么全部成功执行,要么全部不执行,从而保证了数据的完整性和一致性。
 
    字段类型丰富,约束灵活
 
    字段类型是MYSQL内部机制中的另一个关键要素。MYSQL支持多种数据类型,包括整数、浮点数、字符串、日期时间等,用户可以根据实际需求选择合适的数据类型来存储数据。此外,MYSQL还提供了约束条件,如主键、外键、唯一约束等,用于保证数据的完整性和准确性。
 
    可移植性强,跨平台运行
 
    除了以上提到的内部机制外,MYSQL的可移植性也是其受欢迎的重要原因之一。MYSQL可以在多种操作系统和硬件平台上运行,无论是Windows、Linux还是Mac OS,无论是x86架构还是ARM架构,MYSQL都能够稳定运行并提供高效的数据库服务。这使得用户可以根据自己的需求选择合适的平台和环境来部署MYSQL。
 
    接口丰富,易于集成迁移
 
    此外,MYSQL还提供了丰富的接口和工具,方便与其他数据库系统进行集成和迁移。用户可以使用ODBC、JDBC等接口将MYSQL与其他应用程序进行连接,实现数据的共享和交换。同时,MYSQL也支持数据的导入导出功能,用户可以将数据从其他数据库系统迁移到MYSQL中,或者将MYSQL中的数据导出到其他格式进行备份或共享。
 
    小结:卓越性能,用户首选
 
    综上所述,MYSQL凭借其精巧的内部机制和出色的可移植性,成为了众多企业和个人用户的首选数据库系统。无论是数据库结构、存储机制、查询语言还是事务处理等方面,MYSQL都展现出了其卓越的性能和灵活性。相信随着技术的不断发展,MYSQL将继续为广大用户提供更加高效、稳定、易用的数据库服务。
 

💫 MYSQL数据类型

 
    在MYSQL数据库中,数据类型是定义表中字段的重要属性,它决定了字段能够存储的数据种类、范围以及如何进行存储和处理。MYSQL支持丰富的数据类型,每种类型都有其独特的定义、特点和应用场景。下面我们将详细介绍MYSQL的几种主要数据类型,并给出具体的示例和解释。
 
    数值类型

    数值类型用于存储数字数据,包括整数和浮点数。

    整数类型:如TINYINT、SMALLINT、MEDIUMINT、INT、BIGINT等,它们分别表示不同范围的整数。例如,TINYINT是有符号的8位整数,取值范围为-128到127。适用于存储年龄、数量等小范围整数数据。
    示例: AGE TINYINT(3),用于存储年龄,最大值为99。

    浮点数和定点数类型:FLOAT和DOUBLE用于存储单精度和双精度浮点数,DECIMAL和NUMERIC用于存储定点数。定点数在存储和计算时能够保持更高的精度,适用于需要精确计算的场景,如金融应用。
    示例: PRICE DECIMAL(10,2),用于存储价格,保留两位小数。
 

    字符串类型

    字符串类型用于存储文本数据。

    定长字符串:CHAR类型用于存储定长字符串,它会预留固定长度的存储空间,不足部分用空格填充。适用于存储长度固定的数据,如手机号码、身份证号等。
    示例: PHONE CHAR(11),用于存储手机号码,固定长度为11位。

    变长字符串:VARCHAR类型用于存储变长字符串,它只占用实际字符串长度的存储空间加上一个或两个额外字节来记录长度。适用于存储长度不固定的文本数据,如姓名、地址等。
    示例: NAME VARCHAR(50),用于存储姓名,最大长度为50个字符。
 

    日期和时间类型

    日期和时间类型用于存储日期、时间或日期时间值。

    DATE:用于存储日期值,格式为’YYYY-MM-DD’。
    TIME:用于存储时间值,格式为’HH:MM:SS’。
    DATETIME:用于存储日期和时间值,格式为’YYYY-MM-DD HH:MM:SS’。
    TIMESTAMP:也用于存储日期和时间值,但与UNIX时间戳相关,具有时区感知和自动更新的特性。
    示例: CREATE_TIME TIMESTAMP DEFAULT CURRENT_TIMESTAMP,用于存储记录的创建时间,默认为当前时间戳。
 

    二进制数据类型

    二进制数据类型用于存储二进制数据。

    BINARY和VARBINARY:类似于CHAR和VARCHAR,但用于存储二进制字符串。
    BLOB:用于存储二进制大对象,如图片、音频、视频等。根据存储需求的不同,有TINYBLOB、BLOB、MEDIUMBLOB和LONGBLOB等类型。
    示例: LOGO BLOB,用于存储用户头像的二进制数据。
 

    枚举和集合类型

    ENUM:枚举类型,允许从预定义的值列表中选择一个值。适用于存储固定范围的选择项,如性别、学历等。
    示例: GENDER ENUM(‘男’, ‘女’),用于存储性别。

    SET:集合类型,允许从预定义的值列表中选择一个或多个值。适用于存储多个选项的组合,如兴趣爱好、技能等。
    示例: HOBBIES SET(‘阅读’, ‘运动’, ‘旅游’),用于存储用户的兴趣爱好。
 

🌟 MYSQL语句

 
    MYSQL的语句和函数是数据库操作的核心组成部分,它们使得数据的增删改查、转换和计算变得简单而高效。下面,我们将深入介绍MYSQL的一些常用语句和函数,帮助大家更好地理解和应用它们。
 
    SELECT语句

    用途:用于从数据库表中检索数据。
    语法:SELECT column1, column2, ... FROM table_name WHERE condition;
    参数:
      column1, column2, ...:要检索的列名。
      table_name:要检索数据的表名。
      condition:可选的,用于筛选数据的条件。

    返回值:返回满足条件的行和列的数据。
    实例: SELECT * FROM users WHERE age > 25;(从users表中检索年龄大于25的所有用户的所有数据。)
 

    INSERT INTO语句

    用途:用于向数据库表中插入新数据。
    语法:INSERT INTO table_name (column1, column2, column3, ...) VALUES (value1, value2, value3, ...);
    参数:
      table_name:要插入数据的表名。
      column1, column2, column3, ...:要插入数据的列名。
      value1, value2, value3, ...:要插入的具体数据值。

    返回值:通常返回一个操作成功的消息或受影响的行数。
    实例INSERT INTO users (name, age) VALUES ('John Doe', 30);(在users表中插入一条新记录,name为’John Doe’,age为30。)
 
 
    UPDATE语句

    用途:用于更新数据库表中的数据。
    语法:UPDATE table_name SET column1 = value1, column2 = value2, ... WHERE condition;
    参数:
      table_name:要更新数据的表名。
      column1 = value1, column2 = value2, ...:要更新的列及其新值。
      condition:可选的,用于指定要更新的行的条件。

    返回值:通常返回一个操作成功的消息或受影响的行数。
    实例UPDATE users SET age = age + 1 WHERE name = 'John Doe';(将名为’John Doe’的用户的年龄加1。)
 

    DELETE语句

    用途:用于从数据库表中删除数据。
    语法:DELETE FROM table_name WHERE condition;
    参数:
      table_name:要删除数据的表名。
      condition:可选的,用于指定要删除的行的条件。如果不指定条件,将删除表中的所有行。

    返回值:通常返回一个操作成功的消息或受影响的行数。
    实例DELETE FROM users WHERE age < 20;(从users表中删除年龄小于20的所有用户。)
 

🚀 MYSQL函数

 
    MYSQL提供了大量的内置函数,用于处理数据、转换数据类型、计算聚合值等。下面介绍几个常用的函数。
 

    CONCAT()函数

    用途:用于连接两个或多个字符串。
    语法:CONCAT(string1, string2, ...)
    参数:string1, string2, ...:要连接的字符串。

    返回值:返回连接后的字符串。
    实例:SELECT CONCAT(first_name, ' ', last_name) AS full_name FROM users;(将users表中的first_name和last_name列连接成一个full_name列。)
 

    DATE_FORMAT()函数

    用途:用于按指定格式显示日期/时间数据。
    语法:DATE_FORMAT(date, format)
    参数:
      date:要格式化的日期/时间值。
      format:指定的日期/时间格式。

    返回值:返回按指定格式显示的日期/时间字符串。
    实例:SELECT DATE_FORMAT(NOW(), '%Y-%m-%d') AS current_date;(返回当前日期的字符串表示,格式为’YYYY-MM-DD’。)
 

    SUM()函数

    用途:用于计算某列的总和。
    语法:SUM(column_name)
    参数:column_name:要计算总和的列名。

    返回值:返回指定列的总和。
    实例:SELECT SUM(amount) AS total_amount FROM orders;(计算orders表中amount列的总和,并返回为total_amount。)
 

    COUNT()函数

    用途:用于计算表中的行数或满足条件的行数。
    语法:COUNT(column_name) 或 COUNT(*)
    参数:
      column_name:可选的,要计数的列名。如果指定列名,将只计算非NULL值的行数。
      *:如果使用*,将计算表中的所有行数,包括包含NULL值的行。
 

🌟 最后的小贴士📢

 
    别忘了,每天的积累都很重要,即使是每天抽出30分钟,也可以让你与别人拉开差距!加油吧,你可以成为下一个数据库大师!💥
 
    在整个学习过程中,一定要保持好奇心和探索心,不断实践和交流。如果你有任何问题,记得在评论区留言哦~我们一起学习成长,掌握MYSQL带来的种种可能性!🌟🎓
 

    希望你从这篇文章的介绍中,得到启发如何开始学习MYSQL。希望这些文字能带给你灵感和动力!
 

    记得点赞👍,转发和关注哦,我们下次见!👋😊

   👇

轻松上手MYSQL:MYSQL初识(下) MYSQL以其卓越的性能、广泛的社区支持和不断创新的特性,成为了数据库领域的佼佼者。相信在未来,它将继续引领数据库技术的发展,为用户提供更加高效、安全和智能的数据管理服务。 https://boutique.blog.csdn.net/article/details/137809569  

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/547921.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

pmp认证考试一年有几次,报名复杂吗?

PMP认证怎么报名&#xff1f;PMP培训机构怎么看是否靠谱&#xff1f; PMP认证报名官方有一个流程图&#xff0c;大家可以参考一下这几个步骤&#xff0c;如果你先前没有了解过PMP的话可能看着有点乱&#xff0c;但是如果是在机构培训后考试的就会觉得简单&#xff0c;毕竟这些…

ip数据报

IP数据报格式详解 在 TCP/IP 协议中&#xff0c;使用 IP 协议传输数据的包被称为 IP 数据包&#xff0c;每个数据包都包含 IP 协议规定的内容。IP 协议规定的这些内容被称为 IP 数据报文&#xff08;IP Datagram&#xff09;或者 IP 数据报。 IP 数据报文由首部&#xff08;称…

初识微服务:重塑软件开发的未来

引言 随着信息技术的飞速发展&#xff0c;软件系统的复杂性和规模不断攀升&#xff0c;传统的单体应用架构已经难以满足现代业务的灵活性和可扩展性需求。在这样的背景下&#xff0c;微服务架构应运而生&#xff0c;成为当前软件开发领域的一大热门话题。本文将深入探讨微服务架…

Linux:如何删除指定时间之前修改的文件

1、与文件有关的时间 在说明如何删除符合这种要求的文件之前&#xff0c;先来看看与文件有关的有哪些时间 简名全名中文名含义atimeaccess time访问时间文件中的数据最后被访问的时间mtimemodify time修改时间文件中的数据最后被修改的时间ctime change time变化时间文件的元…

7D性能项目日记4:做性能可不可以是一种信仰?

这个标题一写出来&#xff0c;应该就会有人说这是走火入魔了&#xff0c;一个职业有啥可成为信仰的&#xff1f;难道不要工资就为了干这个行业吗&#xff1f;当然不是&#xff0c;听我徐徐道来。 前几天在上海跟几个同行吃饭。其间谈到&#xff0c;有些人不愿意做性能&#xf…

腾讯EdgeOne产品测评体验—Web服务全能一体化服务,主打一步到位

前言 现在网络Web攻击真的防不胜防啊&#xff0c;相信有很多独狼开发者自己建站&#xff0c;租个云服务器&#xff0c;一部署自己的服务&#xff0c;每隔一段时间内测和网站总有一个要崩。自己感觉难受不说&#xff0c;网站稍微有点要出头的时候&#xff0c;数不清的访问攻击就…

STM32学习和实践笔记(13):数码管显示实验

共阳就是共正极&#xff0c;也就是正极全部接在一起。 共阴就是共负极&#xff0c;也就是负极全部接在一起。 我目前使用这款PZ6806L&#xff0c;使用了一个共阳数码管。 共阴与共阳在码表上其实就是正好取反就可以了&#xff0c;所以可以共用一个码表。 数码管显示程序主要分…

零基础也可以学习的医疗设备维修技能

零基础也可以学习的维修技能 解锁工程师的隐藏潜能&#xff01; 您是否曾因维修问题而感到束手无策&#xff1f; 彩虹医疗影像培训课程不仅提供技能&#xff0c; 更能为您提供自信。不再需要依赖他人&#xff0c; 您将成为故障排查的行家。迎接更具挑战性的机会&#xff0…

LeetCode_1304.和为零的 N 个不同整数

题目&#xff1a; 题解&#xff1a; 题目说让我们返回一个由n个各不相同的整数组成的数组&#xff0c;相加为0。 这里的比较好的办法就是类似于 1 2 3 0 -3 -2 -1这样对称的数组。既满足要求&#xff0c;又好实现。 先calloc出一个容量为n的整型数组&#xff0c;定义两个变量…

【VIC水文模型】模型原理简介

VIC水文模型原理 VIC水文模型概述土壤&#xff08;Soil&#xff09;积雪&#xff08;Snow&#xff09;动态湖和湿地模型动态湖&#xff08;Lake Model&#xff09;湿地模型&#xff08;Wetland Model&#xff09; 1 VIC模型陆面水文过程&#xff08;产流过程&#xff09;1.1 能…

PHP-001、PHP学习之PhpStorm+PhpStudy环境安装

一、说明 由于当前需要&#xff0c;暂时停止学习python&#xff0c;当然有时间继续&#xff0c;转为php&#xff0c;听说php开发网站、小程序等运行效率更高&#xff0c;朋友那边再做这个&#xff0c;准备学习一下&#xff0c;和朋友们一起来吧&#xff0c;就这开发环境安装&a…

【团体程序设计天梯赛 往年关键真题 25分题合集 详细分析完整AC代码】(L2-025 - L2-048)搞懂了赛场上拿下这些分就稳了

L2-025 分而治之 并查集 样例 输入样例&#xff1a; 10 11 8 7 6 8 4 5 8 4 8 1 1 2 1 4 9 8 9 1 1 10 2 4 5 4 10 3 8 4 6 6 1 7 5 4 9 3 1 8 4 2 2 8 7 9 8 7 6 5 4 2输出样例&#xff1a; NO YES YES NO NO分析&#xff1a; 先将所有边记录下来&#xff0c;再每次询问时&…

【MySQL】 mysql 日常工单处理脚本 解放你的双手!!!

简介 在工作中经常帮助开发的小伙伴执行些 sql&#xff0c;手动执行效率低不直观&#xff0c;还要单独备份等等&#xff0c;极为麻烦&#xff0c;怎么办&#xff1f;用它&#xff01;解放时间多摸鱼&#xff01;&#xff01;&#xff01;我的摸鱼小帮手。 流程图&#xff1a;…

C语言结构体的使用

C语言结构体的使用 1、先声明在定义 #include<stdio.h> #include<string.h> struct student{ char name[20]; int age; double score; };int main(){ struct student st; struct student *stt&st;strcpy(st.name,"zhangsan"); //通过地址赋值 (&am…

Matroska解封装原理与实践

本期作者 背景 Matroska是一种开放标准、功能强大的多媒体封装格式&#xff0c;可容纳多种不同类型的视频、音频及字幕流&#xff0c;其常见的文件扩展名为.mkv、.mka等。与应用广泛的MP4相比&#xff0c;Matroska更加灵活开放&#xff0c;可以同时容纳多个字幕&#xff0c;甚至…

云计算,如何从IT战略上升为企业核心战略?

ITValue 本文摘自《云栖战略参考》&#xff0c;这本刊物由阿里云与钛媒体联合策划。目的是为了把各个行业先行者的技术探索、业务实践呈现出来&#xff0c;与思考同样问题的“数字先行者”共同探讨、碰撞&#xff0c;希望这些内容能让你有所启发。 首发&#xff5c;钛媒体APP I…

YOLO-World——S(cvpr2024)

文章目录 Abstract成果 MethodPre-training Formulation: Region-Text PairsModel ArchitectureYOLO DetectorText EncoderText Contrastive HeadTraining with Online VocabularyInference with Offline Vocabulary Re-parameterizable Vision-Language PANText-guided CSPLay…

面试算法-174-二叉树的层序遍历

题目 给你二叉树的根节点 root &#xff0c;返回其节点值的 层序遍历 。 &#xff08;即逐层地&#xff0c;从左到右访问所有节点&#xff09;。 示例 1&#xff1a; 输入&#xff1a;root [3,9,20,null,null,15,7] 输出&#xff1a;[[3],[9,20],[15,7]] 解 class Solut…

消息队列中间件,RabbitMQ的使用,死信队列,延迟队列,利用枚举实现队列,交换机,RountKey的声明

目录 0.交换机种类和区别 1.声明队列和交换机以及RountKey 2.初始化循环绑定 3.声明交换机 4.监听队列 4.1 监听普通队列 4.2监听死信队列 5.削峰填谷的实现 0.交换机种类和区别 Direct Exchange&#xff08;直连交换机&#xff09;&#xff1a; 直连交换机将消息发送到…

武汉星起航:亚马逊跨境引领全球贸易新趋势,展现积极影响力

随着全球化浪潮的持续推进&#xff0c;跨境电商行业正迎来前所未有的发展机遇。亚马逊作为全球领先的电商平台&#xff0c;其在跨境电商领域的发展趋势备受瞩目。亚马逊跨境电商不仅扩大了跨境市场的规模&#xff0c;优化了供应链管理&#xff0c;还积极应用科技创新&#xff0…
最新文章