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.mzph.cn/news/6668.shtml

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

相关文章

【VUE】解决图片视频加载缓慢/首屏加载白屏的问题

1 问题描述 在 Vue3 项目中,有时候会出现图片视频加载缓慢、首屏加载白屏的问题 2 原因分析 通常是由以下原因导致的: 图片或视频格式不当:如果图片或视频格式选择不当,比如选择了无损压缩格式,可能会导致文件大小过大…

unity 控制text根据字数自动扩展大小,并扩展UI背景

需求:文字内容位置保持不变,向下增加,背景框随之同步扩展。 1.UGUI 九宫格 拉伸 对背景框图片资源处理,避免图片拉伸。 (10条消息) unity UGUI 九宫格 拉伸_unity九宫格拉伸_野区捕龙为宠的博客-CSDN博客 2.背景框添加组件 3.…

php裁剪图片,并给图片加上水印

本次以裁剪四个图片为例,图片如下 代码如下 public function cutImg($imgUrl){try{// 读取原始图片$src_img imagecreatefromjpeg($imgUrl);// 获取原始图片的宽度和高度$src_width imagesx($src_img);$src_height imagesy($src_img);// 计算每个部分的宽度和高…

【数字信号处理】带通采样定理及其MATLAB仿真

目录 一、带通采样定理1.1 内容1.2 公式推导 二、MATLAB信号仿真2.1 信号仿真实验2.2 MATLAB代码 三、总结参考 一、带通采样定理 按照奈奎斯特采样定理(低通采样),采样频率 f s f_{s} fs​ 要大于等于信号中最高频率 f m a x f_{max} fmax​ 的2倍,才…

C++OpenCV(2):图像处理基础概念与操作

🔆 文章首发于我的个人博客:欢迎大佬们来逛逛 🔆 OpenCV项目地址及源代码:点击这里 文章目录 图形读取与显示加载图片显示图片打印图片信息保存图片 色彩模型转换RGB颜色模型HSV颜色模型HLS模型LAB模型 图像像素读写操作像素算数运…

macOS 源码编译 qpress

╰─➤ git clone https://github.com/PierreLvx/qpress.git ╰─➤ cd qpress ╰─➤ make g -O3 -o qpress -x c quicklz.c -x c qpress.cpp aio.cpp utilities.cpp -lpthread -Wall -Wextra -Werror ╰─➤ sudo make install …

怎么快速定位bug?怎么编写测试用例?

目录 01定位问题的重要性 02问题定位技巧 03初次怎么写用例 作为一名测试人员如果连常见的系统问题都不知道如何分析,频繁将前端人员问题指派给后端人员,后端人员问题指派给前端人员,那么在团队里你在开发中的地位显而易见 ,口碑…

垃圾回收标记阶段算法

1.标记阶段的目的 主要是在GC在前,判断出哪些是有用的对象,哪些是需要回收的对象,只有被标记为垃圾对象,GC才会对其进行垃圾回收。判断对象是否为垃圾对象的两种方式:引用计数算法和可达性分析算法。 2.引用计数算法…

如何搭建使用dubbo-Admin?

dubbo-Admin介绍 一款用于dubbo可视化界面操作的管理平台 dubbo-Admin特点 dubbo-Admin是dubbo的管理界面平台,且是一个前后端分离的项目,前端使用vue,后端使用springboot。 软件下载 dubbo-admin-0.5.0.zip 软件使用

会议OA项目之会议审批(亮点功能:将审批人签名转换为电子手写签名图片)

🥳🥳Welcome Huihuis Code World ! !🥳🥳 接下来看看由辉辉所写的关于OA项目的相关操作吧 目录 🥳🥳Welcome Huihuis Code World ! !🥳🥳 一.主要功能点介绍 二.效果展示 三.前端…

MongoDB 的日常使用

一、简介 1、 常见的数据库分类 RDBMS(关系型数据库):常见的关系型数据库有 Oracle、DB2、Microsoft SQL Server、Microsoft Access、MySQL; NoSQL(非关系型数据库):常见的非关系型数据库有 …

thinkphp实现无限分类(使用递归)

thinkphp实现无限分类(使用递归) 本文实例为大家分享了thinkphp实现无限分类的详细代码,希望对大家学习无限分类有所启发。 数据库:test 数据表:(tp_category): Common/conf/conf…

在VSCode中实现Rust编程调试指南

在 VS Code 中调试 Rust:终极指南 在本教程中,您将学习如何使用 VS Code 调试 Rust。可用于使用 VS Code 调试 Rust 的操作。设置 VS Code 来调试 Rust Rust因其易用性、安全性和高性能而继续保持其作为最受欢迎的编程语言的地位。随着 Rust 的流行&…

elementui el-table折叠表格,点击主表数据展开从表明细

用element-ui 的el-table实现&#xff1a;主表table可实现展开行显示关联的明细表table的列表数据&#xff0c;效果图如下 <el-tableref"tableData"v-loading"listLoading":data"tableData"row-key"id"borderstripehighlight-curr…

自动驾驶感知系统-激光雷达

感知系统 现有的车载传感器主要包括超声波雷达、激光雷达、毫米波雷达、车载摄像头、红外探头等。主流的自动驾驶感知平台以雷达和车载摄像头为主&#xff0c;呈现多传感器融合发展趋势。基于测量能力和环境适应性&#xff0c;预计雷达和车载摄像头会保持其感知平台霸主地位&a…

在react中配置less

第一步&#xff1a;暴露出webpack配置文件 终端命令&#xff1a;npm run eject (此命令一旦运行不可逆) 第二步&#xff1a;安装less以及less-loader npm install less less-loader --save-dev 第三步&#xff1a;修改webpack的配置文件 运行完以上命令后&#xff0c;项目…

精通自动化,Pytest自动化测试框架-fixture用例的前后置(实现)

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 测试用例实现前后…

crmeb部署

安装宝塔 教程 安装所需要的软件 php mysql5.7 redis fileinfo nginx 安装crmeb 重启mysql 前台http://192.168.216.128/ 后台http://192.168.216.128/admin admin admin888登录 访问前台

自动化运维工具--saltstack部署及使用

目录 一、saltstack简介 1、介绍 2、Salt的核心功能 3、saltstack通信机制 二、saltstack部署 1、部署环境 2、配置yum源 3、安装master与minion 4、连接认证master和minion 三、salt运行 1、执行格式 2、实操演示 一、saltstack简介 1、介绍 saltstack是一个配置管…

连锁反应开始了!Linux 发行版迎新变化!

任何企业都有合法权利捍卫其模型和产品。撇开大量不真正了解开源许可证如何工作的人不谈&#xff0c;我们的印象是&#xff0c;有很多人觉得仅仅因为这是Linux&#xff0c;他们就有某种权利免费获得它。但事实上&#xff0c;他们没有。这不是自由软件中的“自由”的意思&#x…