成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

在 Postgres 里克隆一個 MongoDB

開發 前端 MongoDB
Postgres 社區在 NoSQL采取一系列動作后并沒有坐以待斃. Postgres一直在進步: 集成了 JSON和 PLV8. PLV8 引入了 V8 Javascript引擎 . 操作 JSON也更簡單了 (需要驗證).

世上本沒有路,走的人多了也就成了路。為什么不能在 Postgres上建一個MongoDB 呢? 

Postgres 社區在 NoSQL采取一系列動作后并沒有坐以待斃.  Postgres一直在進步: 集成了 JSON和 PLV8.  PLV8 引入了 V8 Javascript引擎 . 操作 JSON也更簡單了 (需要驗證).

開始前需要做的準備:

 MongoDB的最低級別是集合.  集合可以用表來表示:

  1. CREATE TABLE some_collection ( 
  2.   some_collection_id SERIAL NOT NULL PRIMARY KEY
  3.   data JSON 
  4. ); 

字符型的JSON 被保存在 Postgres 表里,簡單易行 (現在看是這樣).

下面實現自動創建集合.  保存在集合表里:

  1. CREATE TABLE collection ( 
  2.   collection_id SERIAL NOT NULL PRIMARY KEY
  3.   name VARCHAR 
  4. ); 
  5.  
  6. -- make sure the name is unique 
  7. CREATE UNIQUE INDEX idx_collection_constraint ON collection (name); 

