us.mongodb.old.js 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. //包含mongodb驱动程序
  2. var mongodb = require("mongodb");
  3. //mongodb安装位置
  4. var server = new mongodb.Server('192.168.65.17', 27017, { auto_reconnect: true });
  5. //指定数据库
  6. var db = new mongodb.Db('UseStudio_Blog', server, { safe: true });
  7. //打开数据库,console.log('connect');输出调试信息到控制台
  8. db.open(function (err, db) { if (!err) { console.log('connect'); } else { console.log(err); } });
  9. //选取数据的示例
  10. exports.select = function (sql, callback) {
  11. db.collection('dbo.PBDirectory', { safe: true }, function (err, collection) {
  12. //为啥monogodb返回多条数据不是Json。有点想不通,要先转数组,再转json。而选取一条数据好像不用
  13. //collection.find(function (err, _json) { callback(_json); });
  14. //查找所有数据。
  15. //console.log(collection);
  16. collection.find().toArray(function (err, _json) { callback(JSON.stringify(_json)); })
  17. //根据条件选取数据
  18. //collection.find({ "UserDirectoryName": "自然岩壁" }).toArray(function (err, _json) { callback(JSON.stringify(_json)); })
  19. //根据条件只选取一条数据。为啥取出来的还不是json,还需要转换为json?mongdb需要改写。
  20. //collection.findOne({ "UserDirectoryName": "自然岩壁" }, function (err, _json) { callback(JSON.stringify(_json)); })
  21. });
  22. }
  23. //存储过程示例
  24. exports.pro = function (sql, callback) {
  25. db.eval("testpro()",function (err, _json) {
  26. console.log(_json);
  27. callback(JSON.stringify(_json));
  28. });
  29. }
  30. //存储过程示例,带参数
  31. exports.testparam = function (sql, callback) {
  32. var _param = "自然岩壁";
  33. console.log(_param);
  34. //eval的参数传递要注意,传递字符用单引号。传递字符变量用'"++"'。有点纠结。不用单引号eval出来是个对象。所以一定要单引号
  35. //db.eval("testparam('自然岩壁')", function (err, _json) {
  36. db.eval("testparam('"+_param+"')", function (err, _json) {
  37. console.log(_json);
  38. callback(JSON.stringify(_json));
  39. });
  40. }
  41. //封装数据库连接,暂时不做。以后再看
  42. /*BlogProvider = function (host, port, database) {
  43. //指定服务器
  44. this.server = new mongodb.Server(host, port, { safe: false }, { auto_reconnect: true }, {});
  45. //指定数据库
  46. this.db = new mongodb.Db(database, this.server);
  47. //打开连接
  48. this.db.open(function (err, db) { if (!err) { console.log('connect'); } else { console.log(err); } });
  49. }
  50. BlogProvider.prototype.proselect = function (sql, callback) {
  51. db.eval("testpro()", function (err, _json) {console.log(_json);callback(JSON.stringify(_json));});}
  52. exports.BlogProvider = BlogProvider;*/