node 操作mysql
在w3c 中有关于这个的介绍,可以参考学习
http://www.runoob.com/nodejs/nodejs-mysql.html
1, 第一步: 在项目安装Mysql 模块
2, 第二步就是开始引入模块使用就行了
// 21 ,// 引入mysql 模块
let mySqlHelper = require('mysql')
22 // 创建连接,当然是以连接池的形式创建
// 关于连接池的概念学习Java的同学很清楚、
// 说白了,就是个池子,放几个连接,当需要连接的时候
// 就取出一个用, 当用完了,再放回去!
// 我记得我学习android 连接池,有核心线程数,最大线程数
// 发生异常咋处理等机制, 和 火车站买篇很像
// 好了,不扯了,以后复习android 再说
let connection = mySqlHelper.createConnection({
host :'localhost',
user :'root',
password:'root',
database:'action'
});
23 。连接
connection.connect();
24 ,查询
let id=2;
// es 6 的标准写法!
let sql = `select username,password from account where id=${id}`
connection.query(sql,function(err,data){
if(err){
console.log('连接数据库失败')
}else{
console.log(data)
}
})
结果如下:
基本使用起来还是蛮简单的!
下面再开始简单的:
var mysql = require('mysql');
var connection = mysql.createConnection({
host : 'localhost',
user : 'root',
password : 'root',
database : 'action'
});
connection.connect();
connection.query('select *from account',function(err,results){
if(err){
console.log('connect no success')
}else{
console.log(results)
}
})
结果:
我的意思是如何解析结果呢:
修改为:
connection.query('select *from account',function(err,results){
if(err){
console.log('connect no success')
}else{
// console.log(results)
console.log(results[0].username)
}
})
打印结果:
那么就好办了, :
connection.query('select *from account',function(err,results){
if(err){
console.log('connect no success')
}else{
// console.log(results)
// console.log(results[0].username)
for(let i = 0;i<results.length;i++){
console.log(results[i].username + "|" + results[i].password)
}
}
})
结果:
这样就测试完查询了,以后再遇到查询的时候,直接 取出数组对象使用就行了!
下面开始测试插入:
var mysql = require('mysql');
var connection = mysql.createConnection({
host : 'localhost',
user : 'root',
password : 'root',
database : 'action'
});
connection.connect();
// 面向对象写法, tmd java 强迫症咋地!
let user = {
username : 'zzz',
password: 'zzz'
}
// 各位小伙伴, es6 字符串模板又来了,多次使用,注定会用!!卖油翁啊,卖油翁!
// let sql = `sdfdsfds'${user.username}','${user.password}'`;
let sql = `insert into account(username,password) values('${user.username}','${user.password}');`
console.log(sql)
connection.query(sql,function(err,results){
if(err){
console.log('connect no success')
}else{
console.log(results)
}
})
结果:
数据库中:
可以根据返回值,得到 插入的ID值,也就是7
*************************************************************
下面是修改操作!!
// 面向对象写法, tmd java 强迫症咋地!
let user = {
username : 'zzz',
password: 'zzz'
}
// 各位小伙伴, es6 字符串模板又来了,多次使用,注定会用!!卖油翁啊,卖油翁!
// // let sql = `sdfdsfds'${user.username}','${user.password}'`;
// let sql = `insert into account(username,password) values('${user.username}','${user.password}');`
// console.log(sql)
let id=2;
let sql = `update account set username='${user.username}' where id=${id};`
console.log(sql)
connection.query(sql,function(err,results){
if(err){
console.log('connect no success')
}else{
console.log(results)
}
})
结果:
好修改完成,最后一个删除!
let id=2;
let sql = `delete from account where id=${id};`
console.log(sql)
connection.query(sql,function(err,results){
if(err){
console.log('connect no success')
}else{
console.log(results)
}
})
结果:
好,基本到这里,Node crud 就 基本用法就结束了
重点,就是用es6 模板字符串去组装sql 语句,这个要掌握!
行吧 ,本篇就结束了,愿各位家人身体安康,下篇我们 将写个简单的用户登录和注册,
欢迎大家继续阅读,谢谢