当前位置: 首页 > news >正文

MySQL C API高效编程:C语言实现数据库操作的深入解析

知识点【MySQL C API】

1、头文件及MYSQL * 句柄

//头文件
#include <mysql/mysql.h>

1、MYSQL

MYSQL是一个结构体,封装了与数据库连接相关的所有状态,配置和数据。

2、MYSQL *的本质

类似于 FILE*,代表一个与数据库连接的通道,所有对数据库的操作都依赖于这个句柄

每个MYSQL* 句柄都对应一个独立的数据库连接,不能在多线程间共享每个线程创建独立的句柄

3、生命周期

从 init 到 close

4、MYSQL结构体内部管理的内容

大致了解就可以 无需刻意背诵

5、MYSQL *作用

一个程序可以同时连接多个MySQL服务器,每个连接需要独立的MYSQL *句柄区分操作目标。

2、mysql_init()

**MYSQL *mysql_init(MYSQL *mysql)**

函数功能

初始化一个MYSQL对象,用于后续数据库连接操作

参数

mysql:指向MYSQL结构体的指针。

如果传入NULL,系统会自动分配并返回一个新对象。

返回值

成功:返回初始化后的MYSQL * 句柄

失败:NULL(如内存不足)

3、mysql_real_connect()

**MYSQL *mysql_real_connect(MYSQL *mysql, const char *host, const char *user, const char *passwd, const char *db, unsigned int port, const char *unix_socket, unsigned long client_flag)**

函数功能

建立于MYSQL服务器的实际连接

参数

mysql:有mysql_init初始化的MYSQL对象

host:主机名或者IP地址,如果是NULL,”localhost“,”127.0.0.1”被视为与本地主机连接

user:登陆用户名

passwd:登陆密码

db:默认连接的数据库名(可选)

port:服务器端口号(0表示默认端口3306)

unix_socket:套接字或命名管道(通常为NULL)

client_flag:连接标志

返回值

成功:返回传入的MYSQL *句柄

失败:NULL,可通过mysql_error(mysql)获取错误信息。

4、mysql_real_query()

**int mysql_real_query(MYSQL *mysql, const char *stmt_str, unsigned long length)**

函数功能

执行SQL查询(支持二进制数据)

参数

mysql:已连接的 MYSQL 对象

