var vue = require('vue');

引入vue的意思,commonjs的写法。node都是用require来载入模块的,可以看看webpack+vue。

require()可以调用模块。

这不是就把vue模块命了个名吗?

nodejs的写法,引入vue模块并命名为vue的意思。前端的东西,大多都是跑在nodejs上的,所以引用模块方式就必须按照nodejs标准

===================================================================

链接:https://blog.csdn.net/u011146511/article/details/78992040

mysql权限:http://blog.csdn.net/anzhen0429/article/details/78296814

npm的mysql地址:https://www.npmjs.com/package/mysql

---------------直连mysql-------------

var router = function(app){
app.get('/one', function (req, res) {
res.writeHeader(200, {'Content-Type':'text/plain;charset=UTF-8'});
// res.sendFile("/Users/wofu/Desktop/node/views/one.html");
res.write("ddd");
var mysql=require('mysql');//调用mysql模块
//创建一个connection数据库连接对象
var connection=mysql.createConnection({
host:'localhost',//主机
user:'root',//mysql认证的用户名
password:'123456',//mysql用户密码
database:'firstDB',//数据库名
port:'3306'//端口号
});
//链接数据库
connection.connect(function(err){
if(err){
console.log(err);
return;
}else{
res.write("数据库连接成功");
res.end();
}
});
//插入数据,,update和delete跟insert类似
var name="lamb9";
var ages=30;
var userAddSql='insert into people (name,ages) values(?,?)';
var params=[name,ages];
******加参数的方法,应用于sql语句中有?占位符的情况
connection.query(userAddSql,params,function(err,rs){
if(err){
console.log(err.message);
return;
}else {
console.log("插入成功");
console.log(rs);
}
});

//*****query语句不加第二个参数************************************
var nam="lamb10";
var ag=30;
var userAddSql='insert into people (name,ages) values("lambo10",20)';
connection.query(userAddSql,function(err,rs){
if(err){
console.log(err.message);
return;
}else {
console.log("插入成功");
console.log(rs);
}
});
//删除---query带参数**********************************************
var userdeletSql='delete from people where id=?';
var upparams=6;
connection.query(userdeletSql,upparams,function(err,rs,fields){
if(err){
console.log(err);
return ;
}else{
console.log("删除成功");

}
});

//删除---query不带参数***************************************************
var userdeletSql='delete from people where id=7';
connection.query(userdeletSql,function(err,rs,fields){
if(err){
console.log(err);
return ;
}else{
console.log("删除成功");

}
});
//查询-----query带参数************************************************
var userinsertSql='SELECT *from people where name=?';
var insertparams='lambo';
connection.query(userinsertSql,insertparams,function(err,rs,fields){
if(err){
console.log(err);
return ;
}else{
console.log("查询成功");
for(var i=0;i<rs.length;i++){
console.log(rs);
console.log(rs[0].name);//rs是查询的结果集,是一个二维数组,第一维是一条记录,第二维是一条记录中的各字段值
}
}
});

///qurey不带参数************************************************
var userinsertSql='SELECT *from people where name="lambo"';

connection.query(userinsertSql,function(err,rs,fields){
if(err){
console.log(err);
return ;
}else{
console.log("查询成功");
for(var i=0;i<rs.length;i++){
console.log(rs);
console.log(rs[0].name);//rs是查询的结果集,是一个二维数组,第一维是一条记录,第二维是一条记录中的各字段值
}
}
});
//更新---query带参数**********************************************
var userupdatetSql='update people set ages=? where name=?';
var upparams=[23,"four"];
connection.query(userupdatetSql,upparams,function(err,rs,fields){
if(err){
console.log(err);
return ;
}else{
console.log("更新成功");

}
});

//更新---query不带参数***************************************************
var userupdatetSql='update people set ages=24 where name="four"';
connection.query(userupdatetSql,function(err,rs,fields){
if(err){
console.log(err);
return ;
}else{
console.log("更新成功");

}
});
//关闭连接
connection.end(function(err){
if(err){
console.log(err.toString());
return;
}else{
console.log("关闭连接");
}
});
});
};

exports.router = router;
=======================连接池连接mysql=====================

连接池的原理:初始化的时候创建多个连接,放到数组中存起来;当有访问数据的时候,不用再创建连接,直接从连接池取出连接使用进行各种数据库操作,操作关闭后再放回连接池中;连接池会自动管理池中的连接(当访问量少的时候,会自动减少一些连接,当访问量大的时候会自动增加一些连接);

