编译pg_duckdb步骤
1. 要求cmake的版本要高于3.17,可以通过下载最新的cmake的程序,然后设置.bash_profile的PATH环境变量,将最新的cmake的bin目录放到PATH环境变量的最前面
2. g++的版本要支持c++17标准,否则会报 error ‘invoke_result in namespace ‘std does not name a template type 错误
2. 下载pg_duckdb的源码GitHub - duckdb/pg_duckdb: DuckDB-powered Postgres for high performance apps & analytics.
注意下载解压后,里面的third_party目录是空的,本来make的时候会执行
git submodule update --init --recursive 来下载所需要的duckdb的源码到该目录中,但是实际使用貌似不行,所以需要到github中直接下载duckdb的源码并放到third_party中
3. 第一次执行的时候发现报下面的错误,可以通过
git init命令解决
make
git submodule update --init --recursive
fatal: 不是一个 git 仓库(或者任何父目录):.git
make: *** [Makefile:109:.git/modules/third_party/duckdb/HEAD] 错误 128
4.添加postgresql 的bin目录到PATH环境变量中,因为编译过程要执行pg_config命令,获取到server/include 目录
5. 安装lz4-devel,否则编译完后无法链接。
5. make过程中还会执行git clone命令,国内访问git网站时灵时不灵,如果报443超时错误可以多执行几次。