mongodb eval 執(zhí)行服務(wù)器端腳本
在服務(wù)器端可以通過db.eval函數(shù)來執(zhí)行javascript腳本,也可以把javascript腳本保存在數(shù)據(jù)庫中,然后在別的數(shù)據(jù)庫命令中調(diào)用.
一、db.eval 執(zhí)行服務(wù)器端腳本
利用db.eval函數(shù)可以在MongoDB服務(wù)器端執(zhí)行javascript腳本.這個函數(shù)先將給定的javascript字符串傳遞給MongoDB服務(wù)器,在服務(wù)器上執(zhí)行,然后返回結(jié)果.
db.eval可以用來模擬多文檔事務(wù):db.eval鎖住數(shù)據(jù)庫,然后執(zhí)行javascript,再解鎖.雖然沒有內(nèi)置的回滾機(jī)制,但這能確保一系列操作按照指定的數(shù)序發(fā)生.
發(fā)送代碼有兩種方式,封裝一個函數(shù)或者不封裝,如:
db.eval("return 'refactor';")
db.eval("function(){return 'refactor';}")
只有傳遞參數(shù)的時候,才必須要封裝成一個函數(shù).參數(shù)通過db.eval的第二個參數(shù)傳遞,要寫成一個數(shù)組的形式.
如:
db.eval("function(name){return 'hello,'+name;}",['refactor'])
若db.eval的表達(dá)式要是復(fù)雜的話,調(diào)試的辦法是將調(diào)試信息寫進(jìn)數(shù)據(jù)庫的日志中
如:
db.eval("print('hello refactor')")
這樣在日志里就能找到hello refactor
二、存儲javascript
每個MongoDB的數(shù)據(jù)庫中都有個特殊的集合:system.js,用來存放javascript變量.這些變量可以在任何MongoDB的javascript上下文中調(diào)用,包括"$where"子句,db.eval調(diào)用,MapReduce作業(yè).用insert可以將變量存在system.js中
如:
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,對其求和:
db.eval("return x+y+z;")
system.js可以存放javascript代碼,這樣就可以很方便的自定義一些腳本,如用javascript寫一個日志函數(shù),將其存放在system.js中:
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)用:
db.eval("log('refactor bolg test',1)")
使用存儲的javascript缺點是代碼會與常規(guī)的源代碼控制脫離,會弄亂客戶端發(fā)送來的javascript.
最適合使用存儲javascript的情況就是程序中有個地方都要用到一個javascript函數(shù),這樣要是更新的話,只需更新這個函數(shù)而不必沒出都修改.要是javascript代碼很長又要繁瑣使用的話,也可以使用存儲javascript,這樣一次會節(jié)省不少傳輸時間.
三、安全性
執(zhí)行javascript代碼就要考慮MongoDB的安全性.
如:
>func="function(){print('hello,"+username+"!');}"
如果username是用戶自定義的,可以使用這樣的字符串"');db.dropDatabase();print('",
代碼就變成了這樣:
>func="function(){print('hello,');db.dropDatabase();print('!');}"
為了避免這種情況,要限定作用域.
絕大多數(shù)驅(qū)動程序都為傳遞給數(shù)據(jù)庫的代碼提供了一種特殊類型,這是因為代碼實際上可以看成是一個字符串和一個作用域的組合.作用域是一個保存著變量名和值映射關(guān)系的文檔.當(dāng)javascript函數(shù)執(zhí)行的時候,這種映射就構(gòu)成了函數(shù)的局部作用域.
相關(guān)文章
關(guān)于MongoTemplate通過id查詢?yōu)閚ull的問題
這篇文章主要介紹了關(guān)于MongoTemplate通過id查詢?yōu)閚ull的問題,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-01-01解決MongoDB占用內(nèi)存過大頻繁死機(jī)的方法詳解
這篇文章主要介紹了解決MongoDB占用內(nèi)存過大頻繁死機(jī)的方法詳解,需要的朋友可以參考下2020-02-02mongodb中根據(jù)時間過濾進(jìn)行查詢的操作方法
這篇文章主要介紹了mongodb中簡單的根據(jù)時間過濾進(jìn)行查詢,文末補充介紹了如何根據(jù)日期過濾/查找MongoDB中的記錄,結(jié)合實例給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-05-05教你使用MongoDB導(dǎo)入導(dǎo)出備份數(shù)據(jù)
這篇文章主要介紹了教你使用MongoDB導(dǎo)入導(dǎo)出備份數(shù)據(jù)方法的相關(guān)資料,需要的朋友可以參考下2022-11-11關(guān)于MongoDB數(shù)據(jù)庫核心概念
這篇文章主要介紹了關(guān)于MongoDB數(shù)據(jù)庫核心概念,MongoDB由C++語言編寫,是一個基于分布式文件存儲的開源數(shù)據(jù)庫系統(tǒng),需要的朋友可以參考下2023-04-04