开源嵌入式数组引擎TileDB的简单使用

TileDB 是C++编写的存储和访问通用多维数组引擎,它的官方Github网站https://github.1git.de/TileDB-Inc/TileDB

1.下载源代码和二进制库

源代码https://github.1git.de/TileDB-Inc/TileDB/archive/refs/tags/2.28.1.tar.gz

选择符合你的机器CPU架构和操作系统的库

二进制库https://github.1git.de/TileDB-Inc/TileDB/releases/download/2.28.1/tiledb-linux-arm64-2.28.1-d648231.tar.gz

2.从源代码编译库

一般不需要,因为https://github.1git.de/TileDB-Inc/TileDB/releases/expanded_assets/2.28.1已经提供了大多数平台的现成库

如果需要,按照以下步骤

tar xf 2.28.1.tar.gz

然后按照解压的BUILDING_FROM_SOURCE.md文件提示的步骤,大致是

bash 复制代码
mkdir build
cd build
../bootstrap <flags>
# Or use CMake directly instead of bootstrap:
# cmake <flags> ..

make -j <nprocs>

make install

3.编译源代码中的例子

参照解压的USAGE.md文件提示的步骤,

定位到目录examples/c_api

以as_built.c为例,编译命令行如下,这里-I /shujv/par/tiledb/include-L /shujv/par/tiledb/lib分别是tiledb头文件和动态库的位置

bash 复制代码
gcc as_built.c -o as_built -ltiledb -I /shujv/par/tiledb/include -L /shujv/par/tiledb/lib

注意对系统c/c++库版本有要求,如果不满足,将报错

bash 复制代码
/shujv/par/tiledb/lib/libtiledb.so:对'std::thread::_State::~_State()@GLIBCXX_3.4.22'未定义的引用
/shujv/par/tiledb/lib/libtiledb.so:对'__cxa_init_primary_exception@CXXABI_1.3.11'未定义的引用
/shujv/par/tiledb/lib/libtiledb.so:对'fcntl64@GLIBC_2.28'未定义的引用
/shujv/par/tiledb/lib/libtiledb.so:对'getentropy@GLIBC_2.25'未定义的引用
/shujv/par/tiledb/lib/libtiledb.so:对'logf@GLIBC_2.27'未定义的引用
/shujv/par/tiledb/lib/libtiledb.so:对'operator new(unsigned long, std::align_val_t)@CXXABI_1.3.11'未定义的引用
/shujv/par/tiledb/lib/libtiledb.so:对'typeinfo for std::thread::_State@GLIBCXX_3.4.22'未定义的引用

等等

我切换到gcc 14.2 docker镜像,编译就不报错了,注意要设置LD_LIBRARY_PATH环境变量加入tiledb动态库的位置

bash 复制代码
gcc as_built.c -o as_built -ltiledb -I  /par/tiledb/include -L /par/tiledb/lib
root@66d4e20ec1d7:/par/TileDB-main/examples/c_api# export LD_LIBRARY_PATH="/par/tiledb/lib:$LD_LIBRARY_PATH"
root@66d4e20ec1d7:/par/TileDB-main/examples/c_api# ./as_built
{
  "as_built": {
    "parameters": {
      "storage_backends": {
        "azure": {
          "enabled": true
        },
        "gcs": {
          "enabled": true
        },
        "s3": {
          "enabled": true
        }
      },
      "support": {
        "serialization": {
          "enabled": true
        }
      }
    }
  }

再编译query_condition_dense.c,能实现对数组条件查询,是不是有点像数据库

bash 复制代码
gcc query_condition_dense.c -o qcd -ltiledb -I  /par/tiledb/include -L /par/tiledb/lib
root@66d4e20ec1d7:/par/TileDB-main/examples/c_api# ./qcd   
Printing the entire array...
{null, alice, 0, 4.1}
{2, bob, 0, 3.4}
{null, craig, 0, 5.6}
{4, dave, 0, 3.7}
{null, erin, 0, 2.3}
{6, frank, 0, 1.7}
{null, grace, 1, 3.8}
{8, heidi, 2, 4.9}
{null, ivan, 3, 3.2}
{10, judy, 4, 3.1}

Running read query with query condition `a = null`...
{null, alice, 0, 4.1}
{null, craig, 0, 5.6}
{null, erin, 0, 2.3}
{null, grace, 1, 3.8}
{null, ivan, 3, 3.2}

Running read query with query condition `b < "eve"`...
{null, alice, 0, 4.1}
{2, bob, 0, 3.4}
{null, craig, 0, 5.6}
{4, dave, 0, 3.7}
{null, erin, 0, 2.3}

Running read query with query condition `c >= 1`...
{null, grace, 1, 3.8}
{8, heidi, 2, 4.9}
{null, ivan, 3, 3.2}
{10, judy, 4, 3.1}

Running read query with query condition `3.0f <= d AND d <= 4.0f`...
{2, bob, 0, 3.4}
{4, dave, 0, 3.7}
{null, grace, 1, 3.8}
{null, ivan, 3, 3.2}
{10, judy, 4, 3.1}

Running read query with query condition `3.0f <= d AND d <= 4.0f AND a != null AND b < "eve"`...
{2, bob, 0, 3.4}
{4, dave, 0, 3.7}
相关推荐
2501_941805931 天前
在大阪智能零售场景中构建支付实时处理与高并发顾客行为分析平台的工程设计实践经验分享
数据库
你怎么知道我是队长1 天前
C语言---枚举变量
c语言·开发语言
李慕婉学姐1 天前
【开题答辩过程】以《基于JAVA的校园即时配送系统的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·开发语言·数据库
珠海西格电力1 天前
零碳园区有哪些政策支持?
大数据·数据库·人工智能·物联网·能源
数据大魔方1 天前
【期货量化实战】日内动量策略:顺势而为的短线交易法(Python源码)
开发语言·数据库·python·mysql·算法·github·程序员创富
fpcc1 天前
C++编程实践——链式调用的实践
c++
Chasing Aurora1 天前
数据库连接+查询优化
数据库·sql·mysql·prompt·约束
倔强的石头_1 天前
【金仓数据库】ksql 指南(六)—— 创建与管理用户和权限(KingbaseES 安全控制核心)
数据库
小熊officer1 天前
Python字符串
开发语言·数据库·python
渐暖°1 天前
JDBC直连ORACLE进行查询
数据库·oracle