>웹 프론트엔드 >JS 튜토리얼 >nodejs를 mysql 데이터베이스에 연결하는 단계에 대한 자세한 설명

nodejs를 mysql 데이터베이스에 연결하는 단계에 대한 자세한 설명

php中世界最好的语言
php中世界最好的语言원래의
2018-05-09 11:48:153308검색

이번에는 nodejs를 mysql 데이터베이스에 연결하는 단계에 대해 자세히 설명하겠습니다. nodejs를 mysql 데이터베이스에 연결하는 주의사항은 무엇인가요?

1. 일반적으로 사용되는 여러 전역 변수1. filename은 현재 파일의 경로를 가져옵니다.

2.

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返回json2. 파일 가져오기 및 내보내기

1. 가져오려면 require를 사용하세요. files

2. module.exports를 사용하여 file

3에 지정된 변수, 메서드, 객체를 내보냅니다.
node

프로젝트 구성디렉터리 구조


demo

package.json 패키지 또는 현재 프로젝트가 의존하는 모듈
router

라우팅을 저장할 파일🎜 views 🎜view를 저장할 모듈🎜 파일 🎜 module 🎜데이터베이스 등 모듈 작성 🎜 app.js 🎜메인 엔트리 파일🎜🎜🎜 4. 라우팅 뷰를 🎜 라우터에 별도로 작성 🎜파일에서🎜demo🎜🎜1. 보기 파일🎜
...
res.json({
 info:"成功",
 code:1
});
...
🎜2. 메인 파일에서 🎜rrreee🎜🎜🎜을 호출합니다. 5. 🎜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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.