Mysql 数据库开发及企业级应用

文章目录

  • 1、Mysql 数据库开发及企业级应用
      • 1.1、为什么要使用数据库
        • 1.1.1、数据库概念(Database)
        • 1.1.2、为什么需要数据库
      • 1.2、程序员为什么要学习数据库
      • 1.3、数据库的选择
        • 1.3.1、主流数据库简介
        • 1.3.2、使用 MySQL 的优势
        • 1.3.3、版本选择
      • 1.4、Windows 平台下安装与配置 MySQL
        • 1.4.1、安装配置MySQL
        • 1.4.2、启动 MySQL 服务
        • 1.4.3、控制台登陆 MySQL 命令
      • 1.5、C/C++访问 MySQL 数据库
        • 1.5.1、Visual Studio 2019 配置
  • 2、修改数据库密码

1、Mysql 数据库开发及企业级应用

1.1、为什么要使用数据库

​ 程序员 Jack 还是在在校学习期间, 就听高年级的大哥忠告, “ 小伙子, 搞编程, 想要成为最牛逼的程序员, 一定要学好 C/C++语言和数据结构及算法” , Jack 谨记了这句忠告, 因为这位高年级的哥们还没毕业就已经被 BAT 公司预定, 在学校那是风光无限, 得到了很多高年级美女学姐的青睐。

​ 经过一段时间的刻苦学习, Jack 终于把 C++ 和数据结构还有算法学得有点模样了, 不自觉就进入初级装逼模式,在同学面前那是指手画脚, 趾高气昂。 。 。 。
在这里插入图片描述

​ 这种状态一直持续到实习期间, Jack 进入一家小有名气的游戏开发公司实习, 被安排到一个棋牌游戏的项目组。 项目组的项目经理颇为认同新来的 Jack 同学( 因为面试时问到的 C++和数据结构相关的试题, 只有 Jack 力压群雄, 达到了项目经理的要求, 甚至有几年工作经验的程序员都搞不定的 A*算法, Jack 也是对答如流! ) , 并没有给他安排一些意义不大的杂活给他干, 而是编制为开发团队的正式一员, 享受正式员工的待遇! 此时的 Jack 意气风发, 代码撸的更加卖力了, 因此也很快融入了开发团队中。 。 。

​ 有一天, 项目组的小组长给 Jack 分配了一个新的任务, 让 Jack 实现用户登陆模块, 具体需求
如下:

  1. 游戏玩家访问游戏客户端, 通过客户端界面输入用户名和密码。
  2. 在游戏玩家点击”确认”后, 客户端连接至数据库服务器对用户名和密码进行确认,如果验证成功, 则 玩家可以进入大厅, 如果失败, 则不允许进入!
  3. 。 。 。
    啊! 数据库! 什么东东?

在这里插入图片描述

因为项目需要, Jack 马上紧张起来, 翻阅各种资料, 耗费了几个废寝忘食的日日夜夜, 才从以下几个方面搞清楚了 why do we need database?

1.1.1、数据库概念(Database)

就是按照数据结构来组织、 存储和管理数据, 建立在计算机存储设备上的仓库。 我们可以把数据库看成电子化的文件柜, 也就是存储电子文件的处所, 用户可以对文件中的数据进行新增、 查询、 更新、 删除等操作。

1.1.2、为什么需要数据库

一般情况下, 要保存用户的数据, 一个最简单的方法是把用户数据写入文件。 例如, 要保存用户的密码信息, 可以写入下面的文件中 txt 文件:

id,name,passwd1,小明,1234562,小红,6543213,小军,8888884,小丽,666666

保存用户购买的道具 prop.txt :

id,prop,price,num1,金戒指,12,1 89794384011111,银戒指,10,12,房卡,10,103,鲜花,2,61,房卡,10,100

但是, 随着应用程序的功能越来越复杂, 数据量越来越大, 如何管理这些数据就成了大问题:

  • 读写文件并解析出数据需要大量重复代码;
  • 从成千上万的数据中快速查询出指定数据需要复杂的逻辑。
  • 数据缺乏安全感 。

