>  기사  >  웹 프론트엔드  >  nodejs를 mysql 데이터베이스에 연결하는 단계 분석

nodejs를 mysql 데이터베이스에 연결하는 단계 분석

php中世界最好的语言
php中世界最好的语言원래의
2018-05-04 09:02:201314검색

이번에는 mysql 데이터베이스를 nodejs와 연결하는 단계에 대한 분석을 가져왔습니다. nodejs를 mysql 데이터베이스에 연결하는 주의사항은 무엇인가요?

이 문서의 예에서는 mysql 데이터베이스에 연결하는 nodejs와 기본 지식 포인트를 설명합니다. 다음과 같이 참조용으로 모든 사람과 공유하세요.

1. 일반적으로 사용되는 여러 전역 변수

1. filename 현재 파일의 경로를 가져옵니다.

2. 현재 파일의 디렉터리를 가져옵니다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返回json3. process.cwd()현재 프로젝트의 디렉터리를 가져옵니다

2. 파일 가져오기 및 내보내기

1. require파일 삽입<p></p>2을 사용하여 file<p style="text-align: left;"><a href="http://www.php.cn/js-tutorial-395208.html" target="_blank"></a><br>3에 지정된 변수, 메서드 및 개체를 내보냅니다. </p>프로젝트 빌드디렉터리 구조


demo🎜🎜 package.json 🎜 현재 프로젝트가 의존하는 패키지 또는 모듈🎜                                                                                                                                            "color: #0000ff">공개 🎜정적 파일🎜 모듈 🎜데이터베이스 등 쓰기 모듈 🎜 app.js 🎜기본 항목 파일🎜🎜 🎜4. 🎜라우터🎜 파일🎜데모에 경로 뷰를 별도로 작성합니다. >🎜🎜1. 보기 파일🎜
...
res.json({
 info:"成功",
 code:1
});
...
🎜2. 메인 파일🎜🎜5에서 🎜ejs🎜template🎜🎜🎜🎜1을 사용하세요. 🎜rrreee🎜2. 메인 파일🎜3에서 🎜rrreee를 구성합니다. 🎜🎜1번 템플릿 파일 🎜rrreee🎜2번을 사용하여 🎜rrreee🎜3번 경로, 메인 파일 🎜rrreee🎜🎜🎜에서 템플릿을 렌더링합니다. ejs 🎜 테일 플레이트 파일 1. . 기본 파일에서 🎜rrreee 구성 🎜 2. 템플릿에서 🎜rrreee 사용 🎜🎜🎜 8. 🎜 mysql🎜Database🎜🎜🎜🎜1을 사용합니다. code> 파일을 module🎜rrreee🎜2에서 사용하세요. router 뷰에서 쿼리 데이터를 사용하고 🎜🎜1번 파일을 가져오고 🎜rrreee🎜2번에서 🎜rrreee🎜3을 사용하세요. 보기, 새 데이터 추가 🎜🎜①, 프런트 엔드 페이지의 코드 사례 보기 🎜🎜②, req.query를 전달하여 사용자 데이터 매개변수 가져오기 🎜rrreee🎜🎜🎜9. code>node🎜는 프론트엔드와 백엔드 분리 개발 모드에서 🎜json🎜🎜🎜🎜🎜을 반환합니다. 미들과 백엔드에서 반환되는 데이터는 일반적으로 json이며, ejs 템플릿 엔진을 사용할 필요가 없습니다. 🎜rrreee🎜 이 기사의 사례를 읽으신 후 방법을 숙지하셨으리라 믿습니다. 더 흥미로운 정보를 보려면 PHP 중국어 웹사이트의 다른 관련 기사를 주목해 보세요. 🎜🎜추천 도서: 🎜🎜🎜Nodejs 비밀번호 암호화 처리 방법 요약🎜🎜🎜🎜🎜Vue 데이터 전송 방법 요약🎜🎜🎜

위 내용은 nodejs를 mysql 데이터베이스에 연결하는 단계 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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