sqlite_fdw 使用
admin
2023-06-04 16:21:25
0

Postgresql 提供了外键表的功能,sqlite_fdw唯一的遗憾是只能select,希望github上能够尽快更新吧!

下面我把sqlite_fdw 如何使用介绍下!

1、下载sqlite_fdw 软件包:

git clone https://github.com/gleu/sqlite_fdw 或者下载 .ZIP压缩文件

make


[postgres@mxl sqlite_fdw]$ make

gcc -Wall -Wmissing-prototypes -Wpointer-arith -Wdeclaration-after-statement -Wendif-labels -Wmissing-format-attribute -Wformat-security -fno-strict-aliasing -fwrapv -O2 -fpic -I. -I./ -I/usr/local/pgsql/include/server -I/usr/local/pgsql/include/internal -D_GNU_SOURCE -I/usr/include/libxml2   -c -o src/sqlite_fdw.o src/sqlite_fdw.c

gcc -Wall -Wmissing-prototypes -Wpointer-arith -Wdeclaration-after-statement -Wendif-labels -Wmissing-format-attribute -Wformat-security -fno-strict-aliasing -fwrapv -O2 -fpic -shared -o sqlite_fdw.so src/sqlite_fdw.o -L/usr/local/pgsql/lib -Wl,--as-needed -Wl,-rpath,'/usr/local/pgsql/lib',--enable-new-dtags  -lsqlite3 


make install 


[root@mxl sqlite_fdw]# make install

/bin/mkdir -p '/usr/local/pgsql/lib'

/bin/mkdir -p '/usr/local/pgsql/share/extension'

/bin/mkdir -p '/usr/local/pgsql/share/extension'

/bin/mkdir -p '/usr/local/pgsql/share/doc/extension'

/usr/bin/install -c -m 755  sqlite_fdw.so '/usr/local/pgsql/lib/sqlite_fdw.so'

/usr/bin/install -c -m 644 sqlite_fdw.control '/usr/local/pgsql/share/extension/'

/usr/bin/install -c -m 644 sql/sqlite_fdw--0.0.1.sql '/usr/local/pgsql/share/extension/'

/usr/bin/install -c -m 644 doc/sqlite_fdw.md '/usr/local/pgsql/share/doc/extension/'


2、在数据库引用sqlite_fdw


postgres=# CREATE EXTENSION sqlite_fdw;

CREATE EXTENSION

postgres=# \dx ;

                                     List of installed extensions

        Name        | Version |   Schema   |                        Description                        

--------------------+---------+------------+-----------------------------------------------------------

 pg_stat_statements | 1.2     | public     | track execution statistics of all SQL statements executed

 plpgsql            | 1.0     | pg_catalog | PL/pgSQL procedural language

 sqlite_fdw         | 0.0.1   | public     | SQLite Foreign Data Wrapper

 uuid-ossp          | 1.0     | public     | generate universally unique identifiers (UUIDs)

(4 rows)


3、创建一个fdw的server


CREATE SERVER sqlite_server  FOREIGN DATA WRAPPER sqlite_fdw  OPTIONS (database '/tmp/localdb.sqlite');


4、创建外键表


CREATE FOREIGN TABLE fdwuserrole(userid integer,roleid ingeter)  SERVER sqlite_server  OPTIONS (table 'userrole');


5、查看外键表server


postgres=# \des

             List of foreign servers

     Name      |  Owner   | Foreign-data wrapper 

---------------+----------+----------------------

 sqlite_server | postgres | sqlite_fdw

(1 row)


6、删除外键表


drop FOREIGN table fdwuserrole;


问题:1

src/sqlite_fdw.c:37:21: error: sqlite3.h: No such file or directory

make 的时候提示解析不了sqlite头文件

rpm -Uvh http://www6.atomicorp.com/channels/atomic/centos/6/x86_64/RPMS/atomic-release-1.0-21.el6.art.noarch.rpm 

yum update

yum sqlite-devel install -y


问题:2

安装sqlite_fdw的时候需要使用postgres 的pg_config 所以需要把postgres 的环境变量在root 添加一下


相关内容

热门资讯

伊朗外长与巴陆军参谋长举行二次... 总台记者23日获悉,伊朗外交部长阿拉格齐与巴基斯坦陆军参谋长穆尼尔开始举行第二次会晤。双方昨晚已举行...
Mythos首个报告出炉:全球... 新智元报道 A厂的玻璃翼计划首战告捷,Mythos 30天内就挖出1万个致命漏洞,甚至拦截了150万...
英特尔Hammer Lake处... IT之家 5 月 23 日消息,爆料者 @jaykihn0 上个月提到,英特尔已放弃为“Nova L...
评论丨当答案唾手可得,我们为何... 为何需要“科学大讲堂”?以创新致未来,就是城市的答案 何为科学?何以创新?在全国科技活动周来临之际...
对话王小川:离开通用人工智能的... “如果没有转型,继续走主流道路,你也会有同等程度的焦虑。”王小川说,这次转型,让他真正回归到从创业第...
新华社文化随笔:文化,新质生产... 新华社深圳5月22日电 题:新华社文化随笔:文化,新质生产力的“隐藏算法” 新华社记者王子铭 5月2...
闻泰科技:安世荷兰声称公司回避... 闻泰科技股份有限公司声明近日,安世半导体(Nexperia B.V.,“安世荷兰”)发布公开声明,声...
较真碰硬!国务院调查组将调查山... 针对山西通洲集团留神峪煤矿瓦斯爆炸事故,国务院事故调查组将较真碰硬开展事故调查,查清查透事故原因,查...
“只要有一丝希望,我们就会尽百... 5月22日19时29分,山西长治市沁源县山西通洲集团留神峪煤业有限公司井下发生瓦斯爆炸事故,200多...
陇东地区滑坡泥石流风险高,甘肃... 甘肃省自然资源厅、甘肃省气象局于2026年5月23日17时30分联合发布地质灾害气象风险预警:5月2...