var
mysql
=
require('mysql')
//调用MySQL模块
mysql模块要安装
$
npm
install
mysql
//创建一个connection
var
connection
=
mysql.createConnection({
host
:
'127.0.0.1',
//主机
user
:
'root',
//MySQL认证用户名
password
:
'',
//MySQL认证用户密码
port:
'3306',
//端口号
database:''
//数据库名
})
//创建一个connection
connection.connect(function(err){
if(err){
console.log('[query]
-
:'+err)
return
}
console.log('[connection
connect]
succeed!')
})
//执行SQL语句
connection.query('SELECT
1
+
1
AS
solution',
function(err,
rows,
fields)
{
if
(err)
{
console.log('[query]
-
:'+err)
return
}
console.log('The
solution
is:
',
rows[0].solution)
})
//关闭connection
connection.end(function(err){
if(err){
return
}
console.log('[connection
end]
succeed!')
})
注:nodejs在 *** 作数据库的时候不用设置数据库的编码格式
set
names
utf8
希望本文所述对大家nodejs程序设计有所帮助。
您可能感兴趣的文章:nodejs连接mysql数据库简单封装示例-mysql模块nodejs进阶(6)—连接MySQL数据库示例nodejs实现的连接MySQL数据库功能示例Nodejs连接mysql并实现增、删、改、查 *** 作的方法详解nodeJs实现基于连接池连接mysql的方法示例nodejs中 *** 作mysql数据库示例NodeJS链接MySql数据库的 *** 作方法Nodejs使用mysql模块之获得更新和删除影响的行数的方法NodeJs使用Mysql模块实现事务处理实例nodejs连接mysql数据库及基本知识点详解
1、跨进程通信新版的nodejs里增加了对子进程的 *** 作,跨进程通信不是问题。
http://nodejs.org/docs/latest/api/all.html#child_Processes
复制代码 代码如下:
var util = require('util'),
exec = require('child_process').exec,
child
child = exec('cat *.js bad_file | wc -l',
function (error, stdout, stderr) {
console.log('stdout: ' + stdout)
console.log('stderr: ' + stderr)
if (error !== null) {
console.log('exec error: ' + error)
}
})
如例我们可以拿到控制台的输出内容stdout!
2、数据库访问相关ActiveX,ADODB.Connection
参考:http://msdn.microsoft.com/en-us/library/windows/desktop/aa746471%28v=vs.85%29.aspx
复制代码 代码如下:
var connection = new ActiveXObject("ADODB.Connection")
var result = 'ok'
try{
connection.Open("Provider=Microsoft.Jet.OLEDB.4.0Data Source=" + params.accessfile)
connection.Execute(params.sql)
} catch(ex){
result = ex.message
}
return {
result: result
}
connection.Open(connectionString),链接字符串参数可以设置访问sql server。
参考:http://www.connectionstrings.com/sql-server-2005
3、为方便维护,特别将cscript和nodejs的脚本合并,用typeof exports判断当前运行环境。
4、字符编码cscript代码使用ascii编码
非ascii码字符进行“\uHHHH”Unicode编码。
5、命令行字符需转义,双引号、百分号在命令行有特殊意义。
参数传递使用base64编码,避免冲突
cscript环境MSXML2.DOMDocument可以做base64编解码
复制代码 代码如下:
function base64Decode(base64){
var xmldom = new ActiveXObject("MSXML2.DOMDocument")
var adostream = new ActiveXObject("ADODB.Stream")
var temp = xmldom.createElement("temp")
temp.dataType = "bin.base64"
temp.text = base64
adostream.Charset = "utf-8"
adostream.Type = 1// 1=adTypeBinary 2=adTypeText
adostream.Open()
adostream.Write(temp.nodeTypedValue)
adostream.Position = 0
adostream.Type = 2// 1=adTypeBinary 2=adTypeText
var result = adostream.ReadText(-1)// -1=adReadAll
adostream.Close()
adostream = null
xmldom = null
return result
}
前端代码:$(document).ready(function() {
$.ajax({
url: '127.0.0.1:1337', //不知道这个url到底应该填什么
dataType: "jsonp",
data: '{"data": "TEST"}',
type: 'POST',
jsonpCallback: 'callback',
success: function (data) {
var ret = jQuery.parseJSON(data)
console.log('Success: '+ret.msg)
},
error: function (xhr, status, error) {
console.log('Error: ' + error.message)
},
})
})
后端代码:
var http = require('http')
var util = require('util')
http.createServer(function (req, res) {
console.log('Request received: ')
res.writeHead(200, { 'Content-Type': 'text/plain' })
req.on('data', function (chunk) {
console.log('GOT DATA!')
console.log(data)
})
res.end('callback(\'{\"msg\": \"OK\"}\')')
}).listen(1337,'127.0.0.1')
console.log('Server running on port ')
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)