检索MongoDB集合的API路线

时间:2019-04-22 22:11:46

标签: node.js mongodb express

我正在尝试从mongo数据库中检索数据。当我尝试在我的API中执行get路由时,会发生问题。我得到的错误是:SchemeName.collection不是一个函数。

这是我在routes/api/tejidos中的API

const express = require("express");
const router = express.Router();
const Equipo = require("../../../models/Equipo");

router.post("/crear", (req, res) => {
    // Form validation

  const newEquipo = new Equipo({
          nombre: req.body.nombre,
          marca: req.body.marca,
          modelo: req.body.modelo,
          serial: req.body.serial,
          proveedor: req.body.proveedor,
          estado: req.body.estado,
          zona: req.body.zona,
          fechaCompra: req.body.fechaCompra,
          tiempoGarantia: req.body.tiempoGarantia,
          guiaUsoRapido:req.body.guiaUsoRapido
        });
    //if (err) throw err

    newEquipo
    .save()
    .then(equipo=>res.json(equipo))
    .catch(err => console.log(err));
    });

    router.get('/leer', function(req, res) {
      const equipos = Equipo.collection("equipos")
      res.json({
        equipos: equipos
      });
    });

    module.exports = router;

这是我的server.js

const express = require("express");
const mongoose = require("mongoose");
const bodyParser = require("body-parser");
const passport = require("passport");

const users = require("./routes/api/users");
const equipos = require("./routes/api/tejidos/equipos");

const app = express();
// Bodyparser middleware
app.use(
  bodyParser.urlencoded({
    extended: false
  })
);
app.use(bodyParser.json());
// DB Config
const db = require("./config/keys").mongoURI;
// Connect to MongoDB
mongoose
  .connect(
    db,
    { useNewUrlParser: true }
  )
  .then(() => console.log("MongoDB successfully connected"))
  .catch(err => console.log(err));

  // Passport middleware
app.use(passport.initialize());

// Passport config
require("./config/passport")(passport);

// Routes
app.use("/api/users", users);
app.use("/api/tejidos/equipos", equipos);



const port = process.env.PORT || 5000; // process.env.port is Heroku's port if you choose to deploy the app there

app.listen(port, () => console.log(`Server up and running... ${port} !`));

当我在http://localhost:5000/api/tejidos/equipos/leer的Postman中使用GET方法时,需要从数据库中检索集合中的数据(使用post方法创建的数据)

此外,我会感谢您推荐的任何文档。

1 个答案:

答案 0 :(得分:0)

只需使用find方法:

router.get('/leer', async (req, res) => {
  const equipos = await Equipo.find();
  res.json({ equipos });
});

这是有用的文档,可用于通过mongoose

进行查询