leveldb 键值数据库

2024-04-20 22:52
文章标签 数据库 键值 leveldb

本文主要是介绍leveldb 键值数据库,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

#git clone --recurse-submodules https://github.com/google/leveldb.git
拉取子模块 及第三方库#mkdir -p build && cd build
#cmake -DCMAKE_BUILD_TYPE=Releas .. && make

测试demo

#include <assert.h>
#include <string.h>
#include <leveldb/db.h>
#include <iostream>
//isSync 1:写入时直接写入磁盘,0:写入时在内存delete db 才会写入磁盘
void writevalue(leveldb::DB *db,std::string keyname,std::string value,bool isSync){leveldb::Options options;leveldb::WriteOptions write_options;write_options.sync = isSync;leveldb::Status status=db->Put(write_options, keyname,value);if(status.ok())std::cout<<"write key "<<keyname<<" ok\n";elsestd::cout<<"write key "<<keyname<<" failed "<<status.ToString()<<"\n";
}void deleltevalue(leveldb::DB *db,std::string keyname){leveldb::Options options;leveldb::Status status=db->Delete(leveldb::WriteOptions(), keyname);if(status.ok())std::cout<<"delete key "<<keyname<<" ok\n";elsestd::cout<<"delete key "<<keyname<<" failed "<<status.ToString()<<"\n";
}void readValue(leveldb::DB *db,std::string keyname){std::string keyvalue;leveldb::Options options;leveldb::Status status=db->Get(leveldb::ReadOptions(), keyname,&keyvalue);if(status.ok())std::cout<<"get key "<<keyname<<" value:"<<keyvalue<<"\n";elsestd::cout<<"get key "<<keyname<<" failed "<<status.ToString()<<"\n";
}int main(){leveldb::DB* db;leveldb::Options options;options.create_if_missing = true;leveldb::Status status = leveldb::DB::Open(options,"./testdb3", &db);assert(status.ok());writevalue(db,"keyname1","keyvalue1",true);readValue(db,"keyname1");deleltevalue(db,"keyname1");readValue(db,"keyname1");writevalue(db,"keyname2","keyvalue2",true);writevalue(db,"keyname3","keyvalue3",true);writevalue(db,"keyname4","keyvalue4",true);leveldb::Iterator *it = db->NewIterator(leveldb::ReadOptions());//正序打印内容for (it->SeekToFirst(); it->Valid(); it->Next()) {std::cout << it->key().ToString() << ":" << it->value().ToString() << std::endl;}//反序打印内容for (it->SeekToLast(); it->Valid(); it->Prev()) {std::cout << it->key().ToString() << ":" << it->value().ToString() << std::endl;}delete db;return 0;
}

打印

write key keyname1 ok
get key keyname1 value:keyvalue1
delete key keyname1 ok
get key keyname1 failed NotFound: 
write key keyname2 ok
write key keyname3 ok
write key keyname4 ok
keyname2:keyvalue2
keyname3:keyvalue3
keyname4:keyvalue4
keyname4:keyvalue4
keyname3:keyvalue3
keyname2:keyvalue2

参考

【存储引擎】LevelDB 编译使用_level db cmake-CSDN博客

这篇关于leveldb 键值数据库的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

MySQL 数据库表操作完全指南:创建、读取、更新与删除实战

《MySQL数据库表操作完全指南:创建、读取、更新与删除实战》本文系统讲解MySQL表的增删查改(CURD)操作,涵盖创建、更新、查询、删除及插入查询结果,也是贯穿各类项目开发全流程的基础数据交互原... 目录mysql系列前言一、Create(创建)并插入数据1.1 单行数据 + 全列插入1.2 多行数据

MySQL 数据库表与查询操作实战案例

《MySQL数据库表与查询操作实战案例》本文将通过实际案例,详细介绍MySQL中数据库表的设计、数据插入以及常用的查询操作,帮助初学者快速上手,感兴趣的朋友跟随小编一起看看吧... 目录mysql 数据库表操作与查询实战案例项目一:产品相关数据库设计与创建一、数据库及表结构设计二、数据库与表的创建项目二:员

MybatisPlus中removeById删除数据库未变解决方案

《MybatisPlus中removeById删除数据库未变解决方案》MyBatisPlus中,removeById需实体类标注@TableId注解以识别数据库主键,若字段名不一致,应通过value属... 目录MyBATisPlus中removeBypythonId删除数据库未变removeById(Se

在 Spring Boot 中连接 MySQL 数据库的详细步骤

《在SpringBoot中连接MySQL数据库的详细步骤》本文介绍了SpringBoot连接MySQL数据库的流程,添加依赖、配置连接信息、创建实体类与仓库接口,通过自动配置实现数据库操作,... 目录一、添加依赖二、配置数据库连接三、创建实体类四、创建仓库接口五、创建服务类六、创建控制器七、运行应用程序八

Oracle数据库定时备份脚本方式(Linux)

《Oracle数据库定时备份脚本方式(Linux)》文章介绍Oracle数据库自动备份方案,包含主机备份传输与备机解压导入流程,强调需提前全量删除原库数据避免报错,并需配置无密传输、定时任务及验证脚本... 目录说明主机脚本备机上自动导库脚本整个自动备份oracle数据库的过程(建议全程用root用户)总结

虚拟机Centos7安装MySQL数据库实践

《虚拟机Centos7安装MySQL数据库实践》用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止Net... 目录安装mysql数据库下载wget命令下载MySQL安装包安装MySQL安装MySQL服务安装完成

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.