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

这篇具有很好参考价值的文章主要介绍了Mysql 数据库开发及企业级应用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

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

1.1、为什么要使用数据库

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

​ 经过一段时间的刻苦学习, Jack 终于把 C++ 和数据结构还有算法学得有点模样了, 不自觉就进入初级装逼模式,在同学面前那是指手画脚, 趾高气昂。 。 。 。
Mysql 数据库开发及企业级应用,MySQL,C++,mysql,数据库开发,数据库

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

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

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

Mysql 数据库开发及企业级应用,MySQL,C++,mysql,数据库开发,数据库

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

1.1.1、数据库概念(Database)

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

1.1.2、为什么需要数据库

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

id,name,passwd

1,小明,123456

2,小红,654321

3,小军,888888

4,小丽,666666

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

id,prop,price,num

1,金戒指,12,1 8979438401111

1,银戒指,10,1

2,房卡,10,10

3,鲜花,2,6

1,房卡,10,100

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

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

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

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

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

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

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

Mysql 数据库开发及企业级应用,MySQL,C++,mysql,数据库开发,数据库

1.3、数据库的选择

1.3.1、主流数据库简介

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

Mysql 数据库开发及企业级应用,MySQL,C++,mysql,数据库开发,数据库

主要的数据库产品有如下几种:
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

Mysql 数据库开发及企业级应用,MySQL,C++,mysql,数据库开发,数据库
Mysql 数据库开发及企业级应用,MySQL,C++,mysql,数据库开发,数据库

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

Mysql 数据库开发及企业级应用,MySQL,C++,mysql,数据库开发,数据库

  • 命令行启动

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

Mysql 数据库开发及企业级应用,MySQL,C++,mysql,数据库开发,数据库

1.4.3、控制台登陆 MySQL 命令

mysql -h 127.0.0.1 -uroot -p123456

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

Mysql 数据库开发及企业级应用,MySQL,C++,mysql,数据库开发,数据库

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

1.5.1、Visual Studio 2019 配置

Mysql 数据库开发及企业级应用,MySQL,C++,mysql,数据库开发,数据库

  • 第一步:打开 mysql 的安装目录,我这里安装目录如下:D:\mysql,确认lib 目录和 include 目录是否存在。
    Mysql 数据库开发及企业级应用,MySQL,C++,mysql,数据库开发,数据库

  • 第二步:打开 VS2019,新建一个空工程,控制台应用程序即可,注意:解决方案平台选择 X64
    Mysql 数据库开发及企业级应用,MySQL,C++,mysql,数据库开发,数据库

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

Mysql 数据库开发及企业级应用,MySQL,C++,mysql,数据库开发,数据库

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

Mysql 数据库开发及企业级应用,MySQL,C++,mysql,数据库开发,数据库
Mysql 数据库开发及企业级应用,MySQL,C++,mysql,数据库开发,数据库

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

Mysql 数据库开发及企业级应用,MySQL,C++,mysql,数据库开发,数据库

  • 第六步:在属性页的链接器中,点击“输入”,将 mysql 安装文件夹中lib目录下的libmysql.lib 文件加到“附加依赖项”中,注意,这里直接把 libmysql.lib 这个依赖名加进去即可,不要加路径。
    Mysql 数据库开发及企业级应用,MySQL,C++,mysql,数据库开发,数据库

  • 第七步:把 mysql 安装目录里的 lib\libmysql.dll 复制到 c:\windows\system32 下 。
    Mysql 数据库开发及企业级应用,MySQL,C++,mysql,数据库开发,数据库

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

Mysql 数据库开发及企业级应用,MySQL,C++,mysql,数据库开发,数据库

2、修改数据库密码

Mysql 数据库开发及企业级应用,MySQL,C++,mysql,数据库开发,数据库
Mysql 数据库开发及企业级应用,MySQL,C++,mysql,数据库开发,数据库文章来源地址https://www.toymoban.com/news/detail-598683.html

