笨蛋学C++之 C++连接数据库

news2024/12/25 10:28:08

笨蛋学C++ 之 VS2019使用C++连接数据库

  • 创建数据库
    • SQL语句
    • VS2019
        • 选择空项目,点击下一步创建
        • 输入项目名称,点击创建
        • 创建成功
        • 点击新建项创建源文件
        • 因为mysql是64位,此时的c++项目是86位,所以这里需要将项目修改为x64位
        • 点击项目 -> 0501-test 属性 -> 将配置和平台修改为Debug、x64
        • 此时的软件页面也要修改为Debug、x64
        • 修改**C/C++**下的**常规**模块的**附加包含目录**的项目的include文件位置,点击项目 -> 0501-test 属性 -> C/C++ -> 附加包含目录 -> 点击编辑 -> 将自己mysql安装的include路径复制到窗口中 -> 点击确定
        • 点击项目 -> 0501-test 属性 -> 链接器 -> 常规 -> 附加库目录 -> 点击编辑 -> 将自己mysql安装的lib路径复制到窗口中 -> 点击确定
        • 点击项目 -> 0501-test 属性 -> 链接器 -> 输入 -> 附加依赖项 -> 点击编辑 -> 输入**libmysql.lib** -> 点击确定
        • 点击应用 -> 点击确定
        • 修改数据库密码、数据库名,测试连接
        • 连接成功,成功插入数据

创建数据库

SQL语句

