一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

NoSQL架構實踐(二)——以NoSQL為主

  前面一篇《NoSQL架構實踐(一)——以NoSQL為輔》主要介紹了以NoSQL為輔助的架構,這種架構實施起來比較簡單,易于理解,由于其中也使用了傳統的關系數據庫,讓開發者更容易控制NoSQL帶來的風險。接下來我們繼續深入下去,換另外一個角度,“以NoSQL為主”來架構系統。

  (三)純NoSQL架構

  只使用NoSQL作為數據存儲

圖 4-純NoSQL架構

  在一些數據結構、查詢關系非常簡單的系統中,我們可以只使用NoSQL即可以解決存儲問題。這樣不但可以提高性能,還非常易于擴展。手機鳳凰網的前端展示系統就使用了這種方案。

  在一些數據庫結構經常變化,數據結構不定的系統中,就非常適合使用NoSQL來存儲。比如監控系統中的監控信息的存儲,可能每種類型的監控信息都不太一樣。這樣可以避免經常對MySQL進行表結構調整,增加字段帶來的性能問題。

  這種架構的缺點就是數據直接存儲在NoSQL中,不能做關系數據庫的復雜查詢,如果由于需求變更,需要進行某些查詢,可能無法滿足,所以采用這種架構的時候需要確認未來是否會進行復雜關系查詢以及如何應對。

  非常幸運的是,有些NoSQL數據庫已經具有部分關系數據庫的關系查詢特性,他們的功能介于key-value和關系數據庫之間,卻具有key-value數據庫的性能,基本能滿足絕大部分web 2.0網站的查詢需求。比如:

  MongoDB就帶有關系查詢的功能,能解決常用的關系查詢,所以也是一種非常不錯的選擇。下面是一些MongoDB的資料:

  雖然Foursquare使用MongoDB的宕機事件的出現使人對MongoDB的自動Shard提出了質疑,但是毫無疑問,MongoDB在NoSQL中,是一個優秀的數據庫,其單機性能和功能確實是非常吸引人的。由于上面的例子有詳細的介紹,本文就不做MongoDB的使用介紹。

  Tokyo Tyrant數據庫帶有一個名為table的存儲類型,可以對存儲的數據進行關系查詢和檢索。一個table庫類似于MySQL中的一個表。下面我們看一個小演示:

  我們要存儲一批用戶信息,用戶信息包含用戶名(name),年齡(age),email,最后訪問時間(lastvisit),地區(area)。下面為寫入的演示代碼:

<?php 
$tt = new TokyoTyrantTable ( "127.0.0.1", 1978 );
$tt->vanish ();//清空
$id = $tt->genUid ();//獲取一個自增id
//put方法提供數據寫入。 put ( string $key , array $columns );

$tt->put ( $id, array ("id" => $id, "name" => "zhangsan", "age" => 27, "email" => "zhangsan@gmail.com", "lastvisit" =>strtotime ( "2011-3-5 12:30:00" ), "area" => "北京" ) );
$id = $tt->genUid ();
$tt->put ( $id, array ("id" => $id, "name" => "lisi", "age" => 25, "email" => "lisi@126.com", "lastvisit" => strtotime( "2011-3-3 14:40:44" ), "area" => "北京" ) );
$id = $tt->genUid ();
$tt->put ( $id, array ("id" => $id, "name" => "laowang", "age" => 37, "email" => "laowang@yahoo.com", "lastvisit" =>strtotime ( "2011-3-5 08:30:12" ), "area" => "成都" ) );
$id = $tt->genUid ();
$tt->put ( $id, array ("id" => $id, "name" => "tom", "age" => 21, "email" => "tom@hotmail.com", "lastvisit" =>strtotime ( "2010-12-10 13:12:13" ), "area" => "天津" ) );
$id = $tt->genUid ();
$tt->put ( $id, array ("id" => $id, "name" => "jack", "age" => 21, "email" => "jack@gmail.com", "lastvisit" =>strtotime ( "2011-02-24 20:12:55" ), "area" => "天津" ) );
//循環打印數據庫的所有數據庫
$it = $tt->getIterator ();
foreach ( $it as $k => $v ) {
print_r ( $v );
}
?>

it知識庫NoSQL架構實踐(二)——以NoSQL為主,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 美女很黄很黄是免费的·无遮挡网站 | 永久免费av网站 | 五月婷婷丁香久久 | caoporn97人人做人人爱最新 | 2019偷偷狠狠的日日 | 加勒比综合 | 国产精品视频全国免费观看 | 亚洲香蕉伊在人在线观看9 亚洲香蕉伊综合在人在线 亚洲香蕉影院 | 色五月在线视频 | 国产手机国产手机在线 | 国产精品女在线观看 | 午夜爽视频 | 国内黄色精品 | 国产精品九九 | 免费成人午夜视频 | 91精选国产 | 成人午夜无人区一区二区 | 精品国产一区二区三区成人 | 国产高清精品入口麻豆 | 色网站免费| 国内精品久久久久影院网站 | 一本久道久久综合多人 | 成人爽a毛片在线视频网站 成人丝袜激情一区二区 | 日本大臿亚洲香蕉大片 | 久久国产精品视频 | 久热最新视频 | 综合色亚洲 | 九九视频精品在线 | 欧美日本高清视频在线观看 | 综合久久综合 | 久久大香香蕉国产免费网站 | 精品视频999| 91最新网站 | 亚洲综合久久综合激情久久 | 国产第一第二第三第四第五 | 成人午夜精品 | 亚洲精品黄 | 色悠久 | 伊人精品线视天天综合 | 亚洲系列中文字幕一区二区 | 国产亚洲福利 |