node连接数据库(express+mysql)
操作是在ubuntu系统的下环境,简单记录一下过程。
首先用apt-get安装数据库,键入命令 sudo apt-get install mysql-server , 一路回车,然后在一个界面设置一下数据库root的密码就好了
在数据库里面我们需要创建一些东西。键入 mysql -uroot -p××××× 来进入sql控制台。
1.先创建数据集 create database databasename ;
2.use database databasename ;
3.建表(这里创建一个很简单的,只有自增id,用户名和密码)
create table user_info (
id int(11) not null auto_increment,
username varchar(30) not null,
password varchar(30) not null,
primary key ( id )
)ENGINE=InnoDB DEFAULT CHARSET=utf8 ;
4.插入一条数据 insert into user_info values(1,'mtjss2','123456') ;
下面是node的部分
创建一个文件夹,比如叫myapp,在里面npm init之后就会也node_modules的依赖文件夹
用 npm install --save 安装如下依赖
1.express
2.mysql
3.body-parser(用来解析post参数)
由于express好像没有自己的数据库封装,所以一般会新建models文件夹,然后写数据库的逻辑,如果只是想简单测试可以直接写在app.js中
这里举例在models下有一个user.js的逻辑封装类,暂时只有一个通过username获取用户信息的方法,其他可以以后加
   var mysql = require('mysql') ;
   //connection config
   var connection = mysql.createConnection({
       host : 'localhost' ,
       user : 'root' ,
       password : '123456' ,
       database : 'my_box'
  });
  function User(user){
      this.username = user.username ;
      this.password = user.password ;
  }
  User.getUserbyUsername = function(username,callback){
      var selectSql = 'select * from user_info where username = ?' ;
     connection.query(selectSql,[username],function(err,res){
      ¦   if(err){
      ¦   ¦   console.log('getUserbyUsername err:' + err) ;
      ¦   ¦   return ;
      ¦   }
      ¦   console.log('Get name success') ;
      ¦   callback(err,res) ;
      }) ;
  } ;
  module.exports = User ;
再贴一下app.js暂时没写路由,就是对/和/reg方法的处理
   var mysql = require('mysql') ;
   //connection config
   var connection = mysql.createConnection({
       host : 'localhost' ,
       user : 'root' ,
       password : '123456' ,
       database : 'my_box'
   });
  function User(user){
      this.username = user.username ;
      this.password = user.password ;
  }
  User.getUserbyUsername = function(username,callback){
      var selectSql = 'select * from user_info where username = ?' ;
      connection.query(selectSql,[username],function(err,res){
      ¦   if(err){
      ¦   ¦   console.log('getUserbyUsername err:' + err) ;
      ¦   ¦   return ;
      ¦   }
      ¦   console.log('Get name success') ;
      ¦   callback(err,res) ;
      }) ;
  } ;
  module.exports = User ;
index.html这个主页面在views文件夹下,没什么代码,不过也贴一下
<!DOCTYPE html>
<html>
<head>
<title>my box</title>
</head>
<body>
<form action="/reg" method="post">
<input type="text" name="username"/>
<input type="submit" value="submit"/>
</form>
</body>
</html>
这样用 node app.js 启动以后在浏览器里访问 localhost:3000就行了,在input里输入数据库中的用户名可以的得到那条数据。
node连接数据库(express+mysql)的更多相关文章
- node+pm2+express+mysql+sequelize来搭建网站和写接口
		前面的话:在这里已经提到了安装node的方法,node是自带npm的.我在技术中会用es6去编写,然后下面会分别介绍node.pm2.express.mysql.sequelize.有少部分是摘抄大佬 ... 
- Vue+node.js+express+mysql实例---对图书信息进行管理
		一个简单的 CURD 实例 ---对图书信息进行管理 目录 1 开发环境 1.1 前端开发环境 1.2 后端开发环境 2 数据库设计和创建 2.1 数据库和表设计 2.2 book 表设计 2.3 s ... 
- nodejs+express+mysql实现restful风格的增删改查示例
		首先,放上项目github地址:https://github.com/codethereforam/express-mysql-demo 一.前言 之前学的java,一直用的ssm框架写后台.前段时间 ... 
