sqlites数据库读取,仅适用于数据少的数据库查询【改进版】

2024-05-23 22:12

本文主要是介绍sqlites数据库读取,仅适用于数据少的数据库查询【改进版】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

直接使用运行程序时加入数据库名和表明,直接完成查询

如:编译后的可执行程序为test,则在命令行输入

./test test.db name

代码如下:

#include <stdio.h>
#include <sqlite3.h>static int callback(void *data, int argc, char **argv, char **azColName) {int i;static int lines = 0;for (i = 0; i < argc; i++) {printf("[%d] %s = %s\n", i, azColName[i], argv[i] ? argv[i] : "NULL");}lines++;printf("第%d行数据查询完毕...\n", lines);return 0;
}int main(int argc, char *argv[]) {sqlite3 *db;char *errMsg = 0;int rc;// 检查参数数量if (argc < 3) {fprintf(stderr, "使用方法: %s 数据库文件 表名\n", argv[0]);return 1;}const char *db_filename = argv[1]; // 数据库文件名从命令行参数获取const char *table_name = argv[2];  // 表名从命令行参数获取// 打开数据库连接rc = sqlite3_open(db_filename, &db);if (rc) {fprintf(stderr, "无法打开数据库: %s\n", sqlite3_errmsg(db));return 0;} else {fprintf(stdout, "成功打开数据库\n");}// 构建SQL查询语句char *sql = malloc(strlen("SELECT * FROM ") + strlen(table_name) + 1);sprintf(sql, "SELECT * FROM %s;", table_name);// 查询指定表中的所有记录rc = sqlite3_exec(db, sql, callback, 0, &errMsg);if (rc != SQLITE_OK) {fprintf(stderr, "SQL错误: %s\n", errMsg);sqlite3_free(errMsg);} else {fprintf(stdout, "查询成功\n");}// 清理SQL语句free(sql);// 关闭数据库连接sqlite3_close(db);return 0;
}

 

这篇关于sqlites数据库读取,仅适用于数据少的数据库查询【改进版】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/996556

相关文章

SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)

《SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)》本文介绍了如何在SpringBoot项目中使用Jasypt对application.yml文件中的敏感信息(如数... 目录SpringBoot使用Jasypt对YML文件配置内容进行加密(例:数据库密码加密)前言一、J

javaScript在表单提交时获取表单数据的示例代码

《javaScript在表单提交时获取表单数据的示例代码》本文介绍了五种在JavaScript中获取表单数据的方法:使用FormData对象、手动提取表单数据、使用querySelector获取单个字... 方法 1:使用 FormData 对象FormData 是一个方便的内置对象,用于获取表单中的键值

Rust中的BoxT之堆上的数据与递归类型详解

《Rust中的BoxT之堆上的数据与递归类型详解》本文介绍了Rust中的BoxT类型,包括其在堆与栈之间的内存分配,性能优势,以及如何利用BoxT来实现递归类型和处理大小未知类型,通过BoxT,Rus... 目录1. Box<T> 的基础知识1.1 堆与栈的分工1.2 性能优势2.1 递归类型的问题2.2

Python使用Pandas对比两列数据取最大值的五种方法

《Python使用Pandas对比两列数据取最大值的五种方法》本文主要介绍使用Pandas对比两列数据取最大值的五种方法,包括使用max方法、apply方法结合lambda函数、函数、clip方法、w... 目录引言一、使用max方法二、使用apply方法结合lambda函数三、使用np.maximum函数

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

C#中读取XML文件的四种常用方法

《C#中读取XML文件的四种常用方法》Xml是Internet环境中跨平台的,依赖于内容的技术,是当前处理结构化文档信息的有力工具,下面我们就来看看C#中读取XML文件的方法都有哪些吧... 目录XML简介格式C#读取XML文件方法使用XmlDocument使用XmlTextReader/XmlTextWr

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

Redis的数据过期策略和数据淘汰策略

《Redis的数据过期策略和数据淘汰策略》本文主要介绍了Redis的数据过期策略和数据淘汰策略,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录一、数据过期策略1、惰性删除2、定期删除二、数据淘汰策略1、数据淘汰策略概念2、8种数据淘汰策略