数据库对内存的存储与读取
#include "mainwindow.h"
#include <QApplication>
#include <QtSql/QSqlDatabase>
#include <QtDebug>
#include <QtSql/qsqlquery.h>
#include <QByteArray>
#include <QTextCodec>
#include <QSqlError>
#define MAX_BUFFER_SIZE (200)
typedef unsigned char UCHAR8;
typedef UCHAR8 Message[MAX_BUFFER_SIZE];
typedef struct _Buffer
{
Message message;
int length;
}Buffer;
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
QTextCodec::setCodecForLocale(QTextCodec::codecForName("UTF-8"));
QSqlDatabase db = QSqlDatabase::addDatabase("QOCI");
db.setHostName("localhost");
db.setUserName("SYSTEM");
db.setPassword("FuxinOracle2014");
db.setPort(1523);
db.setDatabaseName("orcl");
if(db.open())
qDebug() << "open";
QSqlQuery q(db);
_Buffer buf;
memset(&buf, 0, sizeof(_Buffer));
buf.length = 1400;
for(int i = 0; i < 10; i++)
buf.message[i] = i + 'a';
for(int i = 10; i < 20; i++)
buf.message[i] = '\0';
for(int i = 20; i < 30; i++)
buf.message[i] = i + 'a';
for(int i = 30; i < 40; i++)
buf.message[i] = ',';
for(int i = 40; i < 50; i++)
buf.message[i] = 'a' - i;
QByteArray by((char*)buf.message, 1400);
if(q.prepare("insert into ssss values(?)"))
{
q.bindValue(0,by);
if(q.exec())
qDebug() << "sus";
else
qDebug() << q.lastError();
}
q.exec("select * from ssss");
while(q.next())
{
QByteArray by2 = q.value(0).toByteArray();
;
}
return a.exec();
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人