이번에는 nodejs를 mysql 데이터베이스에 연결하는 단계에 대해 자세히 설명하겠습니다. nodejs를 mysql 데이터베이스에 연결하는 주의사항은 무엇인가요?
1. 일반적으로 사용되는 여러 전역 변수1. filename
은 현재 파일의 경로를 가져옵니다.
3. process.cwd()
현재 프로젝트의 디렉터리 가져오기filename
获取当前文件的路径
2、dirname
获取当前文件的目录
3、process.cwd()
获取当前工程的目录
二、文件的引入与导出
1、使用require
引入文件
2、使用module.exports
导出文件中指定的变量、方法、对象
三、node
项目的搭建目录结构
demo
package.json 当前项目所依赖的包或者模块
router 存放路由的文件
views 存放视图的模块
public 静态文件
module 书写模块比如数据库
app.js 主入口文件
四、将路由视图单独写在router
文件中demo
1、视图视图文件
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;
2、在主文件中调用
'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);
五、使用ejs
模板
1、需要安装但可以不引入
npm install ejs --save
2、在主文件中配置
//配置模板的文件路径 app.set("views",dirname+"/views"); //配置模板引擎 app.set("view engine","ejs");
3、使用
①、模板文件
<!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>
②、在路由中渲染模板
'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;
③、主文件
'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);
六、关于ejs
模板文件的使用
1、返回数据
... let dataset = { name:"张三", age:20, books:['三国演义','西游记','红楼梦','水浒传'] } res.render("03_index.ejs",dataset); ...
2、普通的字段
<h2><%= name %></h2> <h2><%= age %></h2>
3、迭代数组
<ul> <% for(let i in books){%> <li><%= books[i] %></li> <%}%> </ul>
七、加载静态文件
1、主文件中配置
//设置静态文件的加载(js,css,img) app.use(express.static(dirname+"/public"));
2、在模板中使用
<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"> ...
八、使用mysql
数据库
1、在module
中创建一个db.js
的文件
'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(); }
2、在router
视图中使用查询数据
①、引入文件
//引入数据库文件 const db = require("./../module/db");
②、视图中使用
router.get("/", (req, res) => { db("select * from m_dept",(err,data)=>{ console.log(data); res.render("03_index.ejs",{data:data}); }) });
3、新增数据
①、前端页面见代码案例
②、通过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("成功"); } }) })
九、关于node
返回json
2. 파일 가져오기 및 내보내기
1. 가져오려면 require
를 사용하세요. files
2. module.exports
를 사용하여 file
3에 지정된 변수, 메서드, 객체를 내보냅니다. node
package.json 패키지 또는 현재 프로젝트가 의존하는 모듈
router
라우터에 별도로 작성
🎜파일에서🎜demo
🎜🎜1. 보기 파일🎜... res.json({ info:"成功", code:1 }); ...
ejs
를 사용하세요. >🎜Template🎜🎜🎜🎜1. 설치가 필요하지만 🎜rrreee🎜2를 도입할 필요는 없습니다. 메인 파일에 🎜rrreee🎜3을 구성하고, 템플릿 파일 🎜rrreee🎜②을 사용하세요. 🎜rrreee🎜3 경로, 메인 파일🎜rrreee🎜🎜🎜6. 🎜ejs
🎜템플릿 파일🎜🎜🎜🎜 사용에 대해 1. 일반 필드🎜rrreee🎜rrreee. 🎜3. 배열 반복 🎜rrreee🎜🎜🎜 7. 정적 파일 로드 🎜🎜🎜🎜1. 기본 파일에서 🎜rrreee🎜 구성 2. 템플릿에서 🎜rrreee🎜🎜🎜 사용 8. 🎜mysql🎜database 🎜🎜🎜🎜1. <code>모듈
🎜rrreee🎜2에서 db.js
파일을 생성합니다. 2. 라우터
에서 쿼리 데이터를 사용합니다. > view🎜 🎜①, 🎜rrreee🎜② 파일 소개, 뷰에서 🎜rrreee🎜3 사용, 새 데이터 추가🎜🎜①, 프런트 엔드 페이지의 코드 예제 보기🎜🎜②, req.query🎜 rrreee🎜🎜🎜9. 🎜node
🎜가 🎜json
🎜🎜🎜🎜🎜을 반환하는 방식에 대해 백엔드 분리 개발 모델, 백엔드에서 반환되는 데이터는 일반적으로 json이므로 ejs 템플릿 엔진을 사용할 필요가 없습니다. 🎜rrreee🎜 이 기사의 사례를 읽은 후 방법을 마스터했다고 생각합니다. PHP 중국어 웹사이트의 다른 관련 기사도 주목해주세요! 🎜🎜추천 자료: 🎜🎜🎜vue는 storejs에서 얻은 데이터를 처리합니다🎜🎜🎜🎜🎜IP로 접근할 수 없는 로컬 개발 환경을 처리하는 방법🎜🎜🎜🎜🎜p5.js_javascript 기술로 불꽃놀이 특수 효과를 만들기 위한 샘플 코드🎜 🎜🎜위 내용은 nodejs를 mysql 데이터베이스에 연결하는 단계에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!