PostGIS mysql_fdw使用(Linux)
##前文讲了mysql_fdw的安装,此文主要讲mysql_fdw的配置以及使用
##附上前文链接:https://www.cnblogs.com/giser-s/p/11208803.html
背景需求
业务平台数据库用的是MySQL,地图引擎用的是ArcGIS,ArcSDE不支持MySQL作为空间数据库,因此我们将空间数据库搭在了PostgreSQL上。
考虑到业务信息与空间信息没法完全划分出界限(即不排除Mysql会存入有待分析的空间数据,PostgreSQL需要将空间数据推到业务端),所以想将两库做同步,并能在ArcMap中进行关联。
讨论了多套方案:有通过接口进行同步;定时服务同步;以及这里提及的MySQL_fdw外部数据封装包。这里记录mysql_fdw的研究成果。
前期准备
因为最终目的需要使ArcSDE能连接库,因此首先还是要在ArcMap中创建企业级空间数据库,不会的参考之前博文链接(方法二):https://www.cnblogs.com/giser-s/p/10345285.html
配置使用
1.资源约定
##先做约定,后面示例用的资源如下
##用户:sde
##空间数据库名称:bkrq
##空间数据表名称:user_role
##Server名称:bkrq_server
##Mysql数据源:
地址:10.19.147.**
账号/密码:root / pwd123
数据库:bkrq
表名:user_role
2.超级账号登陆bkrq库
[root@localhost ~]# su - postgres
-bash-4.2$ psql
postgres=# \c bkrq

3.创建扩展
bkrq=# CREATE EXTENSION mysql_fdw;

4.创建外部服务器Server
#超级用户执行(这里用postgres)
#替换成mysql的真实IP和端口
bkrq=# CREATE SERVER bkrq_server
FOREIGN DATA WRAPPER mysql_fdw
OPTIONS (host '10.19.147.**', port '3306');

5.创建映射Mapping
#超级用户执行(这里用postgres)
#pguser 替换成需要查询MYSQL表的PG数据库普通用户
bkrq=# CREATE USER MAPPING FOR sde
SERVER bkrq_server
OPTIONS (username 'root', password 'pwd123');

6.赋权限
#超级用户执行(这里用postgres)
#pguser 替换成需要查询MYSQL表的PG数据库普通用户
#这里sde默认创建时已经是超级用户,这步非必要
bkrq=# grant usage ON FOREIGN SERVER bkrq_server to sde;

7.切换用户/库
#普通用户执行(切换到sde用户,库bkrq不变)
#创建与mysql结构一样的表, 参数中指定表名和库名
bkrq=# \c bkrq sde;

8.创建外部表
#普通用户执行(sde用户,bkrq库)
#创建外部表(与Mysql同步表,表名、表结构保持一致)
######建表时标红处为mysql表,注意区分大小写#######
bkrq=# CREATE FOREIGN TABLE USER_ROLE(
ROLE_ID int,
ROLE_NAME text,
ROLE_TXT text,
MENU_ID text)
SERVER bkrq_server
OPTIONS (dbname 'bkrq', table_name 'USER_ROLE');

9.插入测试
#普通用户执行(sde用户,bkrq库)
#支持写MYSQL远程表, 如果要回收写权限,建议使用超级用户建foreign table,并且将select权限赋予给普通用户。
bkrq=# INSERT INTO user_role values (1, '2',’3’,’4’);
10.Mysql_fdw结束
查看mysql表与pg表,刚才插入的数据是否执行成功即可。至此,Mysql_fdw的配置和使用结束。
但是,因为ArcGIS的介入,配置还没有结束!
fdw同步的数据都会存在外部数据表中,与一般的普通表不同(具体区别自行百度),ArcSDE不识别,ArcMap里编辑的就无法同步到MySQL,无奈只能想到用触发器的方式实现。
#外部数据表在pgAdmin中查看方法。文件--选项--浏览器--外部数据表。

#彩蛋:这里搜到foreign_table_exposer.fdw,这个扩展的介绍说明就是将外部表转为普通表,但好像版本比较高,我9.4编译失败,大家可以试试

10.新建表
#
bkrq=# CREATE TABLE tab_act_user_role(ROLE_ID int, ROLE_NAME text, ROLE_TXT text, MENU_ID text);
11.新建函数/过程
#新增auditlogfunc的函数过程,实现触发器触发时,更新user_role外部表
CREATE OR REPLACE FUNCTION auditlogfunc() RETURNS TRIGGER AS $example_table$
BEGIN
if (TG_OP = 'DELETE') then
delete from user_role where ROLE_ID = OLD.ROLE_ID;
return old;
elsif (TG_OP = 'UPDATE') then
update user_role set ROLE_NAME = new.ROLE_NAME , ROLE_TXT = new.ROLE_TXT , MENU_ID = new.MENU_ID where ROLE_ID = OLD.ROLE_ID;
return new;
elsif (TG_OP = 'INSERT') then
insert into user_role select new.*;
return new;
end if;
return null;
END;
$example_table$ LANGUAGE plpgsql;
12.新建触发器
#为内部表tab_act_user_role添加增删改查的触发器
CREATE TRIGGER example_trigger AFTER INSERT or UPDATE or DELETE ON tab_act_user_role
FOR EACH ROW EXECUTE PROCEDURE auditlogfunc();
13.测试
insert into tab_act_user_role values (111112,'2','2','2');
delete from tab_act_user_role where role_id = 111112;
update tab_act_user_role set role_name ='2222' where role_id = '111111';
#操作tab_act_user_role表时,如果user_role外部表数据有更新,则表示成功!
select * from user_role;
#遇到过下面的错误,在建表的时候Mysql的表一定要设主键

