当前位置:网站首页>The Vue project connects to the MySQL database through node and implements addition, deletion, modification and query operations
The Vue project connects to the MySQL database through node and implements addition, deletion, modification and query operations
2022-07-31 04:44:00 【sebeefe】
Vue项目通过node连接MySQL数据库
1.创建Vue项目
vue create 项目名
Vue项目创建的详细步骤,有需要的可移步这里
2.下载安装需要的插件
下载express
npm install express
下载cors,用于处理接口跨域问题
npm install cors
下载mysql
npm install mysql
下载axios
npm install axios
3.在项目中创建server文件夹,用于搭建本地服务器
新建/server/app.js,用于配置服务器相关信息
let express = require(‘express’)
let app = express()
let cors = require(‘cors’)
let bodyParser = require(‘body-parser’)app.use(bodyParser.json()); //配置解析,用于解析json和urlencoded格式的数据
app.use(bodyParser.urlencoded({extended: false}));
app.use(cors()) //配置跨域,必须在路由之前app.listen(80, () => {
console.log(‘服务器启动成功’);
})新建/server/db/index.js,用于配置数据库相关信息
let mysql = require(‘mysql’)
let db = mysql.createPool({
host: ‘127.0.0.1’, //数据库IP地址
user: ‘root’, //数据库登录账号
password: ‘root’, //数据库登录密码
database: ‘test’ //要操作的数据库
})module.exports = db
新建/server/API/user.js,用于操作数据库
let db = require(‘…/db/index’)
exports.get = (req, res) => {
var sql = ‘select * from user’
db.query(sql, (err, data) => {
if(err) {
return res.send(‘错误:’ + err.message)
}
res.send(data)
})
}新建/server/router.js,用于配置对应路由
let express = require(‘express’)
let router = express.Router()
let user = require(‘./API/user’)router.get(‘/user’, user.get)
module.exports = router
在/server/app.js中导入路由配置
let express = require(‘express’)
let app = express()
let cors = require(‘cors’)
let bodyParser = require(‘body-parser’)
let router = require(‘./router’)app.use(bodyParser.json()); //配置解析,用于解析json和urlencoded格式的数据
app.use(bodyParser.urlencoded({extended: false}));
app.use(cors()) //配置跨域
app.use(router) //配置路由app.listen(80, () => {
console.log(‘服务器启动成功’);
})测试服务器是否搭建成功
server文件夹下执行node app.js
提示“服务器启动成功”,浏览器打开http://127.0.0.1/user,可看见user数据表中对应的数据,表示服务器搭建成功.
4.Vue项目访问接口获取数据
<template>
<div>
<button @click="get()">获取user表数据</button>
</div>
</template>
<script>
import axios from "axios"
export default {
data () {
return {
};
},
methods: {
get() {
axios.get('http://127.0.0.1/user').then(res=>{
console.log(res.data);
}).catch(err=>{
console.log("获取数据失败" + err);
})
}
}
}
</script>
执行结果
注意:运行项目前,一定要先启动服务器,只有服务器启动之后,接口才能被调用,所以需要打开两个终端,分别用于启动服务器和项目
数据表的增删改查操作
1.服务器配置
新建/server/API/list.js,用于存放列表相关操作
let db = require(‘…/db/index’)
exports.all = (req, res) => { //获取info表全部数据
var sql = ‘select * from info’
db.query(sql, (err, data) => {
if(err) {
return res.send(‘错误:’ + err.message)
}
res.send(data)
})
}
exports.get = (req, res) => { //通过id查询数据
var sql = ‘select * from info where id = ?’ //?用于占位
db.query(sql, [req.query.id], (err, data) => {
if(err) {
return res.send(‘错误:’ + err.message)
}
res.send(data)
})
}exports.del = (req, res) => { //通过id删除数据
var sql = ‘delete from info where id = ?’
db.query(sql, [req.query.id], (err, data) => {
if(err) {
return res.send(‘错误:’ + err.message)
}
res.send({
status: 200,
message: ‘删除成功’
})
})
}exports.add = (req, res) => { //向info表添加数据
var sql = ‘insert into info (id,name,address,tel) values (?,?,?,?)’
db.query(sql, [req.query.id, req.query.name, req.query.address, req.query.tel], (err, data) => {
if(err) {
return res.send(‘错误:’ + err.message)
}
res.send({
status: 200,
message: ‘添加成功’
})
})
}exports.update = (req, res) => { //通过id更新数据
var sql = ‘update info set name = ?, address = ?, tel = ? where id = ?’
db.query(sql, [req.query.name, req.query.address, req.query.tel, req.query.id], (err, data) => {
if(err) {
return res.send(‘错误:’ + err.message)
}
res.send({
status: 200,
message: ‘修改成功’
})
})
}在/server/router.js中配置对应路由
let express = require(‘express’)
let router = express.Router()
let user= require(‘./API/user’)
let info = require(‘./API/list’)router.get(‘/user’, user.get)
router.get(‘/list/all’, info.all)
router.get(‘/list/get’, info.get)
router.get(‘/list/add’, info.add)
router.get(‘/list/update’, info.update)
router.get(‘/list/del’, info.del)module.exports = router
2.前端配置
- 页面样式
(本人懒得写样式了,随便看看就好_(:з」∠)_)
注意:此处的页面搭建本人使用了elementUI组件,CV前要先下载elementUI
在终端执行 npm i element-ui -S ,同时在main.js中导入注册即可
<template>
<div id="box">
<div class="left">
<el-button type="primary" @click="all">获取info表的全部数据</el-button>
<h2>-----------------------------------</h2>
<el-input v-model="id" placeholder="请输入id" class="input"></el-input>
<el-button type="danger" @click="del">删除</el-button>
<el-button type="primary" @click="get">查询</el-button>
<h2>-----------------------------------</h2>
<el-input v-model="id" placeholder="请输入id" class="input"></el-input>
<el-input v-model="name" placeholder="请输入姓名" class="input"></el-input>
<el-input v-model="address" placeholder="请输入地址" class="input"></el-input>
<el-input v-model="tel" placeholder="请输入电话" class="input"></el-input>
<el-button type="primary" @click="add">添加</el-button>
<el-button type="primary" @click="update">修改</el-button>
</div>
<div class="right">
<table class="hovertable">
<tr>
<th>ID</th><th>姓名</th><th>家庭住址</th><th>联系电话</th>
</tr>
<tr v-for="(item, index) in info" v-bind:key="index">
<td>{
{item.id}}</td>
<td>{
{item.name}}</td>
<td>{
{item.address}}</td>
<td>{
{item.tel}}</td>
</tr>
</table>
</div>
</div>
</template>
对应的实现函数
效果展示
vue+mysql+node实现数据表增删改查
再补充一点:get请求传参数据存放在req.query中;post请求传参数据存放在req.body中.
文章中只展示了get请求,所以在此特别补充说明一下
具体可参见vue登录注册案例,其中的登录使用的是get请求,注册使用的是post请求
文中的内容都是一些相当基础的知识,希望大家可以在看懂理解的基础上多敲代码,这样才能有所进步(虽然cv真的很快乐)
先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在.深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小.自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前.因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担.添加下方名片,即可获取全套学习资料哦
边栏推荐
- 【debug锦集】Expected input batch_size (1) to match target batch_size (0)
- 产学研用 共建开源人才生态 | 2022开放原子全球开源峰会教育分论坛圆满召开
- (8) Math class, Arrays class, System class, Biglnteger and BigDecimal classes, date class
- 【云原生】DevOps(五):集成Harbor
- MySQL数据库备份
- 开源社区三十年 | 2022开放原子全球开源峰会开源社区三十年专题活动圆满召开
- 强化学习:从入门到入坑再到拉屎
- Error EPERM operation not permitted, mkdir ‘Dsoftwarenodejsnode_cache_cacach两种解决办法
- 简易网络文件拷贝的C实现
- interprocess communication
猜你喜欢
【wpf】wpf中的那些模板之深度解析
Fusion Cloud Native, Empowering New Milestones | 2022 Open Atom Global Open Source Summit Cloud Native Sub-Forum Successfully Held
input输入框展示两位小数之precision
【debug锦集】Expected input batch_size (1) to match target batch_size (0)
30 Years of Open Source Community | 2022 Open Atom Global Open Source Summit 30 Years of Open Source Community Special Event Held Successfully
递归实现汉诺塔问题
LocalDate addition and subtraction operations and comparison size
MySQL基础操作
MySQL数据库安装配置保姆级教程(以8.0.29为例)有手就行
Knowledge Distillation 7: Detailed Explanation of Knowledge Distillation Code
随机推荐
From scratch, a mirror to the end, a pure system builds a grasscutter (Grasscutter)
Error EPERM operation not permitted, mkdir ‘Dsoftwarenodejsnode_cache_cacach两种解决办法
【py脚本】批量二值化处理图像
open failed: EACCES (Permission denied)
(4) Recursion, variable parameters, access modifiers, understanding main method, code block
Bubble sort, selection sort, insertion sort, binary search directly
Can‘t load /home/Iot/.rnd into RNG
Thinking about data governance after Didi fines
(5) final, abstract class, interface, inner class
【R语言】【3】apply,tapply,lapply,sapply,mapply与par函数相关参数
Vue项目通过node连接MySQL数据库并实现增删改查操作
MySQL基础操作
Exsl file preview, word file preview web page method
剑指offer专项突击版第15天
马斯克对话“虚拟版”马斯克,脑机交互技术离我们有多远
ERP生产作业控制 金蝶
HCIP第十天_BGP路由汇总实验
ERROR 2003 (HY000) Can‘t connect to MySQL server on ‘localhost3306‘ (10061)
three.js 制作3D相册
开源社区三十年 | 2022开放原子全球开源峰会开源社区三十年专题活动圆满召开