gpt4 book ai didi

javascript - 无法从另一个文件进行查询(connection.query 不是函数)

转载 作者:行者123 更新时间:2023-11-29 15:37:23 25 4
gpt4 key购买 nike

我是 Node.js 和数据库的新手。尝试执行 mysql 查询,但收到此错误 TypeError: connection.query is not a function

我正在使用 Node MySQL 2 (https://www.npmjs.com/package/mysql2) 包;

app.js 文件中的连接和查询工作正常,但在另一个文件中它会抛出该错误。

我的代码可能有什么问题?

app.js

const chalk = require('chalk');
const debug = require('debug')('app');
const morgan = require('morgan');
const path = require('path');
const mysql = require('mysql2');

const app = express();
const port = process.env.PORT || 3000;

const connection = mysql.createConnection({
host: '...',
user: '...',
password: '...',
database: '...',
});

connection.connect((err) => {
if (err) {
debug(`error connecting: ${chalk.red(err.stack)}`);
return;
}

debug(`connected as id ${chalk.green(connection.threadId)}`);
});

app.use(morgan('tiny'));

app.use(express.static(path.join(__dirname, '/public/')));
app.use('/css', express.static(path.join(__dirname, '/node_modules/bootstrap/dist/css/')));
app.use('/js', express.static(path.join(__dirname, '/node_modules/bootstrap/dist/js/')));
app.use('/js', express.static(path.join(__dirname, '/node_modules/jquery/dist/')));
app.set('views', './src/views');
app.set('view engine', 'ejs');

const nav = [{ link: '/books', title: 'Books' },
{ link: '/authors', title: 'Authors' }];

const bookRouter = require('./src/routes/bookRoutes')(nav);

app.use('/books', bookRouter);
app.get('/', (req, res) => {
res.render(
'index',
{
nav,
title: 'Library app',
},
);
});

app.listen(port, () => {
debug(`listening on port ${chalk.green(port)}`);
});

module.exports = connection;

bookRoutes.js

const mysql = require('mysql2');
const debug = require('debug')('app:bookRoutes');

const connection = require('../../app');

const bookRouter = express.Router();

function router(nav) {
const books = [
{
title: 'Nocturna',
genre: 'Fantasy',
author: 'Maya Motayne',
read: false,
},
{
title: 'Finale',
genre: 'Fantasy',
author: 'Stephanie Garber',
read: false,
},
];

bookRouter.route('/')
.get((req, res) => {
connection.query('SELECT * FROM `books`', (error, results) => {
debug(results);
res.render(
'bookListView',
{
nav,
title: 'Library app',
books,
},
);
});
});

bookRouter.route('/:id')
.get((req, res) => {
const { id } = req.params;
res.render(
'bookView',
{
nav,
title: 'Library app',
book: books[id],
},
);
});

return bookRouter;
}

module.exports = router;

编辑:项目树

├── app.js
├── package-lock.json
├── package.json
├── public
| ├── css
| | └── styles.css
| └── js
└── src
├── routes
| └── bookRoutes.js
└── views
├── bookListView.ejs
├── bookView.ejs
└── index.ejs

感谢您的帮助。

最佳答案

bookRoutes.js

const mysql = require('mysql2');
const debug = require('debug')('app:bookRoutes');

const connection = require('./../../app').connection; // identify the exported module

// the rest…

关于javascript - 无法从另一个文件进行查询(connection.query 不是函数),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58098436/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com