DROP TABLE IF EXISTS `test`;
CREATE TABLE `test`  (
  `id` int NOT NULL,
  `name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL,
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;
---------------------------------------------------------------
INSERT INTO `test` VALUES (1, 'jack');
INSERT INTO `test` VALUES (2, 'tom');
INSERT INTO `test` VALUES (3, 'smith');

VS2019

  • 选择空项目,点击下一步创建

在这里插入图片描述

  • 输入项目名称,点击创建

在这里插入图片描述

  • 创建成功

在这里插入图片描述

  • 点击新建项创建源文件

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

  • 因为mysql是64位,此时的c++项目是86位,所以这里需要将项目修改为x64位

在这里插入图片描述

  • 点击项目 -> 0501-test 属性 -> 将配置和平台修改为Debug、x64

在这里插入图片描述

  • 此时的软件页面也要修改为Debug、x64

在这里插入图片描述

  • 修改C/C++下的常规模块的附加包含目录的项目的include文件位置,点击项目 -> 0501-test 属性 -> C/C++ -> 附加包含目录 -> 点击编辑 -> 将自己mysql安装的include路径复制到窗口中 -> 点击确定

在这里插入图片描述

  • 点击项目 -> 0501-test 属性 -> 链接器 -> 常规 -> 附加库目录 -> 点击编辑 -> 将自己mysql安装的lib路径复制到窗口中 -> 点击确定

在这里插入图片描述

  • 点击项目 -> 0501-test 属性 -> 链接器 -> 输入 -> 附加依赖项 -> 点击编辑 -> 输入libmysql.lib -> 点击确定

在这里插入图片描述

  • 点击应用 -> 点击确定

在这里插入图片描述

  • D:\MySQL\mysql\Install Directory\lib 下的libmysql.dll文件复制到 C:\Windows\System32
    在这里插入图片描述
  • 修改数据库密码、数据库名,测试连接
#include <mysql.h>
#include <iostream>
#include <cstring> // 包含字符串操作相关的头文件
using namespace std;

const char* host = "127.0.0.1";
const char* user = "root";
const char* password = "P@ssw0rd";
const char* database_name = "c++test";
const int port = 3306;

typedef struct Test {
    int id;
    string name;
} Test;

int main(void) {
    // 设置链接
    MYSQL* con = mysql_init(NULL);
    // 设置编码
    mysql_options(con, MYSQL_SET_CHARSET_NAME, "GBK");
    if (!mysql_real_connect(con, host, user, password, database_name, port, NULL, 0)) {
        cerr << "Failed to connect to database Error: " << mysql_error(con) << endl;
        return -1;
    }

    Test test{ 4,"wangwu" };
    char sql[1024];
    sprintf_s(sql, sizeof(sql), "INSERT INTO test (id,name) VALUES (%d,'%s')", test.id, test.name.c_str());

    if (mysql_query(con, sql)) {
        cerr << "Failed to insert to database Error: " << mysql_error(con) << endl;
        return -1;
    }

    mysql_close(con);
    return 0;
}
  • 连接成功,成功插入数据

在这里插入图片描述

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

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

相关文章

linux 单机安装consul

sudo yum install -y yum-utils && sudo yum-config-manager --add-repo https://rpm.releases.hashicorp.com/RHEL/hashicorp.repo && sudo yum -y install consul#添加consul配置文件 nano /etc/consul.d/server.json {"server": true,"boots…

Python异步Redis客户端与通用缓存装饰器

前言 这里我将通过 redis-py 简易封装一个异步的Redis客户端&#xff0c;然后主要讲解设计一个支持各种缓存代理&#xff08;本地内存、Redis等&#xff09;的缓存装饰器&#xff0c;用于在减少一些不必要的计算、存储层的查询、网络IO等。 具体代码都封装在 HuiDBK/py-tools: …

使用 uni-app 开发 iOS 应用的操作步骤

哈喽呀&#xff0c;大家好呀&#xff0c;淼淼又来和大家见面啦&#xff0c;上一期和大家一起探讨了使用uniapp开发iOS应用的优势及劣势之后有许多小伙伴想要尝试使用uniapp开发iOS应用&#xff0c;但是却不懂如何使用uniapp开发iOS应用&#xff0c;所以这一期淼淼就来给你们分享…

nginx--平滑升级

失败了&#xff0c;等我拍好错继续更新 命令 选项说明 帮助: -? -h 使用指定的配置文件: -c 指定配置指令:-g 指定运行目录:-p 测试配置文件是否有语法错误:-t -T 打印nginx的版本信息、编译信息等:-v -V 发送信号: -s 示例: nginx -s reload 信号说明 立刻停止服务:stop,相…

【C++】学习笔记——string_3

文章目录 六、string类5. string类的操作6. string类的转换7. string类的模拟实现 未完待续 搭配文档食用 六、string类 5. string类的操作 上面的函数中&#xff0c;有些是不常用的&#xff0c;咱们只挑几个重要的进行讲解。 c_str 就是将字符串转换成 C语言 字符串的格式。…

[Java EE] 多线程(六):线程池与定时器

1. 线程池 1.1 什么是线程池 我们前面提到,线程的创建要比进程开销小,但是如果线程的创建/销毁比较频繁,开销也会比较大.所以我们便引入了线程池,线程池的作用就是提前把线程都创建好,放到用户态代码中写的数据结构中,后面就可以随用随取. 线程池最大的好处就是减少每次启动,…

Python中动画显示与gif生成

1. 动画生成 主要使用的是 matplotlib.animation &#xff0c;具体示例如下&#xff1a; import matplotlib.pyplot as plt import matplotlib.animation as animation import numpy as np fig, ax plt.subplots() t np.linspace(0, 3, 40) g -9.81 v0 12 z g * t**2 / …

【Python函数和类6/6】类与对象

目录 目标 类与对象 类的定义 栗子 实例化对象 属性和方法的调用 特殊的self参数 类方法的其它参数 函数与方法的区别 总结 目标 在前面的博客当中&#xff0c;我们已经接触了一部分封装。比如&#xff1a;将数据扔进列表中&#xff0c;这就是一个简单…

短视频素材去哪里搬运?短视频素材有哪些类型?

在这个数字化和视觉传达至关重要的时代&#xff0c;选择合适的视频素材对于提升视频内容的吸引力和观众参与度至关重要。无论您是一名广告制片人、社交媒体经理还是独立视频制作者&#xff0c;以下这些精选的视频素材网站将为您提供从高清视频到特效资源的全面支持&#xff0c;…

工厂模式和策略模式区别

工厂模式和策略模式都是面向对象设计模式&#xff0c;但它们的目的和应用场景有所不同。 工厂模式是一种创建型设计模式&#xff0c;旨在通过使用一个工厂类来创建对象&#xff0c;而不是直接使用new关键字来创建对象。这样做可以使系统更容易扩展和维护&#xff0c;因为新的对…

reactjs后台管理系统搭建

1 通过yarn 模板创建reactjs项目 yarn create vite reactjs-antdesign-admin --template react-ts 2 基础路由测试 定义一个router/index.tsx&#xff0c;里面定义路由组件 const Router: React.FC () > {return (<HashRouter><Switch><Route path"…

Edge浏览器使用心得与深度探索

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

信息时代的智慧导航:高效搜索、信息筛选与信任构建的全面指南!

文章目录 一、高效搜索&#xff1a;快速定位目标信息的秘诀二、信息筛选&#xff1a;去伪存真&#xff0c;找到有价值的信息三、信任构建&#xff1a;深入了解与直接沟通《搜索之道&#xff1a;信息素养与终身学习的新引擎》亮点内容简介目录获取方式 随着科技的飞速发展&#…

前端基础学习html(2)

目录 表格标签&#xff1a; 列表标签&#xff1a; 表格标签&#xff1a; <!-- 表格基本架构 --><!-- tr表示一行&#xff0c;td表示一行内单元格 --><!--th为第一行表头加粗居中显示 --><table border"1"><thead><tr><th&g…

用Stream流方式合并两个list集合(部分对象属性重合)

一、合并出共有部分 package com.xu.demo.test;import java.util.Arrays; import java.util.List; import java.util.stream.Collectors;public class ListMergeTest1 {public static void main(String[] args) {List<User> list1 Arrays.asList(new User(1, "Alic…

【linux学习指南】linux指令与实践文件编写

文章目录 &#x1f4dd;前言&#x1f320; linux目录结构&#x1f309;linux命令介绍 &#x1f320;pwd命令&#x1f309;mkdir指令&#xff08;重要&#xff09; &#x1f320;cd 指令&#x1f309;touch指令 &#x1f320;rmdir指令 && rm 指令&#xff08;重要&…

nginx--配置文件

组成 主配置文件&#xff1a;nginx.conf 子配置文件&#xff1a;include conf.d/*.conf 协议相关的配置文件&#xff1a;fastcgi uwsgi scgi等 mime.types&#xff1a;⽀持的mime类型&#xff0c;MIME(Multipurpose Internet Mail Extensions)多用途互联⽹网邮件扩展类型&…

KUKA机器人KR3 R540维护保养——涂润滑脂

KUKA机器人在保养时少不了润滑脂&#xff0c;不同型号的机器人需要的润滑脂类型也不一样&#xff0c;保养时注意选用合适的润滑脂。本篇文章以KUKA机器人KR3 R540为例&#xff0c;在轴盖板 A2、A3、A5 的内侧涂上润滑脂。 一、涂润滑脂的作用 拆开机器人一个轴的盖板&am…

链表面试题2

1&#xff0c;合并两个有序链表 我们先定义一个虚拟节点newH&#xff0c; 然后按照上图所走&#xff0c;但是当其中一个链表走空时&#xff0c;我们只需返回另一个链表即可 class Solution {public ListNode mergeTwoLists(ListNode headA, ListNode headB) {ListNode newhead…

python基础语法--函数

一、函数概述 函数就是执行特定任务完成特定功能的一段代码。可以在程序中将某一段代码定义成函数&#xff0c;并指定一个函数名和接收的输入&#xff08;参数&#xff09;&#xff0c;这样就可以在程序的其他地方通过函数名多次调用并执行该段代码了。 每次调用执行后&#…