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,一经查实,立即删除!

相关文章

Redis 执行Lua脚本

Redis 执行lua 脚本 redis incr 命令当Key不存在时会默认设置key 并自增为1,如果需要在key不存在时重新初始化key 可以在应用程序中判断,也可以直接使用lua脚本 Redis 执行lua脚本命令 Script load 将脚本 script 添加到Redis服务器的脚本缓存中,并不…

介绍Tensorflow的基本概念和场景

TensorFlow是一种开源的机器学习框架,由Google开发,用于构建和训练人工神经网络。它使用图形表示来表示数学计算,其中节点表示操作,边表示数据流。以下是TensorFlow的基本概念: Tensor:TensorFlow的计算单位…

神经网络随记-参数矩阵、剪枝、模型压缩、大小匹配、、

神经网络的参数矩阵 在神经网络中,参数矩阵是模型学习的关键部分,它包含了神经网络的权重和偏置项。下面是神经网络中常见的参数矩阵: 权重矩阵(Weight Matrix):权重矩阵用于线性变换操作,将输…

k8s+containerd安装

准备环境 准备两台服务器节点,如果需要安装虚拟机,可以参考《wmware和centos安装过程》 机器名IP角色CPU内存centos01192.168.109.130master4核2Gcentos02192.168.109.131node4核2G 设置主机名,所有节点都执行 vim /etc/hosts #增加 192.…

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

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

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

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

【C#】set和get访问器的使用例子

假设我们有一个名为Person的类,该类具有一个私有字段_age表示人的年龄。我们可以使用get和set访问器来访问和修改该字段。 csharp public class Person { private int _age; public int Age { get > _age; // get访问器用于获取_age的值 set > _age value; /…

mysql 自增长键值增量设置

参考文章 MySQL中auto_increment的初值和增量值设置_auto_increment怎么设置_linda公馆的博客-CSDN博客 其中关键语句 show VARIABLES like %auto_increment% set auto_increment_increment4; set auto_increment_offset2;

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.引用计数算法…

[QT编程系列-33]:科学计算 - 开源数值计算库GNU Scientific Library(简称GSL)

目录 第1章 简介 1.1 概述 1.2 主要功能 1.3 C接口 1.4 在QT中使用GSL的步骤 第2章 GSL C函数库 2.1 功能概述 2.2 代码示例 第1章 简介 1.1 概述 GNU Scientific Library(简称GSL)是一个开源数值计算库,旨在提供各种数学和科学计算…

如何搭建使用dubbo-Admin?

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

base-R(又称为基础R)中的apply函数族

说明:此为学习baseR中apply函数族笔记,仅学习使用。 C编程语言使用循环,但是R软件提倡使用向量化操作和apply系列函数来批量处理数据,从而大大简化了计算,提高代码的速度、可读性和可维护性。其实,大部分ap…

【力扣】74. 搜索二维矩阵 <二分法>

【力扣】74. 搜索二维矩阵 给你一个满足下述两条属性的 m x n 整数矩阵: 每行中的整数从左到右按非递减顺序排列。每行的第一个整数大于前一行的最后一个整数。 给你一个整数 target ,如果 target 在矩阵中,返回 true ;否则&am…

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

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

SQL 三表联查

三表联查 创建三张表来三表联查一下吧inner join 内连接full join 全连接left join 左连接因需要在三个表中查东西,还不能要交集,要并集。 创建三张表 我用的是DBaver来创建,下面就是代码,跑完之后会出现三个表。 create table tas_master.hk_test_1(id INT not null,na…