我是新來的節點和mongo,並有一個奇怪的問題,從mongo shell查看我的數據庫的內容。我構建了一個簡單的REST API,並且具有良好的CRUD功能,但即使數據似乎已保存,我仍無法從shell中找到它。從shell中查看mongo db內容
我的程序很簡單;我從this example複製它。
有三個文件:package.json,server.js(主文件)和routes/wines.js。 Mongo db是像往常一樣安裝和配置的(監聽端口27017)。我可以從shell中添加,更新,讀取和刪除收集項目,而不會出現任何問題。
的package.json:
{
"name": "wine-cellar",
"description": "Wine Cellar Application",
"version": "0.0.1",
"private": true,
"dependencies": {
"express": "3.x",
"mongodb": "^1.4.19"
}
}
server.js
var express = require('express'),
wine = require('./routes/wines');
var app = express();
app.use(express.logger('dev')); /* 'default', 'short', 'tiny', 'dev' */
app.use(express.bodyParser());
app.get('/wines', wine.findAll);
app.get('/wines/:id', wine.findById);
app.post('/wines', wine.addWine);
app.put('/wines/:id', wine.updateWine);
app.delete('/wines/:id', wine.deleteWine);
app.listen(3000);
console.log('Listening on port 3000...');
路線/ wines.js(很簡單的REST API)
var mongo = require('mongodb');
var Server = mongo.Server,
Db = mongo.Db,
BSON = mongo.BSONPure;
var server = new Server('localhost', 27017, {auto_reconnect: true});
db = new Db('winedb', server);
db.open(function(err, db) {
if(!err) {
console.log("Connected to 'winedb' database");
db.collection('wines', {strict:true}, function(err, collection) {
if (err) {
console.log("The 'wines' collection doesn't exist. Creating it with sample data...");
populateDB();
}
});
}
});
exports.findById = function(req, res) {
var id = req.params.id;
console.log('Retrieving wine: ' + id);
db.collection('wines', function(err, collection) {
collection.findOne({'_id':new BSON.ObjectID(id)}, function(err, item) {
res.send(item);
});
});
};
exports.findAll = function(req, res) {
db.collection('wines', function(err, collection) {
collection.find().toArray(function(err, items) {
res.send(items);
});
});
};
exports.addWine = function(req, res) {
var wine = req.body;
console.log('Adding wine: ' + JSON.stringify(wine));
db.collection('wines', function(err, collection) {
collection.insert(wine, {safe:true}, function(err, result) {
if (err) {
res.send({'error':'An error has occurred'});
} else {
console.log('Success: ' + JSON.stringify(result[0]));
res.send(result[0]);
}
});
});
}
exports.updateWine = function(req, res) {
var id = req.params.id;
var wine = req.body;
console.log('Updating wine: ' + id);
console.log(JSON.stringify(wine));
db.collection('wines', function(err, collection) {
collection.update({'_id':new BSON.ObjectID(id)}, wine, {safe:true}, function(err, result) {
if (err) {
console.log('Error updating wine: ' + err);
res.send({'error':'An error has occurred'});
} else {
console.log('' + result + ' document(s) updated');
res.send(wine);
}
});
});
}
exports.deleteWine = function(req, res) {
var id = req.params.id;
console.log('Deleting wine: ' + id);
db.collection('wines', function(err, collection) {
collection.remove({'_id':new BSON.ObjectID(id)}, {safe:true}, function(err, result) {
if (err) {
res.send({'error':'An error has occurred - ' + err});
} else {
console.log('' + result + ' document(s) deleted');
res.send(req.body);
}
});
});
}
/*--------------------------------------------------------------------------------------------------------------------*/
// Populate database with sample data -- Only used once: the first time the application is started.
// You'd typically not find this code in a real-life app, since the database would already exist.
var populateDB = function() {
var wines = [
{
name: "CHATEAU DE SAINT COSME",
year: "2009",
grapes: "Grenache/Syrah",
country: "France",
region: "Southern Rhone",
description: "The aromas of fruit and spice...",
picture: "saint_cosme.jpg"
},
{
name: "LAN RIOJA CRIANZA",
year: "2006",
grapes: "Tempranillo",
country: "Spain",
region: "Rioja",
description: "A resurgence of interest in boutique vineyards...",
picture: "lan_rioja.jpg"
}];
db.collection('wines', function(err, collection) {
collection.insert(wines, {safe:true}, function(err, result) {});
});
};
當我測試從我的API終端使用curl命令,我沒有問題。我可以創建,讀取和編輯數據庫中的數據,並且在終端上顯示正常。
然而,mongo shell是一個不同的故事。當我運行「秀星展」,我看到我的winedb數據庫中列出,但是當我運行查詢就可以了,它的行爲就好像數據庫是空的:
> use winedb
switched to db winedb
> db.winedb.count()
0
> db.getCollection('winedb')
winedb.winedb
> db.count()
2014-10-28T00:14:26.229-0400 TypeError: Property 'count' of object winedb is not a function
> db.winedb.count()
0
> db.getCollection('winedb').find()
> db.getCollection('winedb').count()
0
同時curl'ing一切都將繼續正常工作。我怎樣才能在mongo shell上看到我的數據?
感謝wdberkeley!你有沒有可能爲mongo推薦一個好的GUI? – 2014-10-28 17:25:08