欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mongodb eval 執(zhí)行服務(wù)器端腳本

 更新時(shí)間:2015年05月12日 10:47:05   投稿:hebedich  
在MongoDB的服務(wù)器端可以通過(guò)db.eval函數(shù)來(lái)執(zhí)行javascript腳本,如我們可以定義一個(gè)javascript函數(shù),然后通過(guò)db.eval在服務(wù)器端來(lái)運(yùn)行!我們前面其實(shí)也接觸過(guò)在服務(wù)器段運(yùn)行一個(gè)預(yù)定義的javascript腳本的情況,如在$where查詢(xún),執(zhí)行mapreduce任務(wù)等。

在服務(wù)器端可以通過(guò)db.eval函數(shù)來(lái)執(zhí)行javascript腳本,也可以把javascript腳本保存在數(shù)據(jù)庫(kù)中,然后在別的數(shù)據(jù)庫(kù)命令中調(diào)用.

一、db.eval 執(zhí)行服務(wù)器端腳本

利用db.eval函數(shù)可以在MongoDB服務(wù)器端執(zhí)行javascript腳本.這個(gè)函數(shù)先將給定的javascript字符串傳遞給MongoDB服務(wù)器,在服務(wù)器上執(zhí)行,然后返回結(jié)果.
db.eval可以用來(lái)模擬多文檔事務(wù):db.eval鎖住數(shù)據(jù)庫(kù),然后執(zhí)行javascript,再解鎖.雖然沒(méi)有內(nèi)置的回滾機(jī)制,但這能確保一系列操作按照指定的數(shù)序發(fā)生.
發(fā)送代碼有兩種方式,封裝一個(gè)函數(shù)或者不封裝,如:

復(fù)制代碼 代碼如下:

db.eval("return 'refactor';")
db.eval("function(){return 'refactor';}")

只有傳遞參數(shù)的時(shí)候,才必須要封裝成一個(gè)函數(shù).參數(shù)通過(guò)db.eval的第二個(gè)參數(shù)傳遞,要寫(xiě)成一個(gè)數(shù)組的形式.
如:

復(fù)制代碼 代碼如下:

db.eval("function(name){return 'hello,'+name;}",['refactor'])

若db.eval的表達(dá)式要是復(fù)雜的話,調(diào)試的辦法是將調(diào)試信息寫(xiě)進(jìn)數(shù)據(jù)庫(kù)的日志中
如:

復(fù)制代碼 代碼如下:

db.eval("print('hello refactor')")

這樣在日志里就能找到hello refactor

二、存儲(chǔ)javascript

每個(gè)MongoDB的數(shù)據(jù)庫(kù)中都有個(gè)特殊的集合:system.js,用來(lái)存放javascript變量.這些變量可以在任何MongoDB的javascript上下文中調(diào)用,包括"$where"子句,db.eval調(diào)用,MapReduce作業(yè).用insert可以將變量存在system.js中
如:

復(fù)制代碼 代碼如下:

db.system.js.insert({"_id":"x","value":1})
db.system.js.insert({"_id":"y","value":2})
db.system.js.insert({"_id":"z","value":3})

上例在全局作用域中定義了x,y,z,對(duì)其求和:

db.eval("return x+y+z;")
 
system.js可以存放javascript代碼,這樣就可以很方便的自定義一些腳本,如用javascript寫(xiě)一個(gè)日志函數(shù),將其存放在system.js中:

復(fù)制代碼 代碼如下:

db.system.js.insert(
  {
    "_id":"log",
    "value":function(msg,level)
        {
          var levels=["DEBUG","WARN","ERROR","PATAL"];
          level=level?level:0;
          var now= new Date();
          print( now +" "+ levels[level]+msg);
        }
  }
)

調(diào)用:

復(fù)制代碼 代碼如下:

db.eval("log('refactor bolg test',1)")

使用存儲(chǔ)的javascript缺點(diǎn)是代碼會(huì)與常規(guī)的源代碼控制脫離,會(huì)弄亂客戶(hù)端發(fā)送來(lái)的javascript.
最適合使用存儲(chǔ)javascript的情況就是程序中有個(gè)地方都要用到一個(gè)javascript函數(shù),這樣要是更新的話,只需更新這個(gè)函數(shù)而不必沒(méi)出都修改.要是javascript代碼很長(zhǎng)又要繁瑣使用的話,也可以使用存儲(chǔ)javascript,這樣一次會(huì)節(jié)省不少傳輸時(shí)間.

三、安全性

執(zhí)行javascript代碼就要考慮MongoDB的安全性.
如:

復(fù)制代碼 代碼如下:

>func="function(){print('hello,"+username+"!');}"

如果username是用戶(hù)自定義的,可以使用這樣的字符串"');db.dropDatabase();print('",
代碼就變成了這樣:

復(fù)制代碼 代碼如下:

>func="function(){print('hello,');db.dropDatabase();print('!');}"

