总结一下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中的写法的更多相关文章

  1. 在node.js中,使用基于ORM架构的Sequelize,操作mysql数据库之增删改查

    Sequelize是一个基于promise的关系型数据库ORM框架,这个库完全采用JavaScript开发并且能够用在Node.JS环境中,易于使用,支持多SQL方言(dialect),.它当前支持M ...

  2. [转]在node.js中,使用基于ORM架构的Sequelize,操作mysql数据库之增删改查

    本文转自:https://www.cnblogs.com/kongxianghai/p/5582661.html Sequelize是一个基于promise的关系型数据库ORM框架,这个库完全采用Ja ...

  3. 在node.js中使用COOKIE

    node.js中如何向客户端发送COOKIE呢?有如下两个方案: 一.使用response.writeHead,代码示例: //设置过期时间为一分钟 var today = new Date(); v ...

  4. Node.js中的URL

    Node.js中的URL 什么是URL URL是Uniform Location Resource的缩写,翻译为"统一资源定位符",也就是描述资源位置的固定表示方法.被URL描述的 ...

  5. node.js中对 redis 的安装和基本操作

    一.win下安装redis https://github.com/MicrosoftArchive/redis/releases 下载Redis-x64-3.2.100.zip,然后解压,放到自定义目 ...

  6. Node.js中环境变量process.env详解

    Node.js中环境变量process.env详解process | Node.js API 文档http://nodejs.cn/api/process.html官方解释:process 对象是一个 ...

  7. Node.js中流程控制

    Node.js中的流程控制可以使用async,在使用之前需要先安装,使用npm安装 npm install async --g 下面主要介绍4种流程控制的方式: 1.串行无关联:async.serie ...

  8. 配置node.js中的express框架

    玩node.js,不玩后台那就是杀鸡牛刀,今天没事整理一下以前开发node.js后台的心得 1.首先安装node.js以及cnpm,在这儿我就不说了,看我node.js中的另一篇文章node.js的安 ...

  9. 【nodejs原理&源码赏析(7)】【译】Node.js中的事件循环,定时器和process.nextTick

    [摘要] 官网博文翻译,nodejs中的定时器 示例代码托管在:http://www.github.com/dashnowords/blogs 原文地址:https://nodejs.org/en/d ...

随机推荐

  1. hdu-1016素数环

    这个题就是给出一个数字n,表示有n个数.编号为1~n. 然后要求我们将这n个数连起来变成一个环,要求随意两个数相加所得值必须为素数. 假设满足条件就将这个环输出来! 这个题:dfs+回溯+推断.然后注 ...

  2. VSTO学习笔记(二)Excel对象模型

    原文:VSTO学习笔记(二)Excel对象模型 上一次主要学习了VSTO的发展历史及其历代版本的新特性,概述了VSTO对开发人员的帮助和效率提升.从这次开始,将从VSTO 4.0开始,逐一探讨VSTO ...

  3. ThinkPHP---RBAC

    一.什么是RBAC 基于角色的访问控制(Role-Based Access Control)作为传统访问控制(自主访问,强制访问)的有前景的代替受到广泛的关注. 在RBAC中,权限与角色相关联,用户通 ...

  4. poj1836--Alignment(dp,最长上升子序列变形)

    Alignment Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 13319   Accepted: 4282 Descri ...

  5. iOS App 性能优化总结

    今天简单总结一些clientapp 优化的方案和方向. 我相信开发一个app大部分团队都能够完毕,可是性能久不一样啦,和我们都写一个冒泡算法一样,我相信每一个人写的冒泡算法都不一样,这些区别就带来了性 ...

  6. HDU4685 Prince and Princess 完美搭配+良好的沟通

    意甲冠军:今天,有n王子,m公主.现在给他们配对,与王子会嫁给一个男人,他喜欢.公主无法做出选择. 这标题去咬硬,还有一类似的题目poj1904.那个题目也是给王子与公主配对,但那个是王子公主各n个, ...

  7. 使用WIX打包客户端程序

    原文:使用WIX打包客户端程序 用WPF为客户做了个小工具,打包的时候发现VS2012居然没有安装项目了,搜了下才知道现在推荐使用WIX来打包了http://wix.sourceforge.net/, ...

  8. CRL 版本2.1.0.0下载

    此次更新完善了部份功能,详情见UpdateLog,重新整理了开发文档,更美档,更详细 百度盘下载 下载地址: 百度盘下载

  9. Linux C 编程内存泄露检測工具(二):memwatch

    Memwatch简单介绍 在三种检測工具其中,设置最简单的算是memwatch,和dmalloc一样,它能检測未释放的内存.同一段内存被释放多次.位址存取错误及不当使用未分配之内存区域.请往http: ...

  10. 安装了VS2010 sp1 后再安装ASP.NET MVC 3.0的问题(Final Result: Installation failed with error code: (0x80070643), "安装时发生严重错误 " (Ela)

    原文:安装了VS2010 sp1 后再安装ASP.NET MVC 3.0的问题(Final Result: Installation failed with error code: (0x800706 ...