nodejs中mysql用法 - TOMMYHU - 专注互联网开发及运营技术,提供相关资料及软件下载,奇趣网络时事评论!
May 18

nodejs中mysql用法 不指定

1、建立数据库连接:createConnection(Object)方法
      该方法接受一个对象作为参数,该对象有四个常用的属性host,user,password,database。与php中链接数据库的参数相同。属性列表如下:

还可以使用字符串连接数据库例如:




输出



2、结束数据库连接end()和destroy()
end()接受一个回调函数,并且会在query结束之后才触发,如果query出错,仍然会终止链接,错误会传递到回调函数中处理。
destroy()立即终止数据库连接,即使还有query没有完成,之后的回调函数也不会在触发。

3、创建连接池 createPool(Object)  Object和createConnection参数相同。
可以监听connection事件,并设置session值

connection.release()释放链接到连接池。如果需要关闭连接并且删除,需要使用connection.destroy()
pool除了接受和connection相同的参数外,还接受几个扩展的参数



4、连接池集群
允许不同的host链接


链接集群的可选参数



5、切换用户/改变连接状态





6、处理服务器连接断开



7、转义查询值
为了避免SQL注入攻击,需要转义用户提交的数据。可以使用connection.escape() 或者 pool.escape()
例如:




8、转换查询标识符
如果不能信任SQL标识符(数据库名、表名、列名),可以使用转换方法mysql.escapeId(identifier);


9、准备查询
可以使用mysql.format来准备查询语句,该函数会自动的选择合适的方法转义参数。



11、获取插入行的id
当使用自增主键时获取插入行id,如:


12、流处理
有时你希望选择大量的行并且希望在数据到达时就处理他们,你就可以使用这个方法


13、混合查询语句(多语句查询)
因为混合查询容易被SQL注入攻击,默认是不允许的,可以使用var connection = mysql.createConnection({multipleStatements: true});开启该功能。
混合查询实例:

同样可以使用流处理混合查询结果:

如果其中一个查询语句出错,Error对象会包含err.index指示错误语句的id,整个查询也会终止。
混合查询结果的流处理方式是做实验性的,不稳定。

14、事务处理
connection级别的简单事务处理


15、错误处理


▲返回顶部
Last modified by tommyhu on2014/05/18 20:33

Add a comment

Nickname

emotemotemotemotemotemotemotemotemotemotemotemotemotemotemotemot