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的使用的更多相关文章

  1. node.js 访问sql server的 node_modules “msnodesql"的安装编译方法

    http://stackoverflow.com/questions/19661811/unable-to-download-msnodesql-0-2-1-v0-10-x64-msi 首先要满足以下 ...

  2. nodejs怎么同步从一个数据库查询函数中返回一个值

    var sql=require('msnodesql'); var conn_str="Driver={SQL Server Native Client 11.0};Server={127. ...

  3. azure git 托管

    azure git上传部署步骤:(首次提交)cd 至本地代码路径git initgit add .git commit –m "initial commit"git remote ...

  4. NodeJS下访问SQL Server

    1.下载node-sqlserver (1)msnodesql (msnodesql-0.2.1-v0.8-x64.msi)下载地址:下载  自行选择与自己系统相符的版本,点击安装. (2)msnod ...

  5. Nodejs与Net 和SQL 交互利器Edge.js

    https://github.com/tjanczuk http://www.cnblogs.com/joylee/archive/2013/02/05/msnodesql.html edge.js这 ...

随机推荐

  1. Linggle: 英语写作学习搜索引擎

    Linggle 搜索引擎是一个可用于英语写作的语法.句子工具,可帮助学习者分析更准确的英文写作建议,能够根据词性来推测短句和句子,可精准的分享出完整英文句子如何撰写. Linggle 是台湾学术团队研 ...

  2. iOS开发资料链接

    ios开发中文文档了 http://developer.apple.com/library/ios/#referencelibrary/GettingStarted/RoadMapiOSCh/chap ...

  3. 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 ...

  4. Java利用Preferences设置个人偏好

    Java利用Preferences设置个人偏好 Preferences的中文意思即偏好或喜好的意思,也就是说同一个程序在每次运行完后,可以通过Preferences来记录用户的偏好,下次启动时,程序会 ...

  5. 自定义 ActionBar 标题与菜单中的文字样式

    自定义标题文字样式 标题样式是 ActionBar 样式的一部分,所以要先定义 ActionBar 的样式 <style name="AppTheme" parent=&qu ...

  6. 使用recon/domains-hosts/baidu_site模块,枚举baidu网站的子域

    使用recon/domains-hosts/baidu_site模块,枚举baidu网站的子域 [实例3-1]使用recon/domains-hosts/baidu_site模块,枚举baidu网站的 ...

  7. Delphi 包的设计思想及它与PAS、BPL、DCU、DLL、OXC的关系。

    DCP ,BPL分别是什么文件,起什么作用?你在DELPHI中建立一个package然后保存一下,看看. bpl和Dll比较相似.只是BPL是BORLAND自己弄出来的东西!!!调用也和调用DLL相似 ...

  8. sqoop学习

    最近学习了下这个导数据的工具,但是在export命令这里卡住了,暂时排不了错误.先记录学习的这一点吧 sqoop是什么 sqoop(sql-on-hadoop):是用来实现结构型数据(如关系型数据库) ...

  9. 转载:Robotium之Android控件定位实践和建议(Appium/UIAutomator姊妹篇)

    来源于:http://blog.csdn.net/zhubaitian/article/details/39803857 1. 背景 为保持这个系列的一致性,我们继续用SDK自带的NotePad实例应 ...

  10. BZOJ4568 : [Scoi2016]幸运数字

    树的点分治,每次求出重心后,求出重心到每个点路径上的数的线性基. 对于每个询问,只需要暴力合并两个线性基即可. 时间复杂度$O(60n\log n+60^2q)$. #include<cstdi ...