13.结束
完结撒花
foreign_table_exposer
PostGIS mysql_fdw使用(Linux)的更多相关文章
- PostGIS mysql_fdw安装(Linux)
##本人在安装过程中,可能因为系统环境因素或是其他原因,参考网上的文章没有一篇是非常顺利的,所以自己总结一下. ##安装过程中非常坎坷,有些地方反复了好几次,弄的有点模糊,但模糊的地方在文中我会指出. ...
- PostGIS mysql_fdw操作日志(留观)
#####Linux终端操作命令记录,留做自己后面研究,绿色部分为成功部分 错误: 服务器"mysql_server" 不存在postgres=# create user mapp ...
- Linux 驱动开发
linux驱动开发总结(一) 基础性总结 1, linux驱动一般分为3大类: * 字符设备 * 块设备 * 网络设备 2, 开发环境构建: * 交叉工具链构建 * NFS和tftp服务器安装 3, ...
- [zz] 安装PostGIS(Linux篇)
0.安装PostgreSQL数据库 参考安装PostgreSQL数据库(Linux篇). 1.安装proj4 #tar zxvf proj-4.8.0.tar.gz#cd proj-4.8.0#./c ...
- PostGIS 安装教程(Linux)(二)
##接上篇,上篇讲述了Postgresql的安装,此篇介绍postgis的安装 ##附上上篇链接:https://www.cnblogs.com/giser-s/p/11195419.html 二.安 ...
- PostGIS 安装教程(Linux)(一)
##本文分两部分,第一部分讲linux下postgresql的安装,第二部分讲postgis的安装 ##感谢作者:https://www.linuxidc.com/Linux/2017-10/1475 ...
- Linux 平台PostGIS安装
1.前提条件: postgresql 9.6.1 已经通过源码方式安装完成并可成功运行. 2. other OS packets OS: CentOS 6.4 X64 X64: libxml2-dev ...
- PostgreSQL9.1 with PostGIS 2.1.4 for mapping coordinates on linux/ubuntu 已经打包成deb 可下载
For location based service, I try to use postgresql with postgis. You can download postgis from here ...
- PostGIS 使用Mysql_fdw同步ArcGIS填坑记录
##实现Mysql_fdw数据同步过程中,出现过很多坑,开此贴记录一下 1.触发器记录 这里insert的时候,采用过insert into f_pressureline select new.*,出 ...
随机推荐
- 用Docker搭建一个支持https的nginx代理服务
用Docker搭建一个支持https的nginx代理服务 说明:本文所提的服务只是作者平常测试使用,可能含有未知bug或不成熟的解决方案,仅供参考,请不要用于正式环境,当然,使用过程中有任何问题欢迎提 ...
- typescript 入门教程二
ts中面向对象成员修饰符:public , private , protexted(ts官方网站:ts) 在ts中,默认的成员修饰符就是public public:是表示是公开的,在任何地方,都可以调 ...
- java.sql.SQLException: Access denied for user 'root'@'localhost' (using password: NO)报错
今天用spring整合mybatis的时候,报了这个错误.去网上查了一下,网上大多数都是用户权限问题,但是我用SQLyog视图使用root用户crud没有问题,排除了是权限的问题,后面发现是idea提 ...
- Java多线程编程(五)定时器Timer
一.定时器Timer的使用 在JDK库中Timer类主要负责计划任务的功能,也就是在指定的时间开始执行某一个任务.Timer类的主要作用就是设置计划任务,但封装任务的类确实TimerTask类,执行计 ...
- 数据结构(二十七)Huffman树和Huffman编码
Huffman树是一种在编码技术方面得到广泛应用的二叉树,它也是一种最优二叉树. 一.霍夫曼树的基本概念 1.结点的路径和结点的路径长度:结点间的路径是指从一个结点到另一个结点所经历的结点和分支序列. ...
- 谁说搞Java的不能玩机器学习?
简介 机器学习在全球范围内越来越受欢迎和使用. 它已经彻底改变了某些应用程序的构建方式,并且可能会继续成为我们日常生活中一个巨大的(并且正在增加的)部分. 没有什么包装且机器学习并不简单. 它对许多人 ...
- 微信授权就是这个原理,Spring Cloud OAuth2 授权码模式
上一篇文章Spring Cloud OAuth2 实现单点登录介绍了使用 password 模式进行身份认证和单点登录.本篇介绍 Spring Cloud OAuth2 的另外一种授权模式-授权码模式 ...
- pythonpip的基本使用
pip 是 Python 包管理工具,该工具提供了对Python 包的查找.下载.安装.卸载的功能.目前如果你在 python.org 下载最新版本的安装包,则是已经自带了该工具.Python 2.7 ...
- 重磅!微软发布 Visual Studio Online:Web 版 VS Code + 云开发环境
北京时间 2019 年 11 月 4 日,在 Microsoft Ignite 2019 大会上,微软正式发布了 Visual Studio Online (VS Online)公开预览版! 如今发布 ...
- tracert/traceroute原理
一.路由追踪程序traceroute/tracert Traceroute是Linux和Mac OS等系统默认提供的路由追踪小程序,Tracert是Windows系统默认提供的路由追踪小程序.二者的功 ...