安装连接池 :1.需要安装mysql:npm install mysql -g   2.需要安装mysqlpool模块npm install -g node-mysql

*********************创建连接池

var router = function(app){
var mysql=require('mysql');//调用mysql模块
app.get('/one', function (req, res) {
// res.sendFile("/Users/wofu/Desktop/node/views/one.html");
res.writeHeader(200, {'Content-Type':'text/plain;charset=UTF-8'});
res.write("ddd");

//***使用连接池操作数据库
var Pool=mysql.createPool({
host:'localhost',//主机
user:'root',//mysql认证的用户名
password:'123456',//mysql用户密码
database:'firstDB',//数据库名
port:'3306'//端口号
});
//有连接时调用
Pool.on('connection', function (connection,err) {
if(err){ console.log(err);
return;}else{res.write("数据库连接成功");
res.end();
}
});

//一个连接上的活动全部执行完时调用
Pool.on('acquire', function (connection) {
console.log('Connection %d acquired', connection.threadId);
});
//等待一个有效队列
Pool.on('enqueue', function () {
console.log('Waiting for available connection slot');
});
//一个连接释放了
Pool.on('release', function (connection) {
console.log('Connection %d released', connection.threadId);
});

// //结束所有连接
// Pool.end(function (err) {
// if (err){
// console.log(err);
// }else {
// console.log("连接全部关闭");
// }
// });

//从链接池中获取一个连接
Pool.getConnection(function(err,connection){
// 执行数据库操作 增删改查和直接连接mysql一样
var userAddSql='insert into people (name,ages) values(?,?)';
var params=['bbb',11];
connection.query(userAddSql,params,function(err,rs){
if(err){
console.log(err.message);
return;
}else{
console.log('insert success');
res.write("成功");
res.end();//这句话表示浏览器相应结束,如果在这句话后继续向浏览器写入会报错,res.write()是错误的;
}

connection.release();//放回连接池
});
});
});
};
exports.router = router;
var router = function(app){
var fs =require('fs');
var http=require('https');
var mysql=require('mysql');//调用mysql模块
var request = require('request');
var url = require('url');
var querystring = require('querystring');
var bodyParser = require("body-parser");
var urlencodedParser = bodyParser.urlencoded({ extended: false })
app.get('/get',function (req, res) {
// console.log(req.query);//{ name: 'lambo' }
// console.log(req.query.name);//lambo
// console.log(req.url);///one?name=lambo
// console.log(url.parse(req.url).pathname);// /one
// console.log(url.parse(req.url).query);// name=lambo
// app.post('/one',urlencodedParser,function (req, res) {

//text/html,application/json", @"text/json", @"text/javascript",@"text/html",
//@"text/xml", @"text/plain; charset=utf-8",image/png
// res.writeHeader(200, {'Content-Type':'image/png;charset=UTF-8'});
res.writeHeader(200, {'Content-Type':'text/html;charset=UTF-8'});
// res.writeHeader(200, {'Content-Type':'application/json;charset=UTF-8'});

// 输出 JSON 格式
var json = JSON.stringify({
"msg":"成功",
result:[{
"name":"新闻",
"site":"http:www.baidu.com"
},{
"name":"新手教程",
"site":"csdnnnn"
}],
"status":"1"
}
);
console.log(json);
res.write(json);
res.end(json);

//***使用连接池操作数据库
var Pool=mysql.createPool({
host:'localhost',//主机
user:'root',//mysql认证的用户名
password:'123456',//mysql用户密码
database:'firstDB',//数据库名
port:'3306'//端口号
});
//

Pool.on('connection', function (connection,err) {
if(err){
console.log(err);
return;
}else{
// res.write("数据库连接成功");
// res.end();
}

});
//
//监听----获得一个连接时调用
Pool.on('acquire', function (connection) {
console.log('Connection %d acquired', connection.threadId);
});
//等待一个有效队列
Pool.on('enqueue', function () {
console.log('Waiting for available connection slot');
});
//一个连接释放了
Pool.on('release', function (connection) {
console.log('Connection %d released', connection.threadId);
});

// //结束所有连接
// Pool.end(function (err) {
// if (err){
// console.log(err);
// }else {
// console.log("连接全部关闭");
// }
// });

//从链接池中获取一个连接
Pool.getConnection(function(err,connection){
// // *************执行数据库操作 增删改查和直接连接mysql一样
// //插入,query加占位
// var userAddSql='insert into people (name,age,birthday) values(?,?,?)';
// var params=['bbb',11,new Date()];
// connection.query(userAddSql,params,function(err,rs){
// if(err){
// console.log(err.message);
// return;
// }else{
// console.log('insert success');
//
//
// var json = JSON.stringify({
// "msg":"成功",
// result:[{
// "name":"新闻",
// "site":"http:www.baidu.com"
// },{
// "name":"新手教程",
// "site":"csdnnnn"
// }],
// "status":"1"
// }
// );
//
// res.write(json);
// res.end();
// }
// });//****************

// //******插入,query不加占位,直接写参数
// var nam="lamb10";
// var ag=30;
// var userAddSql='insert into people (name,age,birthday) values("nam",21,now())';
// connection.query(userAddSql,function(err,rs){
// if(err){
// console.log(err.message);
// return;
// }else {
// console.log("插入成功");
// console.log(rs);
// }
// });//*********

// //*****删除---query加占位**********************************************
// var userdeletSql='delete from people where id=?';
// var upparams=269;
// connection.query(userdeletSql,upparams,function(err,rs,fields){
// if(err){
// console.log(err);
// return ;
// }else{
// console.log("删除成功");
//
// }
// });//**************
//
// //删除---query不加占位**************************************************
// var userdeletSql='delete from people where id=7';
// connection.query(userdeletSql,function(err,rs,fields){
// if(err){
// console.log(err);
// return ;
// }else{
// console.log("删除成功");
//
// }
// });//*************
//
// //查询-----query带占位************************************************
// var userinsertSql='SELECT *from people where name=?';
// var insertparams='lambo2';
// connection.query(userinsertSql,insertparams,function(err,rs,fields){
// if(err){
// console.log(err);
// return ;
// }else{
// console.log("查询成功");
// for(var i=0;i<rs.length;i++){
// console.log(rs);
// console.log(rs[0].name);//rs是查询的结果集,是一个二维数组,第一维是一条记录,第二维是一条记录中的各字段值
// }
// }
// });//**********************
//
//
// ///查询----不带占位************************************************
// var userinsertSql='SELECT *from people where name="bbb"';
// connection.query(userinsertSql,function(err,rs,fields){
// if(err){
// console.log(err);
// return ;
// }else{
// console.log("查询成功");
// for(var i=0;i<rs.length;i++){
// console.log(rs);
// console.log(rs[0].name);//rs是查询的结果集,是一个二维数组,第一维是一条记录,第二维是一条记录中的各字段值
// }
// }
// });//***************************
//

// //更新---带占位**********************************************
// var userupdatetSql='update people set age=? where name=? and id=?';
// var upparams=[23,"lambo2",3];
// connection.query(userupdatetSql,upparams,function(err,rs,fields){
// if(err){
// console.log(err);
// return ;
// }else{
// console.log("更新成功");
//
// }
// });//*******************
//

// //更新---不带占位***************************************************
// var userupdatetSql='update people set age=24 where name="lambo2" and id=11';
// connection.query(userupdatetSql,function(err,rs,fields){
// if(err){
// console.log(err);
// return ;
// }else{
// console.log("更新成功");
//
// }
// });//******************

// //关闭当前的连接连接
// connection.end(function(err){
// if(err){
// console.log(err.toString());
// return;
// }else{
// console.log("关闭连接");
// }
// });

connection.release();//放回连接池
});//poolconnect

});//get请求
};
exports.router = router;

