VS2019连接MySQL

VS2019连接MySQL

  • 下载MySQL Connector/C++
  • 配置头文件,库文件路径
    • 配置头文件路径
    • 配置库的路径
    • 复制dll文件
  • MySQL的用户设置
    • 将权限赋值给新用户
  • 编写代码
  • 往数据库写入

老师布置的作业让我们用VS2019连接MySQL实现一个小型的日志系统,中间踩了很多的坑,写篇博客记录一下:

下载MySQL Connector/C++

首先看看自己的MySQL文件夹下,有没有这个文件,如果是默认路径,一般会放到:Program Files下:
在这里插入图片描述
点进去:

如果有这个,说明在装MySQL时已经将Connector/C++ 装好了,此时可以直接进入下一步,如果没有的话,可以访问官网下载:

https://dev.mysql.com/downloads/connector/cpp/
在这里插入图片描述

配置头文件,库文件路径

我们装的库是一个第三方库,所以VS不能自动识别,我们得自己配置一下。
新创建一个项目:
在这里插入图片描述此时第一步把x86换成x64,我们的这个Connector/C++是64位的库,如果不换,之后会有一堆奇怪的错误:
在这里插入图片描述
添加一个头文件和源文件:
在这里插入图片描述
在这里插入图片描述

配置头文件路径

此时,鼠标右击这里:
在这里插入图片描述选择属性:

在这里插入图片描述选择C/C++下面的常规(如果没有这个选项,先添加一个源文件就行了)
在这里插入图片描述编辑附加包含目录
在这里插入图片描述在这里插入图片描述

把Connector/C++ 下的include路径添加进去:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
还要包括jbdc的路径
在这里插入图片描述在这里插入图片描述

配置库的路径

换到下面的连接器的常规选项:
在这里插入图片描述
编辑附加库目录:将lib64下的vs14路径写进去:
在这里插入图片描述在这里插入图片描述
然后切到输入选项:
在这里插入图片描述编辑附加依赖项:将这两个库的名字粘贴进去,不带路径

在这里插入图片描述在这里插入图片描述不要网络点右下角的应用:
在这里插入图片描述

复制dll文件

最后,需要将lib64下的dll文件复制到C:\Windows\System32或者是复制到项目的目录中:

在这里插入图片描述在这里插入图片描述或者这里:
在这里插入图片描述
现在我们包几个头文件试试:

#pragma once
#include <mysql_driver.h>  
#include <mysql_connection.h>  
#include <cppconn/statement.h>  
#include <cppconn/resultset.h>  
#include <cppconn/prepared_statement.h>

在这里插入图片描述
如果没有报错,说明配置成功。

MySQL的用户设置

我们配置好了VS,现在我们来配置MySQL的用户,这里我创建一个新用户来演示,首先,我们得以以root用户身份登录到MySQL服务器。打开命令行界面

mysql -u root -p

在这里插入图片描述
以root的身份创建一个新用户:假设你要创建一个名为newuser的用户,并且该用户只能从localhost连接,你可以执行以下命令:

CREATE USER 'newuser'@'localhost' IDENTIFIED BY 'password';

请将newuser替换为你想要创建的用户名,将localhost替换为允许该用户连接的主机名或IP地址,将password替换为用户的密码。

在这里插入图片描述

将权限赋值给新用户

MySQL提供了多种权限级别,可以针对特定数据库、特定表甚至特定操作来分配权限。例如,如果你想给 ‘new_user’ 用户在名为 ‘my_database’ 的数据库中所有表的所有权限,可以使用以下命令:

GRANT ALL PRIVILEGES ON my_database.* TO 'new_user'@'localhost';

这里的 ALL PRIVILEGES 表示赋予所有权限,包括但不限于查询、插入、更新、删除、创建表等。ON my_database.* 指明了权限适用的数据库及其所有表。

假设我这里有一个my_log的数据库,那我应该这么写:
在这里插入图片描述在完成权限分配后,通常需要执行 FLUSH PRIVILEGES; 命令来刷新MySQL的权限缓存,使其立即生效:

FLUSH PRIVILEGES;

在这里插入图片描述
此时MySQL这边的配置也搞定。

编写代码

#pragma once
#include <mysql_driver.h>  
#include <mysql_connection.h>  
#include <cppconn/statement.h>  
#include <cppconn/resultset.h>  
#include <cppconn/prepared_statement.h>class Logger
{
public:Logger(){}private:std::string dbName = "my_log";std::string dbUser = "luoshui";std::string dbPassword = "xiangzihao137";std::string dbHost = "localhost";std::string dbPort = "3306";sql::mysql::MySQL_Driver* driver;sql::Connection* con;
};

这里出现了两个新的东西,我们来解释一下:

在C++中,特别是在使用MySQL Connector/C++与MySQL数据库交互时,你提到的这两行代码是关于对象指针的声明。让我们详细解释一下它们的意思:
sql::mysql::MySQL_Driver* driver
sql::mysql::MySQL_Driver:这是MySQL Connector/C++库中的一个类,它表示一个MySQL数据库驱动。这个驱动是连接到MySQL服务器所必需的。
driver;:这表示声明了一个指向sql::mysql::MySQL_Driver类对象的指针,名为driver。在实际使用之前,你通常会初始化这个指针,让它指向一个MySQL_Driver对象。
sql::Connection* con;
sql::Connection:这是MySQL Connector/C++库中的另一个类,它表示一个到MySQL服务器的连接。通过这个连接,你可以执行SQL查询、获取结果等。
* con;:这表示声明了一个指向sql::Connection类对象的指针,名为con。在实际使用之前,你通常会使用这个指针来创建一个到MySQL服务器的连接。
为了使用这些指针,你通常会按照以下步骤操作:
初始化driver指针,让它指向一个新的MySQL_Driver对象。
使用driver指针来创建与MySQL服务器的连接,并将返回的连接对象赋值给con指针。
使用con指针来执行各种数据库操作,如执行查询、获取结果等。

这些操作可能会涉及到异常处理,因为数据库连接和操作可能会因为各种原因(如连接失败、SQL错误等)而失败。因此,在使用这些类时,通常需要适当的错误检查和异常处理。

