mysql语句在node.js中的写法
总结一下mysql语句在node.js中的各种写法,参考了npm网站mysql模块给的实例。
查询 select
//1
db.query('select * from tuanshang_users where user_id < 10',function(err,results,fields){
//if(err) throw err;
console.log( results );
if(!!results.length){
console.log('查询到'+ results.length +'条数据');
}else{
console.log('没有相关数据');
}
});
//2
db.query('select * from tuanshang_users where user_id=?',[8],function(err,results,fields){
if(err) throw err;
console.log( results );
});
//3
db.query({
sql: 'select * from tuanshang_users where user_id=? and username=?',
values: [43,'ABCD'],
timeout: 40000
},function(err,results,fields){
if(err) throw err;
console.log( results );
});
//4
db.query({
sql: 'select * from tuanshang_users where user_id=? and username=?',
timeout: 40000
},[44,'ABCDEF'],function(err,results,fields){
if(err) throw err;
console.log( results );
});
//5
var userid = 44;
var columns = ['username','password'];
var sql = 'select ?? from ?? where user_id=?';
db.query(sql,[columns,'tuanshang_users',userid],function(err,results,fields){
if(err) throw err;
console.log( results );
});
插入 insert into
//1
var o = {username:'cnode', password:'123456'};
db.query('insert into tuanshang_users set ?', o, function(err,result){
console.log( result );
if(result){
console.log('插入成功');
console.log( result.insertId );
}else{
console.log('插入失败');
}
});
//2
db.query('insert into tuanshang_users set ?',{username:'hello',password:'123456'}, function(err,result){
//if(err) throw err;
if(result){
console.log('插入成功');
console.log( result );
}else{
console.log('插入失败');
}
});
//3
db.query({
sql: 'insert into tuanshang_users set ?',
values: {username:'kankan',password:'123456'},
timeout: 40000
},function(err,result){
//if(err) throw err;
console.log( result );
if( !!result ){
console.log('插入成功');
console.log( result.insertId );
}else{
console.log('插入失败');
}
});
//4 5 参考查询select
更新 update
//1
db.query('update tuanshang_users set ? where user_id=?',[{username:'hello'},8],function(err,result){
//if(err) throw err;
console.log(result);
if(!!result && !!result.changedRows){
console.log('更新成功');
console.log( result.changedRows );
}else{
console.log('更新失败');
}
});
//2
db.query('update tuanshang_users set ? where user_id=5',{username:'hello'},function(err,result){
//if(err) throw err;
console.log(result);
if(!!result && !!result.changedRows){
console.log('更新成功');
console.log( result.changedRows );
}else{
console.log('更新失败');
}
});
//3
db.query({
sql: 'update tuanshang_users set ? where user_id=?',
values: [{username:'hello'},8],
timeout: 40000
},function(err,result){
//if(err) throw err;
console.log( result );
if(!!result && !!result.changedRows){
console.log('更新成功');
console.log( result.changedRows );
}else{
console.log('更新失败');
}
});
//4 5 参考查询select
删除 delete
//1
db.query('delete from tuanshang_users where username="hello"',function(err,result){
//if(err) throw err;
console.log( result );
if(!!result && !!result.affectedRows){
console.log('删除成功');
console.log( result.affectedRows );
}else{
console.log('删除失败');
}
});
//2
db.query('delete from tuanshang_users where user_id=?',[10],function(err,result){
//if(err) throw err;
console.log( result );
if(!!result && !!result.affectedRows){
console.log('删除成功');
console.log( result.affectedRows );
}else{
console.log('删除失败');
}
});
//3
db.query({
sql: 'delete from tuanshang_users where user_id=?',
values: [51],
timeout: 40000
},function(err,result){
//if(err) throw err;
console.log( result );
if(!!result && !!result.affectedRows){
console.log('删除成功');
console.log( result.affectedRows );
}else{
console.log('删除失败');
}
});
//4 5 参考查询select
查询操作,会返回一个结果数组。如果没有查询数据,结果数组为空,即数组长度为0。
插入,更新,删除操作会返回一个结果对象
{
fieldCount: 0,
affectedRows: 0,
insertId: 0,
serverStatus: 2,
warningCount: 0,
message: '',
protocol41: true,
changedRows: 0
}
在插入操作后,结果对象中 insertId 返回插入的数据在表中id的位置。
在更新操作后,结果对象中 changedRows 返回更新了多少行(表中有几条数据中的字段值发生变化),affectedRows 返回满足where条件影响的行。
在删除操作后,结果对象中 affectedRows 返回删除了多少行。如果是0表示没有删除行或者没有满足删除条件的数据行。
mysql语句在node.js中的写法的更多相关文章
- 在node.js中,使用基于ORM架构的Sequelize,操作mysql数据库之增删改查
Sequelize是一个基于promise的关系型数据库ORM框架,这个库完全采用JavaScript开发并且能够用在Node.JS环境中,易于使用,支持多SQL方言(dialect),.它当前支持M ...
- [转]在node.js中,使用基于ORM架构的Sequelize,操作mysql数据库之增删改查
本文转自:https://www.cnblogs.com/kongxianghai/p/5582661.html Sequelize是一个基于promise的关系型数据库ORM框架,这个库完全采用Ja ...
- 在node.js中使用COOKIE
node.js中如何向客户端发送COOKIE呢?有如下两个方案: 一.使用response.writeHead,代码示例: //设置过期时间为一分钟 var today = new Date(); v ...
- Node.js中的URL
Node.js中的URL 什么是URL URL是Uniform Location Resource的缩写,翻译为"统一资源定位符",也就是描述资源位置的固定表示方法.被URL描述的 ...
- node.js中对 redis 的安装和基本操作
一.win下安装redis https://github.com/MicrosoftArchive/redis/releases 下载Redis-x64-3.2.100.zip,然后解压,放到自定义目 ...
- Node.js中环境变量process.env详解
Node.js中环境变量process.env详解process | Node.js API 文档http://nodejs.cn/api/process.html官方解释:process 对象是一个 ...
- Node.js中流程控制
Node.js中的流程控制可以使用async,在使用之前需要先安装,使用npm安装 npm install async --g 下面主要介绍4种流程控制的方式: 1.串行无关联:async.serie ...
- 配置node.js中的express框架
玩node.js,不玩后台那就是杀鸡牛刀,今天没事整理一下以前开发node.js后台的心得 1.首先安装node.js以及cnpm,在这儿我就不说了,看我node.js中的另一篇文章node.js的安 ...
- 【nodejs原理&源码赏析(7)】【译】Node.js中的事件循环,定时器和process.nextTick
[摘要] 官网博文翻译,nodejs中的定时器 示例代码托管在:http://www.github.com/dashnowords/blogs 原文地址:https://nodejs.org/en/d ...
随机推荐
- [cocos2d-x]屏幕自适应解决的方法
近期在写一个项目,要求pc,ipad,andriod平台上都能够执行,所以选择用cocos2d-x来开发. 我们的资源大小是1024*768的,在pc上和苹果上都是没有问题的,但是到了andriod上 ...
- java多线程:ReentrantReadWriteLock读写锁使用
Lock比传统的线程模型synchronized更多的面向对象的方式.锁和生活似,应该是一个对象.两个线程运行的代码片段要实现同步相互排斥的效果.它们必须用同一个Lock对象. 读写锁:分为读锁和写锁 ...
- ORA-00210 ORA-15001 ORA-15055 ORA-01031: insufficient privileges
ORA-00210: cannot open the specified control file ORA-00202: control file: '+DATA/posdb/con ...
- android动画-动画分类及代码演示样例
原来一直对动画一知半解,仅仅知道依照网上的方法会用即可了,可是自己写起来感觉确实有点费劲,今天最终研究了代码实现,一下子感觉清晰多了.先把总结例如以下,代码中有具体的凝视. 动画分类 1.Peoper ...
- Hermes和开源Solr、ElasticSearch
不同
Hermes和开源Solr.ElasticSearch不同 谈到Hermes的索引技术.相信非常多同学都会想到Solr.ElasticSearch.Solr.ElasticSearc ...
- 如何做程序猿SOHO它定购家庭赚外快?
做为一名程序猿.我想大多数人除了平时削尖了脑袋研究各种各样的技术之外. ArticleId=28404183" width="1" height="1" ...
- python实用小代码
栈的实现 #!/usr/bin/env python #coding=utf-8 #python version 2.7.4 class stack: def __init__(self,list=N ...
- 最锋利的Visual Studio Web开发工具扩展:Web Essentials详解
原文:最锋利的Visual Studio Web开发工具扩展:Web Essentials详解 Web Essentials是目前为止见过的最好用的VS扩展工具了,具体功能请待我一一道来. 首先,从E ...
- hdu2222Keywords Search (特里)
Problem Description In the modern time, Search engine came into the life of everybody like Google, B ...
- 解决Android Device Chooser 找不到设备问题
第一种情况: 已经启动了官方的模拟器也进入了Android手机界面,可是在Android Device Chooser 看不到设备,怎么办? 例如以下图所看到的,使用Reset adb 或者在adb所 ...