js中require()的用法----JS如何连接数据库执行sql语句或者建立数据库连接池的更多相关文章

  1. SQLCMD的用法,使用CMD 执行sql语句

    SQLCMD的用法,使用CMD 执行sql语句 SQLCMD 允许在Windows命令窗中通过命令行提示符运行脚本. 语法如下: sqlcmd  [  { { -U <login id> ...

  2. BIML 101 - ETL数据清洗 系列 - BIML 快速入门教程 - 连接数据库执行SQL语句

    BIML 101 - BIML 快速入门教程 第一节 连接数据库执行SQL语句 本小节将用BIML建一个简单的可以执行的包. 新建一个biml文件,贴入下面的代码 1 <Biml xmlns=& ...

  3. [转载]js中return的用法

    一.返回控制与函数结果,语法为:return 表达式; 语句结束函数执行,返回调用函数,而且把表达式的值作为函数的结果 二.返回控制,无函数结果,语法为:return;  在大多数情况下,为事件处理函 ...

  4. js中this的用法

    经过近几周的模拟面试题,我查询了一些资料,今天就来说说,在js中this的用法吧.方法有四:第一,用作全局变量,第二,用作表该对象,第三,用作构造函数,第四,用作call和applay

  5. JQuery之append和appendTo的区别,还有js中的appendChild用法

    JQuery之append和appendTo的区别 append()前面是要选择的对象,后面是要在对象内插入的元素内容 appendTo()前面是要插入的元素内容且为Jquery对象,而后面是要选择的 ...

  6. JS中event.keyCode用法及keyCode对…

    js中event.keyCode用法及keyCode对照表 标签: javascriptJavaScriptJavascriptjavaScript 2012-12-11 15:11 HTML Jav ...

  7. 浅谈JS中 reduce() 的用法

    过去有很长一段时间,我一直很难理解 reduce() 这个方法的具体用法,平时也很少用到它.事实上,如果你能真正了解它的话,其实在很多地方我们都可以用得上,那么今天我们就来简单聊聊JS中 reduce ...

  8. JS中 reduce() 的用法

    过去有很长一段时间,我一直很难理解 reduce() 这个方法的具体用法,平时也很少用到它.事实上,如果你能真正了解它的话,其实在很多地方我们都可以用得上,那么今天我们就来简单聊聊JS中 reduce ...

  9. (转载)总结一下SQL语句中引号(')、quotedstr()、('')、format()在SQL语句中的用法

    总结一下SQL语句中引号(').quotedstr().('').format()在SQL语句中的用法 总结一下SQL语句中引号(').quotedstr().('').format()在SQL语句中 ...

随机推荐

  1. UE4 中的Blutilities

    该功能是为编辑器中的简单扩展功能而设置的. 一般而言用蓝图在编辑器中做功能扩展都会用到Construction Script,但该功能有一些缺陷: 首先在actor发生任何变化(包括Transform ...

  2. php面试专题---mysql数据库分库分表

    php面试专题---mysql数据库分库分表 一.总结 一句话总结: 通过数据切分技术将一个大的MySQLServer切分成多个小的MySQLServer,既攻克了写入性能瓶颈问题,同一时候也再一次提 ...

  3. 杂项-SAP:SAP (服务访问点(Service Accessing point))

    ylbtech-杂项-SAP:SAP (服务访问点(Service Accessing point)) 1.返回顶部 1. SAP,是Service Accessing point的缩写,意思是服务访 ...

  4. MYSQL数据库中的查询语句

    查询的方法 *简单查询:select * from 表名 (* = 所有的) *读取特定列:select 字段一,字段二 from 表名 *条件查询:select * from 表名 where (多 ...

  5. Vagrant 手册之同步目录 - VirtualBox

    原文地址 如果你使用的 provider 是 VirtualBox,那么 VirtualBox 同步目录就是默认的同步目录类型.这些同步目录使用 VirtualBox 的共享目录系统来同步客户机跟宿主 ...

  6. _exit和exit的区别

    在linux的标准库函数中,有一套称作高级I/O的函数,我们熟知的printf .fopen .fread .fwrite都在此列,他们也被称作缓冲I/O.其特征是对应每一个打开的文件,都存在一个缓冲 ...

  7. Game on a Tree Gym - 102392F(树上最大匹配)

    思路: 本质是求一个树上的最大匹配能否覆盖所有的点. dfs遍历,用qian[]数组记录当前节点的子树内有几个没有匹配的点(初始化为-1因为可以匹配掉一个子树中未匹配的点),pipei[]数组记录当前 ...

  8. 【python】随机数相关

    http://www.cnblogs.com/yd1227/archive/2011/03/18/1988015.html 该博文写的很详细,备忘. 需要注意的是,写测试脚本的时候,不要将脚本命名成跟 ...

  9. (转载)Java 8 认识 HashMap

    原链接:传送门 摘要 HashMap是Java程序员使用频率最高的用于映射(键值对)处理的数据类型.随着JDK(Java Developmet Kit)版本的更新,JDK1.8对HashMap底层的实 ...

  10. 《STL源码剖析》——第一、二、三章

     第一章:概论: 换句话说,STL所实现的,是依据泛型思维架设起来的一个概念结构.这个以抽象概念(abstract concepts)为主体而非以实际类(classes)为主体的结构,形成了一个严谨的 ...