gitbase 是mysql server 的一个实现(主要是用来分析git仓库代码),但是里面好多功能可能并不是很强大(sql 的限制)
我们可以通过singer 的tap-mysql 将数据抽取到标准的pg 数据库,可以方便的使用pg 的好多函数

参考使用

mysql-postgresql 的可以参考 https://www.cnblogs.com/rongfengliang/p/10239118.html
具体的转换很简单,主要是说明几个gitbase 上的缺陷以及怎么解决
实际的代码可以参考https://github.com/rongfengliang/gitbase2postgresql

同步问题

  • string length
    默认singer 是通过获取数据库表的schema 进行类型长度确定的,但是singer对于gtibase string 显示的是是0.所以进行处理会有问题
  • 解决方法

    属于临时解决了,修改singer 关于string 类型处理

  elif data_type in STRING_TYPES:
result.type = ['null', 'string']
# result.maxLength = c.character_maximum_length
git clone https://github.com/rongfengliang/tap-mysql.git
pip install -e tap-mysql

说明

因为singer 推荐的方式是venv 安装,所以tap 以及target 最好是使用venv 解决,不然会有各种问题(singer 是基于pipe 的处理模型)

参考资料

https://github.com/rongfengliang/tap-mysql
https://github.com/rongfengliang/tap-mysql
https://github.com/rongfengliang/gitbase2postgresql

 
 
 
 

最新文章

  1. 4.Struts2转向类型详解
  2. Robotium ant 报错Unable to find instrumentation info for: ComponentInfo{project/android.test.InstrumentationTestRunner}
  3. python 代码片段25
  4. jQuery中append()与appendTo()方法区别
  5. Android 获取网络状态
  6. 转载------------------关于android的一些技巧
  7. Java -- Thread中start和run方法的区别
  8. Angularjs2——TypeScript学习网站
  9. vue echarts 遇到的bug之一 无法渲染的问题
  10. JVM菜鸟进阶高手之路七(tomcat调优以及tomcat7、8性能对比)
  11. on duplicate key update简单使用
  12. HBase RegionServer Splitting 流程
  13. mysql 压缩版配置
  14. 数据库的OLE字段写入长二进制文件
  15. KD-树(上)
  16. 深入flask中的request
  17. python自动化运维之路~DAY7
  18. js变量按照存储方式区分,有哪些类型,并表述其特点
  19. C# web服务器被webbench攻击及目现采用的防御措施
  20. Angular 4 路由介绍

热门文章

  1. vue-cli中轮播图vue-awesome-swiper使用方法
  2. Java核心技术梳理-IO
  3. sqlserver安装教程
  4. 2019 4399java面试笔试题 (含面试题解析)
  5. 【开发笔记】- Java中关于HashMap的元素遍历的顺序问题
  6. 解决for循环中异步处理(异步变同步)
  7. Android canvas.save()与canvas.restore()的使用总结
  8. idea2018.3导入grails项目,无法正常使用问题解决
  9. Docker05-容器
  10. 关于MySQL数据库编码修复相关问题