一旦表建好了,就可以通過存儲過程自動創建集合.  方法就是先建表,然后插入建表序列.

  1. CREATE OR REPLACE FUNCTION create_collection(collection varcharRETURNS 
  2. boolean AS $$ 
  3.   var plan1 = plv8.prepare('INSERT INTO collection (name) VALUES ($1)', [ 'varchar' ]); 
  4.   var plan2 = plv8.prepare('CREATE TABLE col_' + collection + 
  5.     ' (col_' + collection + '_id INT NOT NULL PRIMARY KEY, data JSON)'); 
  6.   var plan3 = plv8.prepare('CREATE SEQUENCE seq_col_' + collection); 
  7.  
  8.   var ret; 
  9.  
  10.   try { 
  11.     plv8.subtransaction(function () { 
  12.       plan1.execute([ collection ]); 
  13.       plan2.execute([ ]); 
  14.       plan3.execute([ ]); 
  15.    
  16.       ret = true
  17.     }); 
  18.   } catch (err) { 
  19.     ret = false
  20.   } 
  21.  
  22.   plan1.free(); 
  23.   plan2.free(); 
  24.   plan3.free(); 
  25.  
  26.   return ret; 
  27. $$ LANGUAGE plv8 IMMUTABLE STRICT; 

有了存儲過程,就方便多了:

  1. SELECT create_collection('my_collection'); 

解決了集合存儲的問題,下面看看MongoDB數據解析.  MongoDB 通過點式注解方法操作完成這一動作:

  1. CREATE OR REPLACE FUNCTION find_in_obj(data json, key varcharRETURNS 
  2. VARCHAR AS $$ 
  3.   var obj = JSON.parse(data); 
  4.   var parts = key.split('.'); 
  5.  
  6.   var part = parts.shift(); 
  7.   while (part && (obj = obj[part]) !== undefined) { 
  8.     part = parts.shift(); 
  9.   } 
  10.  
  11.   // this will either be the value, or undefined 
  12.   return obj; 
  13. $$ LANGUAGE plv8 STRICT; 

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

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

除了字符串的比較, MongoDB還提供了數字類型的比較并提供關鍵字exists .  下面是find_in_obj() 方法的不同實現:

  1. CREATE OR REPLACE FUNCTION find_in_obj_int(data json, key varcharRETURNS 
  2. INT AS $$ 
  3.   var obj = JSON.parse(data); 
  4.   var parts = key.split('.'); 
  5.  
  6.   var part = parts.shift(); 
  7.   while (part && (obj = obj[part]) !== undefined) { 
  8.     part = parts.shift(); 
  9.   } 
  10.  
  11.   return Number(obj); 
  12. $$ LANGUAGE plv8 STRICT; 
  13.  
  14. CREATE OR REPLACE FUNCTION find_in_obj_exists(data json, key varcharRETURNS 
  15. BOOLEAN AS $$ 
  16.   var obj = JSON.parse(data); 
  17.   var parts = key.split('.'); 
  18.  
  19.   var part = parts.shift(); 
  20.   while (part && (obj = obj[part]) !== undefined) { 
  21.     part = parts.shift(); 
  22.   } 
  23.  
  24.   return (obj === undefined ? 'f' : 't'); 
  25. $$ LANGUAGE plv8 STRICT; 

接下來是數據查詢.  通過現有的材料來實現 find() 方法.

#p#

在本部分中將覆蓋保存數據以及從MongDB查詢中構建WHERE從句,以便檢索我們已經寫入的數據。

保存數據到集合中很簡單。首先,我們需要檢查JSON對象并尋找一個_id值。這部分代碼是原生的假設,如果_id已存在這意味著一個更新,否則就意味著一個插入。請注意,我們目前還沒有創建objectID,只使用了一個序列待其發生:

  1. CREATE OR REPLACE FUNCTION save(collection varchar, data json) RETURNS 
  2. BOOLEAN AS $$ 
  3.   var obj = JSON.parse(data); 
  4.  
  5.   var id = obj._id; 
  6.  
  7.   // if there is no id, naively assume an insert 
  8.   if (id === undefined) { 
  9.     // get the next value from the sequence for the ID 
  10.     var seq = plv8.prepare("SELECT nextval('seq_col_" + 
  11.         collection + "') AS id"); 
  12.     var rows = seq.execute([ ]); 
  13.    
  14.     id = rows[0].id; 
  15.     obj._id = id; 
  16.  
  17.     seq.free(); 
  18.  
  19.     var insert = plv8.prepare("INSERT INTO col_" + collection + 
  20.         "  (col_" + collection + "_id, data) VALUES ($1, $2)"
  21.         [ 'int''json']); 
  22.  
  23.     insert.execute([ id, JSON.stringify(obj) ]); 
  24.     insert.free(); 
  25.   } else { 
  26.     var update = plv8.prepare("UPDATE col_" + collection + 
  27.       " SET data = $1 WHERE col_" + collection + "_id = $2"
  28.      [ 'json''int' ]); 
  29.  
  30.     update.execute([ data, id ]); 
  31.   } 
  32.  
  33.   return true
  34. $$ LANGUAGE plv8 IMMUTABLE STRICT; 

基于這個觀點,我們可以構建一些插入的簡單文檔:

  1.   "name""Jane Doe"
  2.   "address": { 
  3.     "street""123 Fake Street"
  4.     "city""Portland"
  5.     "state""OR" 
  6.   }, 
  7.   "age": 33 
  8.  
  9.   "name""Sarah Smith"
  10.   "address": { 
  11.     "street""456 Real Ave"
  12.     "city""Seattle"
  13.     "state""WA" 
  14.   } 
  15.  
  16.   "name""James Jones"
  17.   "address": { 
  18.     "street""789 Infinity Way"
  19.     "city""Oakland"
  20.     "state""CA" 
  21.   }, 
  22.   "age": 23 

讓我們創建一個集合并插入一些數據:

  1. work=# SELECT create_collection('data'); 
  2.  create_collection 
  3. ------------------- 
  4.  t 
  5. (1 row) 
  6.  
  7. work=# SELECT save('data''{ our object }'); 
  8.  save 
  9. ------ 
  10.  t 
  11. (1 row) 

英文原文:Building a MongoDB Clone in Postgres: Part 1

譯文鏈接:http://www.oschina.net/translate/building_a_mongodb_clone_in_postgres_part_1

責任編輯:林師授 來源: 中國開源社區 編譯
相關推薦

2011-07-20 10:02:01

Xcode cocoa 窗口

2024-12-10 13:11:36

2013-04-22 10:15:27

GoogleGoogle管理

2016-04-08 15:13:29

人工智能阿里小Ai

2021-01-04 09:12:31

集合變量

2019-07-05 09:20:30

1G5G4G

2021-07-26 17:18:03

Linux進程通信

2009-04-22 15:16:30

2013-05-13 10:24:44

谷歌開發團隊開發管理

2015-08-06 13:44:21

swiftcocoapods

2011-09-08 10:46:12

Widget

2009-09-22 11:54:42

ibmdwPHP

2023-03-15 09:00:43

SwiftUISlider

2021-06-03 10:00:47

JavaScript 前端數克隆對象

2023-05-30 11:30:54

云原生多云IT

2017-08-17 14:38:39

JavaAbstract抽象

2021-06-26 16:24:21

Linux命令系統

2022-02-10 22:34:51

對象JVM收集器

2017-11-23 08:30:27

數據庫Postgres樹莓派

2016-03-01 14:37:47

華為
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 天堂久久网 | 精品自拍视频 | 国产精品自产av一区二区三区 | 九九热免费视频在线观看 | 久久精品国产一区二区三区不卡 | 久久久久久久久久影视 | 国产大学生情侣呻吟视频 | 亚洲欧美综合精品另类天天更新 | 亚洲欧美高清 | 五月激情婷婷网 | 日韩一区二区在线免费观看 | 亚洲欧美在线视频 | h视频免费在线观看 | 九九热免费视频在线观看 | 亚洲精品久久久一区二区三区 | 免费视频久久 | 一区二区三区四区电影 | 欧美国产亚洲一区二区 | 成人欧美一区二区三区在线观看 | 亚洲狠狠爱一区二区三区 | 欧美日韩精品亚洲 | 五月天婷婷丁香 | 一区二区三区四区免费在线观看 | 亚洲三区在线观看 | 手机看片在线播放 | 欧美高清视频一区 | 国产色 | 黄色大片视频 | 成人在线免费视频 | 九九热在线免费视频 | 在线欧美一区 | 亚洲视频在线看 | 97人澡人人添人人爽欧美 | 视频一区二区三区在线观看 | 在线免费观看a级片 | 91在线精品播放 | 亚洲人va欧美va人人爽 | 99精品视频免费观看 | 日韩欧美精品一区 | 久色视频在线 | 玖玖国产精品视频 |