0

0

在 Postgres 里克隆一个 MongoDB

php中文网

php中文网

发布时间:2016-06-07 16:48:02

|

1136人浏览过

|

来源于php中文网

原创

Postgres 社区在 NoSQL采取一系列动作后并没有坐以待毙. Postgres一直在进步: 集成了 JSON和 PLV8. PLV8 引入了 V8 Javascript引

世上本没有路,走的人多了也就成了路。为什么不能在 postgres上建一个mongodb 呢?

Postgres 社区在 NoSQL采取一系列动作后并没有坐以待毙. Postgres一直在进步: 集成了 JSON和 PLV8. PLV8 引入了 V8 Javascript引擎 . 操作 JSON也更简单了 (需要验证).

开始前需要做的准备:

  • Postgres 9.2+ (as of this blog entry, 9.2 is in beta) -

  • V8 - https://github.com/v8/v8

  • PLV8 -

  • MongoDB的最低级别是集合. 集合可以用表来表示:

        CREATE TABLE some_collection (
          some_collection_id SERIAL NOT NULL PRIMARY KEY,
          data JSON
        );

    字符型的JSON 被保存在 Postgres 表里,简单易行 (现在看是这样).

    下面实现自动创建集合. 保存在集合表里:

        CREATE TABLE collection (
          collection_id SERIAL NOT NULL PRIMARY KEY,
          name VARCHAR
        );

        -- make sure the name is unique
        CREATE UNIQUE INDEX idx_collection_constraint ON collection (name);

    一旦表建好了,,就可以通过存储过程自动创建集合.  方法就是先建表,然后插入建表序列.

        CREATE OR REPLACE FUNCTION create_collection(collection varchar) RETURNS
        boolean AS $$
          var plan1 = plv8.prepare('INSERT INTO collection (name) VALUES ($1)', [ 'varchar' ]);
          var plan2 = plv8.prepare('CREATE TABLE col_' + collection +
            ' (col_' + collection + '_id INT NOT NULL PRIMARY KEY, data JSON)');
          var plan3 = plv8.prepare('CREATE SEQUENCE seq_col_' + collection);
       
          var ret;
       
          try {
            plv8.subtransaction(function () {
              plan1.execute([ collection ]);
              plan2.execute([ ]);
              plan3.execute([ ]);
         
              ret = true;
            });
          } catch (err) {
            ret = false;
          }
       
          plan1.free();
          plan2.free();
          plan3.free();
       
          return ret;
        $$ LANGUAGE plv8 IMMUTABLE STRICT;

    有了存储过程,就方便多了:

        SELECT create_collection('my_collection');

    解决了集合存储的问题,下面看看MongoDB数据解析. MongoDB 通过点式注解方法操作完成这一动作:

    LongShot
    LongShot

    LongShot 是一款 AI 写作助手,可帮助您生成针对搜索引擎优化的内容博客。

    下载

        CREATE OR REPLACE FUNCTION find_in_obj(data json, key varchar) RETURNS
        VARCHAR AS $$
          var obj = JSON.parse(data);
          var parts = key.split('.');
       
          var part = parts.shift();
          while (part && (obj = obj[part]) !== undefined) {
            part = parts.shift();
          }
       
          // this will either be the value, or undefined
          return obj;
        $$ LANGUAGE plv8 STRICT;

    上述功能返回VARCHAR,并不适用所有情形,但对于字符串的比较很有用:

        SELECT data
          FROM col_my_collection
        WHERE find_in_obj(data, 'some.element') = 'something cool'

    除了字符串的比较, MongoDB还提供了数字类型的比较并提供关键字exists .  下面是find_in_obj() 方法的不同实现:

        CREATE OR REPLACE FUNCTION find_in_obj_int(data json, key varchar) RETURNS
        INT AS $$
          var obj = JSON.parse(data);
          var parts = key.split('.');
       
          var part = parts.shift();
          while (part && (obj = obj[part]) !== undefined) {
            part = parts.shift();
          }
       
          return Number(obj);
        $$ LANGUAGE plv8 STRICT;
       
        CREATE OR REPLACE FUNCTION find_in_obj_exists(data json, key varchar) RETURNS
        BOOLEAN AS $$
          var obj = JSON.parse(data);
          var parts = key.split('.');
       
          var part = parts.shift();
          while (part && (obj = obj[part]) !== undefined) {
            part = parts.shift();
          }
       
          return (obj === undefined ? 'f' : 't');
        $$ LANGUAGE plv8 STRICT;

    接下来是数据查询.  通过现有的材料来实现 find() 方法.

    相关阅读:

    CentOS编译安装MongoDB

    CentOS 编译安装 MongoDB与mongoDB的php扩展

    CentOS 6 使用 yum 安装MongoDB及服务器端配置

    Ubuntu 13.04下安装MongoDB2.4.3

    MongoDB入门必读(概念与实战并重)

    《MongoDB 权威指南》(MongoDB: The Definitive Guide)英文文字版[PDF]

     

    更多详情见请继续阅读下一页的精彩内容:

    linux

    热门AI工具

    更多
    DeepSeek
    DeepSeek

    幻方量化公司旗下的开源大模型平台

    豆包大模型
    豆包大模型

    字节跳动自主研发的一系列大型语言模型

    通义千问
    通义千问

    阿里巴巴推出的全能AI助手

    腾讯元宝
    腾讯元宝

    腾讯混元平台推出的AI助手

    文心一言
    文心一言

    文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

    讯飞写作
    讯飞写作

    基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

    即梦AI
    即梦AI

    一站式AI创作平台,免费AI图片和视频生成。

    ChatGPT
    ChatGPT

    最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

    相关专题

    更多
    java入门学习合集
    java入门学习合集

    本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

    2

    2026.01.29

    java配置环境变量教程合集
    java配置环境变量教程合集

    本专题整合了java配置环境变量设置、步骤、安装jdk、避免冲突等等相关内容,阅读专题下面的文章了解更多详细操作。

    2

    2026.01.29

    java成品学习网站推荐大全
    java成品学习网站推荐大全

    本专题整合了java成品网站、在线成品网站源码、源码入口等等相关内容,阅读专题下面的文章了解更多详细推荐内容。

    0

    2026.01.29

    Java字符串处理使用教程合集
    Java字符串处理使用教程合集

    本专题整合了Java字符串截取、处理、使用、实战等等教程内容,阅读专题下面的文章了解详细操作教程。

    0

    2026.01.29

    Java空对象相关教程合集
    Java空对象相关教程合集

    本专题整合了Java空对象相关教程,阅读专题下面的文章了解更多详细内容。

    3

    2026.01.29

    clawdbot ai使用教程 保姆级clawdbot部署安装手册
    clawdbot ai使用教程 保姆级clawdbot部署安装手册

    Clawdbot是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

    25

    2026.01.29

    clawdbot龙虾机器人官网入口 clawdbot ai官方网站地址
    clawdbot龙虾机器人官网入口 clawdbot ai官方网站地址

    clawdbot龙虾机器人官网入口:https://clawd.bot/,clawdbot ai是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

    16

    2026.01.29

    Golang 网络安全与加密实战
    Golang 网络安全与加密实战

    本专题系统讲解 Golang 在网络安全与加密技术中的应用,包括对称加密与非对称加密(AES、RSA)、哈希与数字签名、JWT身份认证、SSL/TLS 安全通信、常见网络攻击防范(如SQL注入、XSS、CSRF)及其防护措施。通过实战案例,帮助学习者掌握 如何使用 Go 语言保障网络通信的安全性,保护用户数据与隐私。

    8

    2026.01.29

    俄罗斯Yandex引擎入口
    俄罗斯Yandex引擎入口

    2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

    622

    2026.01.28

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    MongoDB 教程
    MongoDB 教程

    共17课时 | 2.4万人学习

    黑马云课堂mongodb实操视频教程
    黑马云课堂mongodb实操视频教程

    共11课时 | 3.1万人学习

    MongoDB 教程
    MongoDB 教程

    共42课时 | 27.5万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号