#pragma once
#include <mysql_driver.h>  
#include<sstream>
#include <mysql_connection.h>  
#include <cppconn/statement.h>  
#include <cppconn/resultset.h>  
#include <cppconn/prepared_statement.h>class Logger
{
public:Logger(){try{//实例化driver对象driver = sql::mysql::get_mysql_driver_instance();//使用字符流,完成连接地址std::stringstream url;url << "tcp://" << dbHost << ":" << dbPort << "/" << dbName;//开始连接con = driver->connect(url.str().c_str(), dbUser.c_str(), dbPassword.c_str());}catch(sql::SQLException& e){//如果失败,捕捉异常std::cerr << e.what();}}~Logger() {delete con;}private:std::string dbName = "my_log";std::string dbUser = "luoshui";std::string dbPassword = "xiangzihao137";std::string dbHost = "localhost";std::string dbPort = "3306";sql::mysql::MySQL_Driver* driver;sql::Connection* con;
};

此时我们用DataGrip:点击+
在这里插入图片描述添加MySQL的连接:
在这里插入图片描述
创建新的连接:
在这里插入图片描述在这里插入图片描述
此时创建好了链接,我们创建一个数据库(就是我们之前假设的那个my_log):
在这里插入图片描述在这里插入图片描述此时一输入完名字,DataGrip会自动识别我们之前为这个my_log设置的权限。

这里可能DataGrip会报错,但是不用管,点击取消发现我们的my_log已经创建好了:
在这里插入图片描述

往数据库写入

这时候就可以准备往数据库写入了:

   //往数据库中写入数据void logToDatabase(const std::string& message) {try{sql::PreparedStatement* pstmt = con->prepareStatement("INSERT INTO logs (message) VALUES (?)");pstmt->setString(1, message);pstmt->executeUpdate();pstmt->close(); // 或者使用delete pstmt; (取决于MySQL Connector/C++的版本)}catch (sql::SQLException& e) {std::cerr << "# ERR: " << e.what();}}

这段代码是使用MySQL Connector/C++库编写的一个Java风格的C++代码片段,用于向名为logs的数据库表中插入一行记录。下面逐行解释:

  1. sql::PreparedStatement* pstmt = con->prepareStatement("INSERT INTO logs (message) VALUES (?)");
  • 创建一个PreparedStatement对象,这个对象预先准备了一条SQL插入语句。在SQL语句中,message列使用问号(?)作为占位符,这是预处理语句的标准做法,可以防止SQL注入攻击,同时也允许我们在执行时动态地插入值。
  1. pstmt->setString(1, message);
  • 为预处理语句的第一个参数(对应SQL语句中的第一个问号)设置值。这里传入的是一个字符串message。数字1表示参数的位置,从1开始计数。
  1. pstmt->executeUpdate();
  • 执行预处理好的SQL语句,也就是执行插入操作,将前面设置好的字符串message插入到logs表的message列中。
  1. pstmt->close();
  • 关闭PreparedStatement对象,释放相关资源。在某些MySQL Connector/C++版本中,可能需要手动关闭这个对象以确保资源得到妥善管理。在现代版本的连接器中,通常推荐使用智能指针或其他自动资源管理机制来自动关闭和释放资源,但如果使用原始指针,则需要手动关闭。
  • 注意:有时根据具体的库实现和内存管理策略,可能需要使用delete pstmt;来删除对象,释放内存,但多数现代的C++数据库驱动程序倾向于使用RAII(Resource Acquisition Is Initialization)原则,即通过构造函数获取资源并在析构函数中自动释放资源,因此直接调用close()方法即可。

总而言之,这段代码是为插入日志记录到数据库做准备、设置参数并执行插入操作,最后清理资源。

注意这里:sql::PreparedStatement* pstmt = con->prepareStatement("INSERT INTO logs (message) VALUES (?)")这里的意思是:想在数据库my_log下的logs表中的message插入数据,如果这张表还没有的话,我们得提前创建一下:

CREATE TABLE IF NOT EXISTS my_log.logs (id INT AUTO_INCREMENT PRIMARY KEY,message TEXT NOT NULL,timestamp TIMESTAMP DEFAULT CURRENT_TIMESTAMP);

在这里插入图片描述

#define _CRT_SECURE_NO_WARNINGS 1
#include"log.hpp"int main()
{Logger logge;logge.logToDatabase("This is a massage");return 0;
}

但是这个时候编的过,但是运行不过:
在这里插入图片描述
这个是因为内存碎片过多,目前没有什么好的解决办法,我们可以将Debug换成Release模式:

在这里插入图片描述这个时候会疯狂报红,是因为我们之前的设置是在Debug下,换成Release就的重新从头再把头文件库包括一遍。

在这里插入图片描述重新配置之后,爆红就消失了。
再次运行:
在这里插入图片描述返回我们的表中,看看么message这一项:
在这里插入图片描述发现已经被成功写入了,我们可以换一下:
在这里插入图片描述
在这里插入图片描述

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

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

相关文章

springboot婚庆系统

摘 要 随着科学技术的飞速发展&#xff0c;各行各业都在努力与现代先进技术接轨&#xff0c;通过科技手段提高自身的优势&#xff1b;对于婚庆系统当然也不能排除在外&#xff0c;随着网络技术的不断成熟&#xff0c;带动了婚庆系统&#xff0c;它彻底改变了过去传统的管理方式…

【Gitea的介绍】

&#x1f525;博主&#xff1a;程序员不想YY啊&#x1f525; &#x1f4ab;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家&#x1f4ab; &#x1f917;点赞&#x1f388;收藏⭐再看&#x1f4ab;养成习惯 &#x1f308;希望本文对您有所裨益&#xff0c;如有…

在同一个网站上自动下载多个子页面内容

一、问题现象 第一次遇到这样的问题&#xff0c;如下图&#xff1a; 即在同一个网站上下载多个内容时&#xff0c;第一个内容明明已经正常get到了&#xff0c;但开始第二个页面的查询 以后&#xff0c;原来已经查出的内容就找不到了。 二、解决办法 我不知道大家是不是遇到…

配置vsftpd服务

服务简介 1、FTP协议概览 FTP&#xff08;File Transfer Protocol&#xff09;⽂件传输协议&#xff0c;在TCP/IP协议族中属于应⽤层协议&#xff0c;是运⾏于 TCP协议之上是⼀种可靠的传输协议&#xff0c;主要功能⽤于实现⽤户间⽂件分发共享&#xff0c;以及⽹络管理 者在进…

Flutter开发之objectbox

Flutter开发之objectbox 在之前进行iOS开发的时候使用WCDB去进行管理数据库很方便&#xff0c;它支持ORM&#xff08;Object-Relational Mapping&#xff0c;对象关系映射&#xff09;&#xff0c;用于实现面向对象编程语言里不同类型系统的数据之间的转换。 那么在Flutter开发…

代码随想录(day10)——栈和队列

Leetcode.1047 删除字符串中所有相邻重复项&#xff1a; 1047. 删除字符串中的所有相邻重复项 - 力扣&#xff08;LeetCode&#xff09; 本题可以利用栈的思想进行解答。但是此处并不是真正的去使用一个栈&#xff0c;而是利用来替代栈在本题中的作用。具体如下&#xff1a; …

【Vue】动态样式

内联样式的动态样式 body(){ boxASelect:false, } v-bind:style"{borderColor:boxASelect ? red : #ccc}" <body><header><h1>Vue Dynamic Styling</h1></header><section id"styling"><div class"demo&quo…

2024年MathorCup数学建模思路A题B题C题D题思路分享

文章目录 1 赛题思路2 比赛日期和时间3 组织机构4 建模常见问题类型4.1 分类问题4.2 优化问题4.3 预测问题4.4 评价问题 5 建模资料 1 赛题思路 (赛题出来以后第一时间在CSDN分享) https://blog.csdn.net/dc_sinor?typeblog 2 比赛日期和时间 报名截止时间&#xff1a;2024…

电脑文件轻松管理:按大小归类,高效存储文件

在数字化时代&#xff0c;电脑文件的管理变得至关重要。面对海量的数据和信息&#xff0c;如何高效整理、归类和保存这些文件&#xff0c;成为了我们必须要面对的挑战。今天&#xff0c;我们就来介绍一种简单而实用的文件管理方法——按文件大小归类保存&#xff0c;让您的数据…

再次加深理解Java中的并发编程

目录 一、线程、进程、程序 二、线程状态 三、线程的七大参数 四、lock与synchronized锁机制 一&#xff09;、lock与synchronized锁区别 二&#xff09;、synchronized锁原理 三&#xff09;、Lock锁原理 五、synchronized锁升级原理 一&#xff09;、锁升级基础知识 …

深度思考:雪花算法snowflake分布式id生成原理详解

雪花算法snowflake是一种优秀的分布式ID生成方案&#xff0c;其优点突出&#xff1a;它能生成全局唯一且递增的ID&#xff0c;确保了数据的一致性和准确性&#xff1b;同时&#xff0c;该算法灵活性强&#xff0c;可自定义各部分bit位&#xff0c;满足不同业务场景的需求&#…

java Web洗衣店管理系统用eclipse定制开发mysql数据库BS模式java编程jdbc

一、源码特点 JSP 洗衣店管理系统是一套完善的web设计系统&#xff0c;对理解JSP java 编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。开发环境为TOMCAT7.0,eclipse开发&#xff0c;数据库为Mysql5.0&#xff0c;使用…

API接口自动化测试框架搭建之需求整理、详细设计和框架设计!

​ 简介&#xff1a; API接口自动化测试框架搭建之需求整理、详细设计和框架设计 1 需求整理 1.1 实现目的 API接口自动化测试&#xff0c;主要针对http接口协议&#xff1b;便于回归测试&#xff1b;线上或线下巡检测试&#xff0c;结合持续集成&#xff0c;及时发现运行环…

嵌入式中逻辑分析仪的基本操作与实现

作为一名嵌入式软件/硬件工程师,要会使用各种仪表仪器,尤其示波器、逻辑分析仪, 这两个仪器可以监测各种数据线、信号线波形, 可以帮我们快速定位产品问题,缩短开发周期。 今天一口君安利一款非常不错的逻辑分析仪:kingst LA5016 这款仪器非常容易上手, 尤其在一些…

【滑动窗口】Leetcode 水果成篮

题目解析 904. 水果成篮 算法讲解 这道题的本质就是&#xff1a;寻找一段连续的区域&#xff08;子数组&#xff09;&#xff0c;这一段连续的区域里面最多包含两种水果&#xff0c;因为有可能这一段连续的区域里面全是一种水果&#xff0c;比如&#xff1a;f(x) {1,1,1,1,…

Linux中安装JDK17.X

1、总体概述&#xff1f; 该操作方式适合centos或red hat环境 2.1、在线下载JDK安装包&#xff1f; 通过wget命令下载JDK17.X包 wget https://download.oracle.com/java/17/latest/jdk-17_linux-x64_bin.tar.gz 如果提示&#xff1a;没有wget命令就安装wget yum install w…

G35-2单螺杆泵

在现代工业流程中&#xff0c;流体输送是至关重要的一环。无论是石油化工、能源开采还是精细化工领域&#xff0c;高效率和可靠的泵送设备都是确保生产过程平稳运行的关键。在这样的背景下&#xff0c;G35-2单螺杆泵凭借其卓越的性能和广泛的应用性&#xff0c;成为了众多工业企…

答题小程序功能细节揭秘:如何提升用户体验和满足用户需求?

答题小程序功能细节体现 随着移动互联网的快速发展&#xff0c;答题小程序成为了用户获取知识、娱乐休闲的重要平台。一款优秀的答题小程序不仅应该具备简洁易用的界面设计&#xff0c;更应该在功能细节上做到极致&#xff0c;以提升用户体验和满足用户需求。本文将从题库随机…

SCI论文发表多长时间才可以被检索?

sci检索&#xff0c;是指发表的sci论文可以在web of science上查询到&#xff0c;是sci论文发表的最后一个步骤&#xff0c;建立在见刊的基础之上。那么&#xff0c;sci发表后多久可检索?没有统一标准&#xff0c;刊物不同&#xff0c;检索时间有差异。 一、SCI文章检索的注意…

深入解析AI大模型:原理、挑战与前景

前言 在现今技术飞速发展的时代&#xff0c;AI大模型学习已成为科技领域的研究热点。要想在这一领域取得突破&#xff0c;研究者需掌握扎实的数学基础、编程能力以及特定领域的业务知识。本文将深入剖析AI大模型的原理、挑战与前景&#xff0c;为读者提供有益的建议。 一、AI…