​ 如果每个应用程序都各自写自己的读写数据的代码, 一方面效率低, 容易出错, 另一方面, 每个应用程序访问数据的接口都不相同, 数据难以复用。

​ 所以, 数据库作为一种专门管理数据的软件就出现了。 应用程序不需要自己管理数据, 而是通过数据库软件提供的接口来读写数据。 至于数据本身如何存储到文件, 那是数据库软件的事情, 应用程序自己并不关心:

这样一来, 编写应用程序的时候, 数据读写的功能就被大大地简化了。

1.2、程序员为什么要学习数据库

  • 几乎任何一个企业级应用, 都要用到数据库。
  • 无论开发、 测试、 运维还是架构师, 数据库都是加分神器!
  • 小的软件企业分工不明确, 全能型人才能得到更多的机会(就业和提升)。
  • 外包和自由程序员必备 。

在这里插入图片描述

1.3、数据库的选择

1.3.1、主流数据库简介

当今市面上的数据库产品众多, 每种数据库都有自己的优势和缺点, 或出于数据库的性能和易用性考虑, 或出于商用和开源考虑, 如何选择自己合适的数据库产品, 成为重中之重!

在这里插入图片描述

主要的数据库产品有如下几种:
Oracle - 作为一种商业性关系型数据库,在事务处理方面有自己独到的优势,功能比较强大,市场占有率也比较高。oracle 数据库是一种大型的关系型数据库,在使用上会收费。在部署上,可以根据自己的环境采用单节点或者集群部署。经常会使用于银行和金融机构,存储大量数据,可以对海量数据进行分析处理,在安全性上使用访问控制和多种数据备份机制,可靠性高。

Mysql - 作为一种开源的轻量级关系型数据库,在开源数据库中比较流行,由于小巧安装方便快捷,经常会用于互联网公司,维护也比较方便。因为开源,使用上比较灵活,mysql 还有许多第三方的存储引擎,可以根据自己的需要进行安装。在功能上mysql 可能没有 oracle 强大,但是对于资源的占用非常少,数据恢复快。在维护上,追求稳定的性能和易用性。

Redis - 作为一种缓存数据库,对于数据的读写特别快,redis 之所以快,是因为它数据放在内存中,但是内存比较贵,另一方面,内存也是有限制的,当内存不够时,就需要使用 redis 的分布式方案redis 作为一种非关系型数据库,可以适用于高并发场景,配合关系型数据库作为做高速缓存,也可以降低磁盘 IO,使用键值对存储,不适用于结构复杂的 sql 数据

另外 MongoDB, SQL Server 等数据库也是常用的数据库。

选择数据库时, 既要考虑成本, 还有考虑维护的稳定和便利性,结合自己的设备规模。 最重要的, 需要结合我们的业务, 如果高安全性, 海量数据, 能承担高昂的成本, 可以选择 oracle一般应用的快速查询, 高并发访问, 一般情况下都可以选择 mysql, 另外特殊情况特殊处理!

1.3.2、使用 MySQL 的优势

​ 如今很多主流网站都选择 MySQL 数据库来存储数据, 比如阿里巴巴的淘宝。 那么, MySQL 到底有什么优势, 吸引了这么多用户? 主要是基于以下几点原因:

  • 开源
    • 开源软件是互联网行业未来发展的趋势。 MySQL 是开放源代码的数据库, 这就使得任何人都可以获取 MySQL 的源代码, 并修正 MySQL 的缺陷, 并且任何人都能以任何目的来使用该数据库,这是一款自由使用的软件。 对于很多互联网公司来说, 选择使用 MySQL 是一个化被动为主动的过程, 无须再因为依赖封闭的数据库产品而受牵制。
  • 成本因素
    • MySQL 社区版是完全免费的, 企业版基于服务和支持收费。 相比之下, OracleDB2SQL
      Server 价格不菲, 再考虑到搭载的服务器和存储设备, 那么成本差距是巨大的。
  • 跨平台性
    • MySQL 不仅提供 Windows 系列的版本, 还提供 UNIXLinuxMac OS 等操作系统对应的版本。 因为很多网站都选择 UNIXLinux 作为网站的服务器, 所以 MySQL 具有跨平台的优势。
  • 容易使用
    • MySQL 是一个真正的多用户、 多线程 SQL 数据库服务器, 能够快速、 高效、 安全地处理大量的数据。 MySQLOracle 性能并没有太大的区别, 在低硬件环境下, MySQL 分布式的方案同样可以解决问题, 而且成本比较经济, 从产品质量、 成熟度、 性价比来讲, MySQL 都是非常不错的。另外,MySQL 的管理和维护非常简单, 初学者很容易上手, 学习成本较低。

