Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Error: collection name must be a String in node js

I am trying to run following code on server

var express = require("express"),
    app = express(),
    bodyParser = require('body-parser'),
    errorHandler = require('errorhandler'),
    methodOverride = require('method-override'),
    hostname = process.env.HOSTNAME || 'localhost',
    port = parseInt(process.env.PORT, 10) || 4004,
    publicDir = process.argv[2] || __dirname + '/public';
var exec = require('child_process').exec;
var fs = require('fs');
 var mongodb = require('mongodb'),
    serverdb = new mongodb.Server('127.0.0.1', 27017, {}),
    dbName = new mongodb.Db('prisync', serverdb, {});
var url = "urlinfo";


//Show homepage
app.get("/", function (req, res) {
  //res.redirect("/index.html");
  console.log("shubham ");
  dbName.open(function (error, client){
      var collection = new mongodb.Collection(client , url);   //line 24 ====
      collection.find().limit(20).toArray(function (err, dataObjArr){
        var data = '';
        var dataArr = [];
        var i = dataObjArr.length;
        //check for error
        if(err){return res.end('error!'+err);}
        //Data
        if(dataObjArr){
          while(i--){
            dataArr[i] = dataObjArr[i]._id;
          }
          data = dataArr.join(' ');
          res.render('/index.html',{ returnedData : data });
        }else{
          res.end();
        }

      });


      });
  });



app.get("/search", function (req, res){
  console.log("shubham batra");
   var pro_name = req.query.name;
   var pro_code = req.query.code;
   var pro_category = req.query.category;
   var pro_brand = req.query.brand;

 pro_name = pro_name+"";
 pro_code = pro_code+"";
 pro_brand = pro_brand+"";
 pro_category = pro_category+"";



  MongoClient.connect('mongodb://127.0.0.1:27017/prisync', function(err, db) {
  if (err) throw err;
    console.log("Connected to Database");


    var documen = {name:pro_name, code:pro_code , category:pro_category, brand:pro_brand };
     //documen = JSON.stringify(documen);
  //insert record
  db.collection('urlinfo').insert(documen, function(err, records) {
    if (err) throw err;

    });

  res.redirect("/index.html");

});
});
//Search page
app.use(methodOverride());
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({
  extended: true
}));
app.use(express.static(publicDir));
app.use(errorHandler({
  dumpExceptions: true,
  showStack: true
}));

console.log("Server showing %s listening at http://%s:%s", publicDir, hostname, port);
app.listen(port);

but it gives following error while try to load localhost:4004

Server showing /home/shubham/Music/pricesync/server/public listening at http://localhost:4004
shubham 

/home/shubham/node_modules/mongodb/lib/server.js:274
      process.nextTick(function() { throw err; })
                                          ^
Error: collection name must be a String
    at Error (<anonymous>)
    at checkCollectionName (/home/shubham/node_modules/mongodb/lib/utils.js:69:11)
    at new Collection (/home/shubham/node_modules/mongodb/lib/collection.js:57:3)
    at /home/shubham/Music/pricesync/server/server.js:24:24
    at /home/shubham/node_modules/mongodb/lib/db.js:221:5
    at connectHandler (/home/shubham/node_modules/mongodb/lib/server.js:272:7)
    at g (events.js:180:16)
    at emit (events.js:95:17)
    at /home/shubham/node_modules/mongodb/node_modules/mongodb-core/lib/topologies/server.js:399:23
    at /home/shubham/node_modules/mongodb/node_modules/mongodb-core/lib/topologies/server.js:756:13

1 Answers

I had the same error, for me it was caused by my timestamp being incorrectly placed.


INCORRECT CODE:

    }),{timestamps:true});


CORRECTED CODE:

var mongoose = require('mongoose');
var ObjectId = mongoose.Schema.Types.ObjectId;

var User = mongoose.model('User', new mongoose.Schema({
    email:{type:String, required:true},
    password:{type:String, required:true},

    listings:[{type:ObjectId,ref:"Listings"}]

},{timestamps:true}));

like image 59
swill734 Avatar answered Dec 06 '25 08:12

swill734



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!