国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 數(shù)據(jù)庫(kù) > MongoDB > 正文

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

2020-10-29 18:51:01
字體:
供稿:網(wǎng)友

在服務(wù)器端可以通過db.eval函數(shù)來執(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可以用來模擬多文檔事務(wù):db.eval鎖住數(shù)據(jù)庫(kù),然后執(zhí)行javascript,再解鎖.雖然沒有內(nèi)置的回滾機(jī)制,但這能確保一系列操作按照指定的數(shù)序發(fā)生.
發(fā)送代碼有兩種方式,封裝一個(gè)函數(shù)或者不封裝,如:

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

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

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

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

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

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

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

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

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

二、存儲(chǔ)javascript

每個(gè)MongoDB的數(shù)據(jù)庫(kù)中都有個(gè)特殊的集合:system.js,用來存放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寫一個(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ì)弄亂客戶端發(fā)送來的javascript.
最適合使用存儲(chǔ)javascript的情況就是程序中有個(gè)地方都要用到一個(gè)javascript函數(shù),這樣要是更新的話,只需更新這個(gè)函數(shù)而不必沒出都修改.要是javascript代碼很長(zhǎng)又要繁瑣使用的話,也可以使用存儲(chǔ)javascript,這樣一次會(huì)節(jié)省不少傳輸時(shí)間.

三、安全性

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

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

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

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

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

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

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

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 岳阳市| 阿尔山市| 忻城县| 龙口市| 泗水县| 措美县| 广安市| 靖西县| 竹北市| 武义县| 阜宁县| 湘潭县| 闸北区| 铜山县| 淮安市| 磐石市| 万山特区| 荃湾区| 城市| 娱乐| 洪江市| 扬州市| 河源市| 芜湖县| 甘孜| 泰安市| 谷城县| 哈密市| 柳河县| 双辽市| 新宁县| 铜鼓县| 连云港市| 合肥市| 静安区| 成安县| 新田县| 嘉峪关市| 邓州市| 阜康市| 丰镇市|