1.3.3、版本选择

MySQL5.7 版本直接跳跃发布了 8.0 版本, 可见这是一个令人兴奋的里程碑版本。 MySQL 8.0版本在功能上做了显著的改进与增强, 不仅在速度上得到了改善, 还提供了一系列巨大的变化, 为用户带了更好的性能和更棒的体验。

三个字形容, 就是比以前的更棒 棒 棒!

1.4、Windows 平台下安装与配置 MySQL

1.4.1、安装配置MySQL

免费下载网址: https://dev.mysql.com/downloads/windows/installer/8.0.html
版本选择 : 社区版 8.0.12

在这里插入图片描述
在这里插入图片描述

1.4.2、启动 MySQL 服务

  • 图形化界面启动:
    • 右击“计算机” , 在快捷菜单中选择“管理” 命令, 如图所示, 打开“计算机管理” 对话
      框。 也可以执行“开始” |“控制面板” |“管理工具” |“服务” 来启动服务。

在这里插入图片描述

  • 命令行启动

    • 查看服务命令: net start
    • 关闭服务命令: net stop MySQL
    • 启动服务器命令: net start MySQL

在这里插入图片描述

1.4.3、控制台登陆 MySQL 命令

mysql -h 127.0.0.1 -uroot -p123456

(注:-h 以及后面的127.0.0.1是主机名字 ,-p后面的为 root 的密码,根据个人设置不同而不同) 。

在这里插入图片描述

1.5、C/C++访问 MySQL 数据库

1.5.1、Visual Studio 2019 配置

在这里插入图片描述

  • 第一步:打开 mysql 的安装目录,我这里安装目录如下:D:\mysql,确认lib 目录和 include 目录是否存在。
    在这里插入图片描述

  • 第二步:打开 VS2019,新建一个空工程,控制台应用程序即可,注意:解决方案平台选择 X64
    在这里插入图片描述

  • 第三步:右击工程名,打开属性页。

在这里插入图片描述

  • 第四步:打开 C/C++目录,将 mysql 安装文件中include文件的路径添加到这里。

在这里插入图片描述
在这里插入图片描述

  • 第五步:打开 链接器目录,在库目录中将 mysql 文件中的 lib 文件路径添加进来。

在这里插入图片描述

  • 第六步:在属性页的链接器中,点击“输入”,将 mysql 安装文件夹中lib目录下的libmysql.lib 文件加到“附加依赖项”中,注意,这里直接把 libmysql.lib 这个依赖名加进去即可,不要加路径。
    在这里插入图片描述

  • 第七步:把 mysql 安装目录里的 lib\libmysql.dll 复制到 c:\windows\system32 下 。
    在这里插入图片描述

  • 第八步:编译如下代码,启动 mysql, 将代码中连接数据库的用户名和密码改成自己的设定,顺利获取到
    student 表中的结果即表示连接成功!

在这里插入图片描述

2、修改数据库密码

在这里插入图片描述
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

万字长文 | Hadoop 上云: 存算分离架构设计与迁移实践

一面数据原有的技术架构是在线下机房中使用 CDH 构建的大数据集群。自公司成立以来,每年都保持着高速增长,业务的增长带来了数据量的剧增。 在过去几年中,我们按照每 1 到 2 年的规划扩容硬件,但往往在半年之后就不得不再次扩容。…

构建新型电力系统,需要什么样的数字能源底座?

