msnodesql的使用
npm install msnodesql
使用msnodesql写的增删改查
var sql=require('msnodesql');
var conn_str="Driver={SQL Server Native Client 11.0};Server={127.0.0.1};Database=AccJiaowu;uid=sa;PWD=XXX;";
//添加
var insert = function(sqlscript,callback) {
sql.open(conn_str, function (err, conn) {
if (err) {
console.log('发生错误');
}
sql.queryRaw(conn_str,sqlscript, function (err, results) {
if (err) {
console.log(err);
callback(JSON.stringify("error"));
}else {
callback(JSON.stringify("ok"));
}
});
});
}
//修改
var update = function(sqlscript,callback) {
sql.open(conn_str, function (err, conn) {
if (err) {
console.log('发生错误');
}
sql.queryRaw(conn_str, sqlscript, function (err, results) {
if (err) {
console.log(err);
callback(JSON.stringify("error"));
}
else {
callback(JSON.stringify("ok"));
}
});
});
}
//查询返回集合
var selectList = function(sqlscript,callback) {
sql.open(conn_str, function (err, conn) {
if (err) {
console.log('发生错误');
}
sql.queryRaw(conn_str, sqlscript, function (err, results) {
if (err) {
console.log(err);
}else {
var txt=toJsonArray(results);
var jsonObj=eval("("+txt+")");
console.log(jsonObj);
callback(jsonObj);
}
});
});
}
//查询返回单个数据
var selectOne = function(sqlscript,callback) {
sql.open(conn_str, function (err, conn) {
if (err) {
console.log('发生错误');
}
sql.queryRaw(conn_str, sqlscript, function (err, result) {
if (err) {
console.log(err);
}else {
var txt=toJson(result);
var jsonObj=eval("("+txt+")");
console.log(jsonObj);
callback(jsonObj);
}
});
});
}
//将查询结果转成json串
function toJson(dt)
{
var jsonString;
if (dt != undefined && dt.rows.length == 1)
{
var rowLen=dt.rows.length;
var colLen=dt.meta.length;
jsonString="{";
for (var j = 0; j < colLen; j++)
{
if (j < colLen - 1)
{
jsonString+="\"" + dt.meta[j].name + "\":" + "\"" + dt.rows[0][j]+ "\",";
}
else if (j == colLen - 1)
{
jsonString+="\"" + dt.meta[j].name + "\":" + "\"" + dt.rows[0][j] + "\"";
}
}
jsonString+="}";
return jsonString;
}
return jsonString;
}
//将查询结果转成json数组
function toJsonArray(dt)
{
var jsonString;
if (dt != undefined && dt.rows.length > 0)
{
var rowLen=dt.rows.length;
var colLen=dt.meta.length;
jsonString="{";
jsonString+="\"data\":[";
for (var i = 0; i < rowLen; i++)
{
jsonString+="{";
for (var j = 0; j < colLen; j++)
{
if (j < colLen - 1)
{
jsonString+="\"" + dt.meta[j].name + "\":" + "\"" + dt.rows[i][j]+ "\",";
}
else if (j == colLen - 1)
{
jsonString+="\"" + dt.meta[j].name + "\":" + "\"" + dt.rows[i][j] + "\"";
}
}
if (i == rowLen - 1)
{
jsonString+="}";
}
else
{
jsonString+="},";
}
}
jsonString+="]}";
return jsonString;
}
return jsonString;
}
exports.insert = insert;
exports.update = update;
exports.selectOne = selectOne;
exports.selectList = selectList;
写sql调用封装的方法
var handlers = require("./handlers");
var result = "";
var http = require('http'),
url = require("url");
http.createServer(function (req,res){
var arg = url.parse(req.url,true).query; //方法一arg => aa=001&bb=002
console.log(arg);
console.log(url.parse(req.url).query);
var userID = arg.userID;
var userName = arg.userName;
var password = arg.password;
var age = arg.age;
var pathname = url.parse(req.url).pathname;
console.log("userID:"+userID+";userName:"+userName+";password="+password+";age:"+age+";pathname:"+pathname);
if(pathname == "/selectList"){
var selSql = "select userID,userName,password,age from Table_1 with(nolock) ";
handlers.selectList(selSql,function(data){
console.log("select data:"+data);
result = data;
});
}else if(pathname == "/selectOne"){
var selSql = "select count(1) as cnt from Table_1 with(nolock) where userName ='"+userName+"' and password='"+password+"'";
handlers.selectOne(selSql,function(data){
console.log("select data:"+data);
result = data;
});
}else if(pathname == "/insert"){
var insSql = "insert into Table_1 (userName,password,age) values('"+userName+"','"+password+"',"+ age +")";
handlers.insert(insSql,function(data){
console.log("insert data:"+data);
result = data;
});
}else if(pathname == "/update"){
var updSql = "update Table_1 set userName = '"+userName+"',password = '"+password+"',age = "+age+" where userID = "+userID;
handlers.update(insSql,function(data){
console.log("update data:"+data);
result = data;
});
}
//res.writeHead(200,{'Content-Type':'text/html;charset=utf-8'}); //'Access-Control-Allow-Origin':'http://localhost/'}
console.log(result);
var str = arg.callback + '(' + JSON.stringify(result) + ')'
console.log(str);
res.end(str);
}).listen(8080,"localhost");
console.log('Server running at http://localhost:8080/')
ajax调用
$.ajax({
url: 'http://localhost:8080/selectList', //请求的是3000端口,应该属于跨域调用,因此dataType用jsonp
dataType: "jsonp",
//jsonpCallback: "_test", //可以自定义‘处理’函数,默认是callback
cache: false,
jsonp:'callback', //默认的传递处理函数是callback
timeout: 5000,
data : {},
success: function(data) {
var userList = data.data;
var tabStr="";
for(var i=0;i<userList.length;i++){
tabStr += "<tr>";
tabStr += "<td>"+userList[i].userID+"</td>";
tabStr += "<td>"+userList[i].userName+"</td>";
tabStr += "<td>"+userList[i].password+"</td>";
tabStr += "<td>"+userList[i].age+"</td>";
tabStr += "</tr>"
}
$("#dataTab").html(tabStr);
},
error: function(jqXHR, textStatus, errorThrown) {
alert('error ' + textStatus + " " + errorThrown);
}
});
msnodesql的使用的更多相关文章
- node.js 访问sql server的 node_modules “msnodesql"的安装编译方法
http://stackoverflow.com/questions/19661811/unable-to-download-msnodesql-0-2-1-v0-10-x64-msi 首先要满足以下 ...
- nodejs怎么同步从一个数据库查询函数中返回一个值
var sql=require('msnodesql'); var conn_str="Driver={SQL Server Native Client 11.0};Server={127. ...
- azure git 托管
azure git上传部署步骤:(首次提交)cd 至本地代码路径git initgit add .git commit –m "initial commit"git remote ...
- NodeJS下访问SQL Server
1.下载node-sqlserver (1)msnodesql (msnodesql-0.2.1-v0.8-x64.msi)下载地址:下载 自行选择与自己系统相符的版本,点击安装. (2)msnod ...
- Nodejs与Net 和SQL 交互利器Edge.js
https://github.com/tjanczuk http://www.cnblogs.com/joylee/archive/2013/02/05/msnodesql.html edge.js这 ...
随机推荐
- Linggle: 英语写作学习搜索引擎
Linggle 搜索引擎是一个可用于英语写作的语法.句子工具,可帮助学习者分析更准确的英文写作建议,能够根据词性来推测短句和句子,可精准的分享出完整英文句子如何撰写. Linggle 是台湾学术团队研 ...
- iOS开发资料链接
ios开发中文文档了 http://developer.apple.com/library/ios/#referencelibrary/GettingStarted/RoadMapiOSCh/chap ...
- Codeforces Round #369 (Div. 2) C. Coloring Trees DP
C. Coloring Trees ZS the Coder and Chris the Baboon has arrived at Udayland! They walked in the pa ...
- Java利用Preferences设置个人偏好
Java利用Preferences设置个人偏好 Preferences的中文意思即偏好或喜好的意思,也就是说同一个程序在每次运行完后,可以通过Preferences来记录用户的偏好,下次启动时,程序会 ...
- 自定义 ActionBar 标题与菜单中的文字样式
自定义标题文字样式 标题样式是 ActionBar 样式的一部分,所以要先定义 ActionBar 的样式 <style name="AppTheme" parent=&qu ...
- 使用recon/domains-hosts/baidu_site模块,枚举baidu网站的子域
使用recon/domains-hosts/baidu_site模块,枚举baidu网站的子域 [实例3-1]使用recon/domains-hosts/baidu_site模块,枚举baidu网站的 ...
- Delphi 包的设计思想及它与PAS、BPL、DCU、DLL、OXC的关系。
DCP ,BPL分别是什么文件,起什么作用?你在DELPHI中建立一个package然后保存一下,看看. bpl和Dll比较相似.只是BPL是BORLAND自己弄出来的东西!!!调用也和调用DLL相似 ...
- sqoop学习
最近学习了下这个导数据的工具,但是在export命令这里卡住了,暂时排不了错误.先记录学习的这一点吧 sqoop是什么 sqoop(sql-on-hadoop):是用来实现结构型数据(如关系型数据库) ...
- 转载:Robotium之Android控件定位实践和建议(Appium/UIAutomator姊妹篇)
来源于:http://blog.csdn.net/zhubaitian/article/details/39803857 1. 背景 为保持这个系列的一致性,我们继续用SDK自带的NotePad实例应 ...
- BZOJ4568 : [Scoi2016]幸运数字
树的点分治,每次求出重心后,求出重心到每个点路径上的数的线性基. 对于每个询问,只需要暴力合并两个线性基即可. 时间复杂度$O(60n\log n+60^2q)$. #include<cstdi ...