stmt_str:SQL语句字符串(不要以;结尾

length:语句长度(使用strlen(stmt_str)计算)

返回值

成功:0

失败:返回非0值,需要用mysql_error(mysql)检查错误

5、mysql_store_result()

**MYSQL_RES *mysql_store_result(MYSQL *mysql)**

函数功能

从服务器获取完整的查询结果集并存储到客户端内存

参数

mysql:已成功执行查询的MYSQL对象

返回值

成功:MYSQL_RES结果集指针

失败:返回NULL,使用mysql_error(mysql)检错

补充

适用于小型结果集,需要手动调用mysql_free_result()释放内存。

6、mysql_num_fields()

**unsigned int mysql_num_fields(MYSQL_RES *result)**

函数功能

获取结果集中的列数

参数

result:mysql_store_result 或者 mysql_use_result 返回的结果集

返回值

列数

7、mysql_num_rows()

**my_ulonglong mysql_num_rows(MYSQL_RES *result)**

函数功能

获取结果集中的行数(仅对 mysql_store_result 有效)

参数

result:my_result_result 返回的结果集

返回值

行数

补充

如果使用 mysql_use_result 需要遍历所有行才能得到准确行数

8、mysql_fetch_field()

**MYSQL_FIELD *mysql_fetch_field(MYSQL_RES *result)**

函数功能

获取结果集中 列的元数据(列名,类型,长度等)

参数

return:结果集指针

返回值

成功:返回MYSQL_FIELD结构体指针

失败:无更多列:NULL

补充

内部会自动指向下一列,无需手动操作

MYSQL_FIELD结构体

typedef struct st_mysql_field
{char *name;// 列名(如 "id")char *org_name;// 原始列名(若使用别名时)char *table;// 所属表名char *org_table;// 原始表名(若使用别名时)char *db;// 所属数据库名char *catalog;// 目录名(通常为空)char *def;// 列的默认值unsigned long length;// 列的定义长度(如 VARCHAR(255) → 255)unsigned long max_length;// 结果集中实际最大长度(需调用 mysql_store_result 后有效)unsigned int name_length;unsigned int org_name_length;unsigned int table_length;unsigned int org_table_length;unsigned int db_length;unsigned int catalog_length;unsigned int def_length;unsigned int flags;// 列的标志(如 NOT_NULL_FLAG)unsigned int decimals;// 小数位数(如 DECIMAL(10,2) → 2)unsigned int charsetnr;// 字符集编号enum enum_field_types type;// 列的数据类型(如 MYSQL_TYPE_INT、MYSQL_TYPE_STRING)
} MYSQL_FIELD;

9、mysql_fetch_row()

**MYSQL_ROW mysql_fetch_row(MYSQL_RES *result)**
typedef char **MYSQL_ROW; *// 例如:row[0] 是第一列的值*

函数功能

从结果集中逐行获取数据

参数

result:结果集指针

返回值

成功:返回MYSQL_ROW类型(字符串数组)

失败:无更多行,NULL

补充

内部会自动指向下一行,无需手动操作

10、mysql_free_result()

**void mysql_free_result(MYSQL_RES *result)**

函数功能

释放mysql_store_result 分配的 结果集的内存

参数

result:带释放的结果集指针

返回值

11、mysql_close()

**void mysql_close(MYSQL *mysql)**

函数功能

关闭数据库连接,并释放MYSQL对象内存

参数

mysql:已连接的MYSQL

返回值

补充

不能重复关闭句柄

可以加上防二次关闭的逻辑

if(mysql != NULL )
{mysql_close(mysql);mysql = NULL;
}

自动清理未释放的结果集:

如果忘记调用mysql_free_result(),mysql_close()会隐式释放结果集,但是显示释放更加直观,更加安全。

综合案例

1、函数补充 mysql_set_character_set

int mysql_set_character_set(MYSQL *mysql, const char *csname);

函数功能

设置 MySQL 客户端连接(MYSQL* 句柄)的字符集,确保客户端与服务器之间的数据传输使用指定编码

参数

mysql:已成功连接的MYSQL *句柄

csname:字符集名称字符串

  • "utf8mb4":支持 Unicode 4 字节字符(如 Emoji)。
  • "gbk":中文编码。
  • "binary":二进制数据。

返回值

成功:0

失败:非0

****以下是不进行编码指定的,向数据库中插入中文(小明)的现象。

2、编译要求

最后需要加上 -lmysqlclient

类似于 我们在线程中添加的-lpthread

l是library(库)的意思

注意

mysql_store_result() 的作用是获取 上一个查询 的结果集。

代码展示

#include <mysql/mysql.h>
#include <stdio.h>
#include <string.h>int main(int argc, char const *argv[])
{//初始化MYSQL * conn = mysql_init(NULL);//错误1 这里参数应是NULLif(conn == NULL){perror("mysql_init");exit(1);}//连接数据库if(!mysql_real_connect(conn,NULL,"root","","person",3306,NULL,0)){fprintf(stderr,"%s\\n",mysql_error(conn));if(conn != NULL){mysql_close(conn);conn = NULL;}exit(1);}mysql_set_character_set(conn, "utf8mb4");//请求char *arr_query1 = "select num,name from new_stu";char *arr_query2 = "insert into new_stu values(109,'小明',18)";unsigned len_query1 = strlen(arr_query1);unsigned len_query2 = strlen(arr_query2);if(mysql_real_query(conn,arr_query1,len_query1)){fprintf(stderr,"%s\\n",mysql_error(conn));if(conn != NULL){mysql_close(conn);conn = NULL;}exit(1);}//获取数据集MYSQL_RES * result = NULL; if(!(result = mysql_store_result(conn))){fprintf(stderr,"%s\\n",mysql_error(conn));if(conn != NULL){mysql_close(conn);conn = NULL;}exit(1);}//遍历数据库行数 列数unsigned int len_column = mysql_num_fields(result);my_ulonglong len_row = mysql_num_rows(result);printf("column == %u,row == %llu\\n",len_column,len_row);//遍历数据库的数据if(len_row != 0){//遍历列的属性MYSQL_FIELD *filed = NULL;while(filed = mysql_fetch_field(result)){printf("%-10s",filed->name);}printf("\\n");//遍历行数据MYSQL_ROW row = NULL;while(row = mysql_fetch_row(result)){for (size_t i = 0; i < len_column; i++){printf("%-10s",row[i]);}printf("\\n");}}else{//无数据printf("No data on database!\\n");}//注意这里 这里我们在这里插入 而不是紧跟着mysql_real_query(conn,arr_query1,len_query1)插入//让大家更好地理解 结果集的存在 和 mysql_store_result 的逻辑if(mysql_real_query(conn,arr_query2,len_query2)){fprintf(stderr,"%s\\n",mysql_error(conn));if(conn != NULL){mysql_close(conn);conn = NULL;}exit(1);}//关闭数据集mysql_free_result(result);//关闭句柄if(conn != NULL){mysql_close(conn);conn = NULL;}return 0;
}

代码犯错:

1、mysql_init 参数应是NULL,写成 还未初始化的conn

2、没有加字符格式矫正,导致数据库中文乱码

mysql_set_character_set

3、对结果集的理解有误 导致mysql_store_result

以及后续result的使用上 与理想情况出现偏差。复习时重点回想

结束

代码重在练习!

代码重在练习!

代码重在练习!

今天的分享就到此结束了,希望对你有所帮助,如果你喜欢我的分享,请点赞收藏加关注,谢谢大家!!!

相关文章:

MySQL C API高效编程:C语言实现数据库操作的深入解析

知识点【MySQL C API】 1、头文件及MYSQL * 句柄 //头文件 #include <mysql/mysql.h>1、MYSQL MYSQL是一个结构体&#xff0c;封装了与数据库连接相关的所有状态&#xff0c;配置和数据。 2、MYSQL *的本质 类似于 FILE*&#xff0c;代表一个与数据库连接的通道&…...

字符串,数组,指针之间的关系

在C语言中&#xff0c;字符串、指针和数组之间有着紧密且复杂的关系&#xff0c;它们在内存存储、操作方式等方面相互关联&#xff0c;以下为你详细介绍&#xff1a; 字符串 定义&#xff1a;字符串是由字符组成的序列&#xff0c;以空字符&#xff08;\0&#xff09;作为结束…...

2025流感疫苗指南+卫健委诊疗方案|高危人群防护+并发症处理 慢性肾脏病饮食指南2025卫健委版|低盐低磷食谱+中医调理+PDF 网盘下载 pdf下载

2025 年卫健委发布的《成人肥胖食养指南&#xff08;2024 年版&#xff09;》为减肥提供了科学的饮食指导。 &#x1f4e2;提示&#xff1a;文章排版原因&#xff0c;资源链接地址放在文章结尾&#x1f447;&#x1f447;&#xff0c;往下翻就行 &#x1f4e2;提示&#xff1…...

学习路线(机器人软件架构)

机器人软件系统架构从入门到专家学习路线 一、基础阶段&#xff08;6-12个月&#xff09;基础知识储备机器人基础概念&#xff1a;编程技能必备语言&#xff1a;工具链&#xff1a; 入门框架推荐资源&#xff1a; 中级阶段&#xff08;1-2年&#xff09;系统架构基础ROS进阶架构…...

Stellaris 群星 [DLC 解锁] CT 表 [Steam] [Windows SteamOS macOS]

Stellaris 群星 [DLC 解锁] & CT 表 [Steam] [Windows & SteamOS & macOS] DLC 版本 至最新全部 DLC 后续可能无法及时更新文章&#xff0c;具体最新版本见下载文件说明&#xff1b; DLC 解锁列表&#xff08;仅供参考&#xff09; 《群星》 - Symbols of Domina…...

题目 3321: 蓝桥杯2025年第十六届省赛真题-画展布置

题目 3321: 蓝桥杯2025年第十六届省赛真题-画展布置 时间限制: 2s 内存限制: 192MB 提交: 673 解决: 130 题目描述 画展策展人小蓝和助理小桥为即将举办的画展准备了 N 幅画作&#xff0c;其艺术价 值分别为 A1, A2, . . . , AN。他们需要从这 N 幅画中挑选 M 幅&#xff0c;并…...

Excel 查询之 iNDEX与MATCH组合

在Excel日常工作中&#xff0c;数据查询是最常见的操作之一。虽然VLOOKUP函数广为人知&#xff0c;但它有一个明显的局限性——要求查询值必须位于返回值的左侧。今天我要介绍一个更灵活、更强大的组合&#xff1a;INDEX和MATCH函数。 为什么选择INDEXMATCH&#xff1f; VLOO…...

【Leetcode 每日一题 - 补卡】1128. 等价多米诺骨牌对的数量

问题背景 给你一组多米诺骨牌 d o m i n o e s dominoes dominoes。 形式上&#xff0c; d o m i n o e s [ i ] [ a , b ] dominoes[i] [a, b] dominoes[i][a,b] 与 d o m i n o e s [ j ] [ c , d ] dominoes[j] [c, d] dominoes[j][c,d] 等价 当且仅当 ( a c a c …...

【Elasticsearch入门到落地】12、索引库删除判断以及文档增删改查

接上篇《11、RestClient初始化索引库》 上一篇我们完成了使用RestHighLevelClient创建索引库的代码实现&#xff0c;本篇将讲解如何判断索引库是否存在并删除它&#xff0c;以及如何对索引库中的文档进行增删改查操作。 一、索引库判断与删除 在操作索引库时&#xff0c;有时…...

36、C#中的⽅法声明参数关键字params,ref,out的意义及⽤法

在C#中&#xff0c;params、ref 和 out 是方法声明中用于修饰参数的关键字&#xff0c;它们各自有不同的用途和语义。以下是它们的详细说明和用法&#xff1a; 1、 params 关键字 意义 params 允许方法接受可变数量的参数&#xff0c;这些参数会被编译为一个数组。适用于参数…...

DEX平台引领风尚 XBIT让数字资产回归简单与透明

近日&#xff0c;全球加密货币市场持续升温&#xff0c;Dex 交易平台成为众多投资者关注焦点&#xff0c;其中XBIT去中心化交易所平台凭借独特优势脱颖而出。 图片来源&#xff1a;币界网 在当今加密货币领域&#xff0c;交易平台的安全性与便捷性至关重要。XBIT去中心化交易所…...

基于Python+MongoDB猫眼电影 Top100 数据爬取与存储

前言&#xff1a;从猫眼电影排行榜页面&#xff08;TOP100榜 - 猫眼电影 - 一网打尽好电影 &#xff09;爬取 Top100 电影的电影名称、图片地址、主演、上映时间和评分等关键信息&#xff0c;并将这些信息存储到本地 MongoDB 数据库中&#xff0c;&#x1f517; 相关链接Xpath&…...

Linux文件复制命令精要指南:cp与scp详解

大家好&#xff0c;欢迎来到程序视点&#xff01;我是你们的老朋友.小二&#xff01; Linux文件复制命令精要指南&#xff1a;cp与scp详解 一、cp命令&#xff08;本地文件复制&#xff09; 核心功能 复制文件/目录到目标路径&#xff0c;支持重命名及批量操作。 关键参数 …...

Qt实现网页内嵌

文章目录 一、环境准备 二、代码实现 三、测试 一、环境准备 首先&#xff0c;确保你的Qt安装包含了QtWebEngine模块。我的Qt是5.12.9并且使用MSVC来编译项目。在项目文件中需要添加以下配置&#xff0c;其中在Qt中配置MSVC&#xff0c;建议去看看这位大佬的博客&#xff1a…...

Kotlin中 StateFlow 或 SharedFlow 或 LiveData的区别

在Android开发中&#xff0c;处理数据流是常见的需求&#xff0c;特别是在UI更新和数据共享方面。Kotlin提供了几种不同的工具来帮助开发者实现这一需求&#xff0c;包括StateFlow、SharedFlow和LiveData。每种工具都有其特点和使用场景&#xff0c;下面我们将逐一比较它们的区…...

jupyter notebook运行简单程序

一. 使用 cmd 创建虚拟环境 1.创建虚拟环境 &#xff08;1&#xff09;创建新的虚拟环境&#xff08;本项目名设置为zhineng&#xff09;&#xff0c;并设置python版本 conda create -n zhineng python3.6 &#xff08;2&#xff09;查看python版本 python --version &am…...

查看Ubuntu版本

1. 使用 lsb_release 命令&#xff08;推荐&#xff09; lsb_release -a输出示例&#xff1a; ubuntuVM-0-6-ubuntu:~$ lsb_release -a No LSB modules are available. Distributor ID: Ubuntu Description: Ubuntu 22.04 LTS Release: 22.04 Codename: jamm…...

《算法导论(第4版)》阅读笔记:p7-p8

《算法导论(第4版)》学习第 5 天&#xff0c;p7-p8 总结&#xff0c;总计 2 页。 一、技术总结 1.算法解决什么问题&#xff1f; DNA测序问题(Dynamic Programming, 动态规划)&#xff0c;寻找路径问题&#xff0c;加密问题&#xff0c;利益最大化问题(linear programming, …...

AI笔记-1

Halide Perovskites (HPs) 卤化物钙钛矿 卤化物钙钛矿&#xff08;HPs&#xff09;已被 公认为 光伏和发光器件 中最有前途的材料之一 在本观点中&#xff0c;我们将探讨钙钛矿的定义&#xff0c;主要聚焦于由 较重卤素&#xff08;Cl、Br和I&#xff09;组成的钙钛矿亚群&…...

【C++重载操作符与转换】成员访问操作符

目录 一、点操作符&#xff08;.&#xff09; 1.1 基本概念 1.2 点操作符不能被重载 二、箭头操作符&#xff08;->&#xff09; 2.1 基本概念 2.2 箭头操作符的重载 2.3 箭头操作符重载的特殊规则 三、成员指针操作符&#xff08;.*&#xff09;和指向成员指针的箭…...

java单元测试代码

import org.junit.jupiter.api.Test; import static org.junit.jupiter.api.Assertions.*; import java.util.List;public class UserServiceTest {Testpublic void testSearchUserByTags() {// 模拟标签列表List<String> tagNameList List.of("tag1", "…...

Vue中的过滤器参数:灵活处理文本格式化

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

【神经网络与深度学习】深度学习中的生成模型简介

深度学习中的生成模型 openai 的一个古早介绍 引言 深度学习中的生成模型能够学习数据分布并生成新数据&#xff0c;在人工智能的多个领域中都有重要应用。不同类型的生成模型在原理和结构上各有特点&#xff0c;适用于不同的任务&#xff0c;如图像生成、文本生成和时间序列…...

Docker(三):DockerFile

一、DockerFile介绍 1、DockerFile 介绍 DockerFile 是一种能够被Docker 程序解释的文件&#xff08;一般为了方便理解称之为“剧本”&#xff09;。 DockerFile 由一条一条的指令组成&#xff0c;并且有自己的书写格式和支持的命令。当我们需要在容器 镜像中指定自己额外的需…...

使用OpenCV 和 Dlib 实现疲劳检测

文章目录 引言1.相关技术介绍2. 系统原理2.1 眼睛纵横比(EAR)算法2.2 系统工作流程 3.代码解析3.1 关键函数说明3.2 主循环逻辑 4.实际应用效果5.参数调优建议6.总结 引言 疲劳驾驶是交通事故的主要原因之一。本文将介绍如何使用Python和计算机视觉技术构建一个实时疲劳驾驶检…...

Python格式化字符串的四种方法

Python格式化字符串的四种方法 1.使用 % 运算符 %s 是一个字符串的占位符&#xff0c;而 “World” 是替换它的值 print("Hello, %s!" % "World") # 输出&#xff1a;Hello, World!你可以使用多个占位符 注意&#xff1a;多个变量占位&#xff0c;变量要…...

蓝桥杯 18. 积木

积木 原题目链接 题目描述 小明用积木搭了一个城堡。为了方便&#xff0c;小明使用的是大小相同的正方体积木&#xff0c;并将其搭建在一个 n 行 m 列的方格图上。每个积木占据方格图中的一个小格子。 小明的城堡是立体的&#xff0c;可以将积木垒在其他积木上。当某个格子…...

解决因字段过长使MYSQL数据解析超时导致线上CPU告警问题

1.首先发生CPU告警 占有率到98.8% 2.DBA找到最终的原因是这条SQL导致 select * from trade_order_sku_071 where order_id in ( P760205793431071471 ) and user_id in ( 67d9158c000000000e0134ff );” 3.观察系统指标&#xff0c;发现CPU和网络同时飙升&#xff0c;同时网络…...

Python中的客户端和服务端交互的基本内容

目录 网络协议 网络的通信方式 需要安装的组件和需要导入的包模块 安装的组件 导入包模块 如何创建客户端 如何创建服务端 网络协议 IPV4&#xff1a;是互联网协议的第四版&#xff0c;也是目前广泛使用的网络协议。它使用32位地址格式&#xff0c;理论上可以提供约43亿…...

Compose 中使用 WebView

在 Jetpack Compose 中&#xff0c;我们可以使用 AndroidView 组件来集成传统的 Android WebView。以下是几种实现方式&#xff1a; 基础 WebView 实现 Composable fun WebViewScreen(url: String) {AndroidView(factory { context ->WebView(context).apply {// 设置布局…...

PyCharm 安装教程

## 简介 PyCharm 是由 JetBrains 公司开发的一款优秀的 Python 集成开发环境&#xff08;IDE&#xff09;&#xff0c;提供了代码分析、图形化调试器、集成测试器和版本控制系统等功能。PyCharm 有两个版本&#xff1a; - **专业版&#xff08;Professional&#xff09;**&am…...

基于MATLAB的图像色彩识别项目,彩色图像矩阵识别

一、项目背景 在本次IP Lab项目中&#xff0c;我们模拟了游戏“Lego’s Life of George”的玩法。游戏要求玩家在屏幕短暂展示图像后&#xff0c;凭借记忆重建乐高结构。我们面临的任务是处理一系列存在各种缺陷的图像&#xff0c;像噪声干扰、旋转以及投影问题等&#xff0c;…...

springboot应用大批量导出excel产生oom处理措施实践(适用于poieasyexcel)

一、背景&#xff1a; 在某些信息管理场景中&#xff0c;存在大批量导出需求&#xff0c;例如一次性导出10~100w行excel数据&#xff0c;如果不做特殊的处理&#xff0c;很容易导致Out Of Memory&#xff0c;特别是堆内存溢出。 oom复现 例如修改IDEA运行配置&#xff0c;VM…...

OpenCV 第6课 图像处理之几何变换(透视)

1、透视变换 2、数学公式 3、透视变换矩阵的生成 4、图像变换函数 5、例程 1、透视变换 OpenCV中的透视变换是一种几何变换,用于将图像从一个平面映射到另一个平面。它通过4个对应点之间的映射关系来变换图像,使得变换后的图像看起来像从不同角度观看。透视变换常用于图像…...

SpringMVC 框架核心知识点详解与实战

文章目录 引言一、响应数据和结果视图1.1 开发环境搭建1.2 返回值类型1.3 转发与重定向1.4 响应 json 数据1.5 静态资源处理 二、SpringMVC 实现文件上传2.1 准备工作2.2 传统方式文件上传 三、SpringMVC 的异常处理3.1 异常处理思路3.2 实现异常处理 四、SpringMVC 框架中的拦…...

Web前端开发:Grid 布局(网格布局)

一、Grid 是什么&#xff1f; Grid&#xff08;网格布局&#xff09; 是 CSS 中一种二维布局系统&#xff0c;可以同时控制行和列的排列方式。相比传统的浮动布局和 Flexbox&#xff08;一维布局&#xff09;&#xff0c;Grid 更适合构建复杂的网页结构&#xff08;比如仪表盘、…...

时间同步服务

时间同步:多主机协作工作时&#xff0c;各个主机的时间同步很重要&#xff0c;时间不一致会造成很多重要应用的故障&#xff0c;如:加密协议&#xff0c;日志&#xff0c;集群等&#xff0c;利用NTP(Network Time Protocol )协议使网络中的各个计算机 时间达到同步。目前NTP协议…...

全球化电商平台Azure云架构设计

业务需求&#xff1a; 支撑全球三大区域&#xff08;北美/欧洲/亚洲&#xff09;用户访问&#xff0c;延迟<100ms处理每秒50,000订单的峰值流量混合云架构整合本地ERP系统全年可用性99.99%满足GDPR和PCI DSS合规要求 建议在实施时使用Azure Landing Zone框架进行部署&…...

【SaaS多租架构】数据隔离与性能平衡

SaaS多租户架构:数据隔离与性能平衡 一、技术背景及发展二、技术特点:数据隔离与性能优化的双核心三、技术细节:实现路径与关键技术四、实际案例分析五、未来发展趋势结语一、技术背景及发展 多租户架构是云计算与SaaS(软件即服务)模式的核心技术,其核心目标是通过共享基…...

ARM介绍及其体系结构

目录 一、ARM介绍 &#xff08;一&#xff09;公司层面 &#xff08;二&#xff09;技术层面 &#xff08;三&#xff09;微处理器芯片或产品方面 二、ARM体系结构 &#xff08;一&#xff09;指令集 &#xff08;二&#xff09;寄存器组织 &#xff08;三&#xff09;存…...

3DGS-slam:splatam公式

配套讲解视频&#xff1a;https://www.bilibili.com/video/BV1ZgfBYdEpg/?spm_id_from333.1387.homepage.video_card.click&vd_sourced4c3e747c32049ddd90dcce17208f4e0 1、多维高斯分布公式: 对于多维&#xff08;多变量&#xff09;高斯分布&#xff0c;概率密度函数的…...

阿里云服务器深度科普:技术架构与未来图景

阿里云服务器深度科普&#xff1a;技术架构与未来图景 一、起源与演进&#xff1a;从虚拟化到云原生 阿里云服务器&#xff08;Elastic Compute Service, ECS&#xff09;诞生于阿里巴巴集团对云计算技术的早期探索。2009年&#xff0c;阿里云团队启动自主研发&#xff0c…...

物联网之对接MQTT最佳实践

小伙伴们&#xff0c;你们好呀&#xff0c;我是老寇&#xff0c;跟我一起学习对接MQTT 安装EMQX 采用docker-compose一键式&#xff0c;启动&#xff01;&#xff01;&#xff01; 还没有安装docker朋友&#xff0c;参考文章下面两篇文章 # Ubuntu20.04安装Docker # Cento…...

基于C++实现的深度学习(cnn/svm)分类器Demo

1. 项目简介 本项目是一个基于C实现的深度学习与传统机器学习结合的分类器Demo&#xff0c;主要流程为&#xff1a; 从CSV文件读取样本数据用卷积神经网络&#xff08;CNN&#xff09;进行特征提取用支持向量机&#xff08;SVM&#xff09;进行最终分类支持模型的保存与加载提…...

探寻适用工具:AI+3D 平台与工具的关键能力及选型考量 (AI+3D 产品经理笔记 S2E03)

引言&#xff1a;从技术光谱到落地选择的桥梁 在前两篇笔记中&#xff0c;我们首先&#xff08;S2E01&#xff09;宏观地探讨了 AI 生成 3D 技术兴起的驱动力、核心价值与面临的挑战&#xff0c;随后&#xff08;S2E02&#xff09;深入辨析了 Text-to-3D、Image-to-3D、NeRF 等…...

软考 系统架构设计师系列知识点 —— 黑盒测试与白盒测试(1)

本文内容参考&#xff1a; 黑盒测试和白盒测试详解-CSDN博客 软件测试中的各种覆盖&#xff08;Coverage&#xff09;详解-CSDN博客 特此致谢&#xff01; 零、概述 黑盒测试又名为功能测试&#xff0c;主要目的是发现软件设计的需求或者是软件设计规格说明书中的错误缺陷。…...

配变运行检测:算法与实现逻辑

在现代电网系统中&#xff0c;配电变压器&#xff08;简称配变&#xff09;作为电力分配的关键设备&#xff0c;其运行状态的稳定与否直接关系到整个电网的供电质量和可靠性。配变运行检测通过实时监测和分析配变的各项运行参数&#xff0c;及时发现潜在故障隐患&#xff0c;为…...

brpc 安装及使用

介绍 brpc&#xff08;Baidu Remote Procedure Call&#xff09;是百度开源的一个高性能、通用的 RPC&#xff08;远程过程调用&#xff09;框架&#xff0c;其目标是让使用者能轻松构建高并发、分布式的应用程序。以下从多个方面详细介绍brpc&#xff1a; 核心特性 高性能 …...

ComfyUI学习笔记,案例四:inpaint

背景 ComfyUI学习笔记&#xff0c;案例四&#xff1a;inpaint&#xff0c;就是将一张图抠掉一块区域后还原&#xff0c;或者在一个图上重绘某个区域&#xff0c;感觉还是比较简单的。 它包含四个案例&#xff1a; inpaint_example&#xff0c;正向提示词 closeup photograph …...

【C++】智能指针RALL实现shared_ptr

个人主页 &#xff1a; zxctscl 专栏 【C】、 【C语言】、 【Linux】、 【数据结构】、 【算法】 如有转载请先通知 文章目录 1. 为什么需要智能指针&#xff1f;2. 内存泄漏2.1 什么是内存泄漏&#xff0c;内存泄漏的危害2.2 内存泄漏分类&#xff08;了解&#xff09;2.3 如何…...