在迈向“碳中和”的进程中,全球能源产业变革已经进入了关键时期,其中电力系统的价值从未像今天这样重要。 国际能源署数据显示,2022年全球与能源相关的二氧化碳排放量超过368亿吨,创下历史新高。其中,电力领域碳排放占…

内网环境使用docker部署微服务系统记录

背景 内网环境部署一套微服务应用系统,采用docker方式部署。包括mysql、redis、nginx、nacos、gateway以及应用程序的jar包。下面记录部署的过程和遇到的问题。 一、内网dockcer部署mysql服务 内网生成mysql镜像 在一个可以连接外网的环境中,下载mys…

基于51单片机的红外测温系统的设计与实现

功能框图 功能描述 本设计以STC89C52单片机为核心控制器,加上其他的模块一起组成非接触人体红外测温的整个系统,其中包含中控部分、输入部分和输出部分。中控部分采用了STC89C52单片机,其主要作用是获取输入部分数据,经过内部处理…

PostgreSQL的进程架构和内存架构

文章首发地址 PostgreSQL的进程架构 PostgreSQL的进程架构是由多个进程组成的,每个进程都有不同的作用和职责。下面是PostgreSQL的进程架构的详细说明: 后台进程(Postmaster) 后台进程是PostgreSQL启动时创建的第一个进程,它负责管理和控…

搭建Home Assistant智能家居系统 - 随时随地控制你的家庭设备「内网穿透」

文章目录 前言1. 安装Home Assistant2. 配置Home Assistant3. 安装cpolar内网穿透3.1 windows系统3.2 Linux系统3.3 macOS系统 4. 映射Home Assistant端口5. 公网访问Home Assistant6. 固定公网地址6.1 保留一个固定二级子域名6.2 配置固定二级子域名 转载自cpolar极点云文章&a…

【Linux系统编程】Linux第一个小程序——进度条

文章目录 1. 对回车(\r)和换行(\n)的理解1.1 概念理解1.2 测试 2. 缓冲区的理解2.1 观察现象2.2 原因解释 3. 倒计时小程序4. 进度条小程序4.1 基本思路及实现4.2 改进及优化4.3 增加百分比显示4.4 增加旋转光标4.5 给进度条配色 …

kotlin中使用Room数据库(包含升降级崩溃处理)

目录 1.导入依赖库 2.数据实体类 3.数据访问对象 (DAO) 4.数据库类 5.调用DAO里面的“增、删、改、查”方法 6.数据库升降级处理 升级(保存数据库历史数据): 升级(不保存数据库历史数据): 降级&…

计网笔记--运输层(vital)

目录 1--运输层概述 2--端口号、复用与分用的概念 3--UDP和TCP的对比 4--TCP的流量控制 5--TCP的拥塞控制 6--TCP超时重传时间的选择 7--TCP可靠传输的实现 8--TCP的连接建立 9--TCP的连接释放 10--TCP报文段的首部格式 1--运输层概述 运输层的任务: 为运…

Yalmip工具箱使用教程(1)-入门学习

博客中所有内容均来源于自己学习过程中积累的经验以及对yalmip官方文档的翻译:YALMIP 1.Yalmip工具箱的下载与安装 1.1下载 Yalmip的作者是Johan Lfberg,是由Matlab平台编程实现的一个免费开源数学优化工具箱,在官网上就可以下载。官方下载…

cmake 提前结束处理命令: return

有时候,我们有这样的需求,当处理到某个地方的时候,后面的我们都不想处理或者不需要处理的时候,就可以提前结束当前的处理逻辑,回到父级去处理.在C/C中,我们有break关键字跳出当前循环,continue关键字进入下一次循环,return关键字返回当前处理的函数. cmake也提供了break(),con…

场景图生成——RelTR训练自己的数据集

RelTR训练自己的数据集 省流量省时间版本框的标注关系的标注总的 前言Open Images V6的标注格式RelTR中使用的Open Images V6的数据标注格式具体步骤框的标注生成格式关系三元组的生成格式 结束语参考链接 省流量省时间版本 框的标注 共需要创建4个json标注文件 train.json, …