Maison >interface Web >js tutoriel >Explication détaillée de la connexion nodejs à la base de données mysql et points de connaissances de base
Cet article présente principalement nodejs pour se connecter à la base de données mysql. Il résume et analyse les modèles et configurations associés de nodejs pour se connecter et faire fonctionner la base de données mysql sous forme d'exemples, ainsi que la requête de base de données mysql, l'ajout de données et d'autres compétences opérationnelles. .Les amis dans le besoin peuvent s'y référer
Les exemples de cet article décrivent la connexion de nodejs à la base de données MySQL et les points de connaissances de base. Partagez-le avec tout le monde pour votre référence, comme suit :
1. Plusieurs variables globales couramment utilisées
1. Obtenez le courant. file Le chemin __filename
2.
Récupère le répertoire du fichier actuel __dirname
3
Récupère le répertoire du projet en cours process.cwd()
2. Importer et exporter de fichiers
1. Utilisez pour importer le fichier require
pour exporter les variables, méthodes et objets spécifiés dans le fichier module.exports
3. node
Structure du répertoire du projet
package.json Le projet actuel dépend du package ou du module
routeur Fichier qui stocke les routes
vues Module qui stocke les vues
Modules d'écriture tels que des bases de données app.js
Fichier d'entrée principal
4. Écrivez la vue de routage séparément dans le
router
1. Afficher le fichier demo
2. Appeler
const express = require("express"); const router = express.Router(); router.get("/", (req, res) => { res.send("hello word"); }); router.get("/article", (req, res) => { res.send("我是文章列表"); }) module.exports = router;
5. Utilisez le modèle
'use strict'; const express = require("express"); const app = express(); app.use("/",require("./router/03_router")) app.use("/app",require("./router/03_router1")) app.listen(3000);
1. introduire ejs
npm install ejs --save
3. Utilisez
①, le fichier modèle
//配置模板的文件路径 app.set("views",__dirname+"/views"); //配置模板引擎 app.set("view engine","ejs");
② et affichez le modèle
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> </head> <body> <h1>我是模板渲染的</h1> </body> </html>③, fichier principal
'use strict'; const express = require("express"); const router = express.Router(); router.get("/", (req, res) => { //可以直接使用res.render("03_index"); res.render("03_index.ejs"); }); router.get("/article", (req, res) => { res.send("我是文章列表"); }) module.exports = router;6. À propos de
'use strict'; const express = require("express"); const app = express(); //配置模板的文件路径 app.set("views",__dirname+"/views"); //配置模板引擎 app.set("view engine","ejs"); app.use("/",require("./router/03_router")) app.use("/app",require("./router/03_router1")) app.listen(3000);Utilisation des fichiers modèles
1. Renvoyer les donnéesejs
... let dataset = { name:"张三", age:20, books:['三国演义','西游记','红楼梦','水浒传'] } res.render("03_index.ejs",dataset); ...3. Tableau itératif
<h2><%= name %></h2> <h2><%= age %></h2>7. Charger les fichiers statiques
<ul> <% for(let i in books){%> <li><%= books[i] %></li> <%}%> </ul>
1. Configuration dans le fichier principal
2. . Utilisez
//设置静态文件的加载(js,css,img) app.use(express.static(__dirname+"/public"));dans le modèle 8. Utilisez
<link rel="stylesheet" href="./css/bootstrap.css" rel="external nofollow" > <script type="text/javascript" src="./js/jquery-3.1.1.min.js"></script> <img src="./img/002.jpg"> ...base de données
1. Créez un fichier dans mysql
module
2. 🎜>db.js
① dans la vue, importez le fichier
'use strict'; const mysql = require("mysql"); /** * 将整个方法全部暴漏出去 * @param sql sql语句 * @param arg 传递到sql语句中的参数,可以不写 * @param callback 回调函数,可以不写 */ module.exports = function (sql,arg,callback) { //1.创建连接(根据自己的数据库配置) let config = mysql.createConnection({ host:"localhost", //数据库的地址 user:"root", //数据库用户名 password:"root", //数据库密码 port:"3306", //mysql数据库的端口号 database:"mybatistest" //使用那个数据库 }); //2.开始连接数据库 config.connect(); //3.对数据库的增删改查操作 config.query(sql,arg,(err,data)=>{ callback && callback(err,data); }) //4.关闭数据库 config.end(); }
②, utilisez router
dans la vue
//引入数据库文件 const db = require("./../module/db");3. Ajouter de nouvelles données①, voir l'exemple de code sur la page frontale②, obtenir les paramètres des données utilisateur via
router.get("/", (req, res) => { db("select * from m_dept",(err,data)=>{ console.log(data); res.render("03_index.ejs",{data:data}); }) });
9. À propos de la manière de revenir req.query
router.get("/regist",(req, res)=>{ //获取到输入参数,前提是input上要写name console.log(req.query); db("insert into student(name,age) values(?,?)",[req.query.username,req.query.age],(err,data)=>{ console.log(data); if(data){ res.send("成功"); } }) })Dans le modèle de développement de séparation front-end et back-end, les données renvoyées par le backend sont généralement json, et il n'est pas nécessaire d'utiliser le moteur de modèles ejs
node
json
J'ai compilé ce qui précède pour vous, j'espère que cela vous sera utile à l'avenir. Articles connexes :
Composition technologique Ajax et analyse des principes de base
... res.json({ info:"成功", code:1 }); ...Analyse de chargement asynchrone Ajax
À propos du flux de sortie à la fin du servlet en technologie Ajax
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!