- 使用 NodeJS+Express+MySQL 实现简单的增删改查
		关于node.js暂时记录如下,以后有时间一定学习 文章来自简书,作者:sprint,2016-07 使用 Node.js + Express+MySQL 实现简单的增删改查 https://www. ... 
- 进入全屏 nodejs+express+mysql实现restful风格的增删改查示例
		首先,放上项目github地址:https://github.com/codethereforam/express-mysql-demo 一.前言 之前学的java,一直用的ssm框架写后台.前段时间 ... 
- 应用node+express+mysql  实现简单的增删改查
		记录下来备忘 1.准备好webstrom编辑器,编辑器调整字体大小等在file->settings->editor下设置 注册码 来源网上: 2017.2.27更新 选择“license ... 
- vue+express+mysql +node项目搭建
		项目搭建前需要先安装node环境及mysql数据库. 1.利用vue-cli脚手架创建一个vue项目 a.全局安装 npm install -g vue-cli b.初始化项目 vue init we ... 
- Node.js Express连接mysql完整的登陆注册系统(windows)
		windows学习环境: node 版本: v0.10.35 express版本:4.10.0 mysql版本:5.6.21-log 第一部分:安装node .Express(win8系统 需要&qu ... 
- Node.js连接Mysql,并把连接集成进Express中间件中
		引言 在node.js连接mysql的过程,我们通常有两种连接方法,普通连接和连接池. 这两种方法较为常见,当我们使用express框架时还会选择使用中间express-myconnection,可以 ... 
- 前端使用node.js+express+mockjs+mysql实现简单服务端,2种方式模拟数据返回
		今天,我教大家来搭建一个简单服务端 参考文章: https://www.jianshu.com/p/cb89d9ac635e https://www.cnblogs.com/jj-notes/p/66 ... 
随机推荐
- selenium webdriver XPath的定位方法练习 !
			html 代码: <html> <body> <div id="div1"> <input name="divl1input& ... 
- [学习]WireShark 的过滤功能
			1. 打开 wireShark 过滤显示 协议 比如显示arp协议 过滤栏输入arp即可 支持的协议类型 TCP UDP HTTP FTP ICMP SMTP等等 2. 过滤ip地址 ip.addr ... 
- mac下mysql5.7.10密码问题
			mysql5.7.10刚安装好,会生成一个随机密码. 如果没记住这个随机密码,那么到mysql/bin/下执行mysql_secure_installation命令 按照提示重置密码和其他选项. ps ... 
- linux 内核态调试函数BUG_ON()[转]
			一些内核调用可以用来方便标记bug,提供断言并输出信息.最常用的两个是BUG()和BUG_ON(). 当被调用的时候,它们会引发oops,导致栈的回溯和错误信息的打印.为什么这些声明会导致 oops跟 ... 
- 第116天: Ajax运用artTemplate实现菜谱
			Ajax运用artTemplate实现菜谱 一.获取接口数据 1.聚合数据API https://www.juhe.cn,在这上面找到菜谱大全数据接口文档 具体使用是这样的: key后面的数据是 ... 
- 第76天:jQuery中的宽高
			Window对象和document对象的区别 1.window对象表示浏览器中打开的窗口 2.window对象可以省略,比如alert()也可以写成window.alert() Document对象是 ... 
- .net 下SSE使用
			HTML5有一个Server-Sent Events(SSE)功能,允许服务端推送数据到客户端.(通常叫数据推送),基于数据推送是这样的,当数据源有新数据,它马上发送到客户端,不需要等待客户端请求.这 ... 
- Oracle中三种循环(For、While、Loop)案例
			1.ORACLE中的FOR循环用法(九九乘法表) declare i ; j ; begin .. loop ..i loop Dbms_Output.put(i||'*'||j||'='||i*j) ... 
- 对于最近的一些日常总结by520(17.10.18)
			---天天考试,各种题型都有,学到了很多新的知识,也发现了自己的许多不足---1.首先,自己的搜索需要加强,特别是广搜,10.18的T1裸广搜没有做对.2.数学的思维和一些逻辑问题需要加强,然后就是要 ... 
- CodeForces - 955B(用char会超时。。。)
			#include <bits/stdc++.h> #define mem(a, b) memset(a, b, sizeof(a)) using namespace std; , INF ... 