為了避免這種情況,要限定作用域.
絕大多數(shù)驅(qū)動(dòng)程序都為傳遞給數(shù)據(jù)庫(kù)的代碼提供了一種特殊類(lèi)型,這是因?yàn)榇a實(shí)際上可以看成是一個(gè)字符串和一個(gè)作用域的組合.作用域是一個(gè)保存著變量名和值映射關(guān)系的文檔.當(dāng)javascript函數(shù)執(zhí)行的時(shí)候,這種映射就構(gòu)成了函數(shù)的局部作用域.

相關(guān)文章

  • mongoDB使用投影剔除‘額外’字段的操作過(guò)程

    mongoDB使用投影剔除‘額外’字段的操作過(guò)程

    這篇文章主要給大家介紹了關(guān)于mongoDB使用投影剔除‘額外’字段的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • 關(guān)于MongoTemplate通過(guò)id查詢(xún)?yōu)閚ull的問(wèn)題

    關(guān)于MongoTemplate通過(guò)id查詢(xún)?yōu)閚ull的問(wèn)題

    這篇文章主要介紹了關(guān)于MongoTemplate通過(guò)id查詢(xún)?yōu)閚ull的問(wèn)題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01
  • win7平臺(tái)快速安裝、啟動(dòng)mongodb的方法

    win7平臺(tái)快速安裝、啟動(dòng)mongodb的方法

    這篇文章主要介紹了win7平臺(tái)快速安裝、啟動(dòng)mongodb的方法,結(jié)合圖文形式分析了win7平臺(tái)下載、安裝、啟動(dòng)、配置MongoDB數(shù)據(jù)庫(kù)的方法與注意事項(xiàng),需要的朋友可以參考下
    2020-05-05
  • 解決MongoDB占用內(nèi)存過(guò)大頻繁死機(jī)的方法詳解

    解決MongoDB占用內(nèi)存過(guò)大頻繁死機(jī)的方法詳解

    這篇文章主要介紹了解決MongoDB占用內(nèi)存過(guò)大頻繁死機(jī)的方法詳解,需要的朋友可以參考下
    2020-02-02
  • mongodb中根據(jù)時(shí)間過(guò)濾進(jìn)行查詢(xún)的操作方法

    mongodb中根據(jù)時(shí)間過(guò)濾進(jìn)行查詢(xún)的操作方法

    這篇文章主要介紹了mongodb中簡(jiǎn)單的根據(jù)時(shí)間過(guò)濾進(jìn)行查詢(xún),文末補(bǔ)充介紹了如何根據(jù)日期過(guò)濾/查找MongoDB中的記錄,結(jié)合實(shí)例給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • 教你使用MongoDB導(dǎo)入導(dǎo)出備份數(shù)據(jù)

    教你使用MongoDB導(dǎo)入導(dǎo)出備份數(shù)據(jù)

    這篇文章主要介紹了教你使用MongoDB導(dǎo)入導(dǎo)出備份數(shù)據(jù)方法的相關(guān)資料,需要的朋友可以參考下
    2022-11-11
  • 解決MongoDB 排序超過(guò)內(nèi)存限制的問(wèn)題

    解決MongoDB 排序超過(guò)內(nèi)存限制的問(wèn)題

    最近小編遇到這樣的問(wèn)題:對(duì)集合執(zhí)行一個(gè)大排序操作(如聚合),出現(xiàn)以下錯(cuò)誤:(測(cè)試版本:MongoDB 3.0.6),怎么快速解決此問(wèn)題呢?下面小編給大家分享MongoDB 排序超過(guò)內(nèi)存限制的解決方法,一起看看吧
    2017-07-07
  • 關(guān)于MongoDB數(shù)據(jù)庫(kù)核心概念

    關(guān)于MongoDB數(shù)據(jù)庫(kù)核心概念

    這篇文章主要介紹了關(guān)于MongoDB數(shù)據(jù)庫(kù)核心概念,MongoDB由C++語(yǔ)言編寫(xiě),是一個(gè)基于分布式文件存儲(chǔ)的開(kāi)源數(shù)據(jù)庫(kù)系統(tǒng),需要的朋友可以參考下
    2023-04-04
  • MongoDB中如何使用JOIN操作詳解

    MongoDB中如何使用JOIN操作詳解

    相信大家都知道m(xù)ongodb是不支持join操作的,因此我們只能自己來(lái)實(shí)現(xiàn)這個(gè)功能。所以下面這篇文章主要給大家介紹了關(guān)于在MongoDB中如何使用JOIN操作的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友們下面來(lái)一起看看吧。
    2017-07-07
  • MongoDB的安裝方法圖文詳細(xì)

    MongoDB的安裝方法圖文詳細(xì)

    MongoDB?是一個(gè)基于分布式文件存儲(chǔ)的數(shù)據(jù)庫(kù),主要用于為?web?應(yīng)用提供可擴(kuò)展的高性能數(shù)據(jù)存儲(chǔ)解決方案,這里簡(jiǎn)單介紹一下安裝方法
    2023-06-06

最新評(píng)論