到了这里,关于Mysql 数据库开发及企业级应用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【ArcGIS Pro微课1000例】0054:Pro3.0创建数据库(文件数据库、移动数据库、企业级数据库)解读

    ArcGIS Pro中主要有三种数据库类型,它们分别是: 文件地理数据库 、 移动地理数据库 和 企业级地理数据库 。它们的区别如下: 存储方式 :文件地理数据库是多个文件存储在具有.gdb扩展名的文件夹中,每个数据集都包含在单个文件中;移动地理数据库存储在完全包含在单个

    2024年02月04日
    浏览(51)
  • 企业级JAVA、数据库等编程规范之命名风格 —— 超详细准确无误

     🧸欢迎来到dream_ready的博客,📜相信你对这两篇博客也感兴趣o (ˉ▽ˉ;) 📜 表白墙/留言墙 —— 初级SpringBoot项目,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学 📜 用户登录前后端开发(一个简单完整的小项目)——SpringBoot与session验证(带前后端源码)全方

    2024年02月06日
    浏览(56)
  • MongoDB 2023年度纽约 MongoDB 年度大会话题 -- 企业级从传统数据库到NOSQL,你会更好...

    开头还是介绍一下群,如果感兴趣PolarDB ,MongoDB ,MySQL ,PostgreSQL ,Redis, Oceanbase, 等有问题,有需求都可以加群群内有各大数据库行业大咖,CTO,可以解决你的问题。加群请联系 liuaustin3 ,在新加的朋友会分到2群(共1300人左右 1 + 2 + 3 + 4) 3群即将突破 400 (目前387)会关闭自由申请

    2024年02月07日
    浏览(46)
  • 海山数据库(He3DB)Redis技术实践:继承开源Redis精髓,强化升级企业级服务

    数字化转型中的企业数据的处理速度和效率直接关系到企业的竞争力,Redis作为业界广泛使用的开源键值对存储系统,以其卓越的性能和丰富的数据结构,成为了众多开发者和企业的首选。然而,近期Redis开源社区对Redis协议进行了变更,从 Redis 7.4 版本开始,Redis 将从 BSD 3-

    2024年04月28日
    浏览(39)
  • php - 超详细 thinkphp + redis 实现商品秒杀抢购功能,提供完整流程详细讲解及企业级功能示例源代码,环境准备、数据库表设计、并发压力测试等(新手小白一看就懂!)

    很多文章都已经过时了,而且还不讲原理,本文一次性说清楚。 很多电商系统几乎都有秒杀功能,那么用 tp+redis 怎么实现呢? 本文详细讲解商品秒杀功能的实现,提供详细的代码及注释,包括环境准备、环境搭建教程(已搭建的跳过即可)、数据库表设计、压力测试、示例

    2023年04月08日
    浏览(50)
  • 大数据开发之Hive(企业级调优)

    创建测试用例 1、建大表、小表和JOIN后表的语句 2、分别向大表和小表中导入数据 1、基本语法 2、实例操作 1)查看下面这条语句的执行计划 (1)没有生成MR任务的 (2)有生成MR任务的 2)查看详细执行计划 10.2.1 列裁剪和分区裁剪 在生产环境中,会面临列很多或者数据量很

    2024年01月18日
    浏览(42)
  • Git---企业级开发模型

    我们知道,一个软件从零开始到最终交付,大概包括一下几个阶段 : 规划、编码、构建、测试、发布、部署和维护. 最初程序比较简单,工作量也不大.程序猿一个人可以完成所有阶段的工作.但随着软件产业的日益发展壮大,软件的规模也在逐渐变得庞大.软件的复杂度不断攀升,一个

    2024年02月13日
    浏览(53)
  • Git企业开发控制理论和实操-从入门到深入(七)|企业级开发模型

    那么这里博主先安利一些干货满满的专栏了! 首先是博主的高质量博客的汇总,这个专栏里面的博客,都是博主最最用心写的一部分,干货满满,希望对大家有帮助。 高质量博客汇总 然后就是博主最近最花时间的一个专栏《Git企业开发控制理论和实操》希望大家多多关注!

    2024年02月10日
    浏览(48)
  • 企业级开发中协同开发与持续集成持续部署

    每个项目有唯一的代码仓库,所以不是每个开发者都需要创建一个代码仓库,一般都是项目负责人创建: 代码仓库有以下几种: github gitee gitlib 代码仓库的使用方法都差不多。 以gitee为例创建一个仓库: 如果没有账户的话,要注册一个新的用户名,注册用户之后,使用注册

    2024年02月14日
    浏览(57)
  • 【Git原理与使用】-- 企业级开发模型

    目录 引入 系统开发环境 Git 分支设计规范 master 分支 release 分支 develop 分支 feature 分支 hotfix 分支 开发场景 - 基于git flow模型的实践 DevOps研发平台 修复测试环境 Bug 修改预发布环境 Bug 修改正式环境 Bug 紧急修复正式环境 Bug 拓展实践 都说: 对于开发者,Git是非常的重要的,

    2024年02月13日
    浏览(92)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包