restify mysql_[菜鸟试水]关于Nodejs搭建后台API服务(Mysql-Restify)[下]

字数太多,我腰斩一下...

因为是API后台,

没有V只剩MC, 我们先看看Controller吧.也是简单的处理代码.

由require看出,我们需要在JsModule下再建一个文件夹Controll,再在里面新建GuestControll.js

var

Guest=require("../Model/Guest.js");

function

GuestControll(app,Mysql)

{

var

GuestModel=Object.create(Guest.GuestModel);

app.get('/guest/gettodayguest', GetTodayGuests);

//查询今天客人

app.get('/guest/getroombooking',

GetRoomBooking); //查询房间预订信息

app.get('/guest/getguestinfobyid',

GetGuestInfoById); //根据客人id获取信息

app.post('/guest/bookroom', NewGuest);

//预订客房

app.post('/guest/checkin', Checkin);

//入住客房

app.post('/guest/checkout', Checkout);

//退房

app.post('/guest/cancelbooking', CancelBooking);

//取消预订

app.post('/guest/overstay', OverStay);

//续住

function

GetTodayGuests(req, res, next) {

console.log("GetTodayGuests

query:"+JSON.stringify(req.query));

var

Today=req.params.today;

GuestModel.GetTodayGuests(Mysql,Today,function(Data){

res.charSet('utf-8');

res.send(Data);

});

}

function

NewGuest(req, res, next){

res.send('0');

}

function

Checkin(req, res, next) {

console.log("Checkin

param:"+JSON.stringify(req.params));

var

RoomId=req.params.roomid;

GuestModel.Checkin(Mysql,RoomId,function(Rst){

res.charSet('utf-8');

var

SR={iRst:Rst};

res.send(SR);

});

}

function

Checkout(req, res, next) {

console.log("Checkout

param:"+JSON.stringify(req.params));

var

RoomId=req.params.roomid;

GuestModel.Checkout(Mysql,RoomId,function(Rst){

res.charSet('utf-8');

var

SR={iRst:Rst};

res.send(SR);

});

}

function

CancelBooking(req, res, next) {

console.log("CancelBooking

param:"+JSON.stringify(req.params));

var

RoomId=req.params.roomid;

var

GuestStr=req.params.guestStr;

var

GuestArr=eval_r(GuestStr);

console.log(GuestArr);

GuestModel.CancelBooking(Mysql,RoomId,GuestArr,function(Rst){

res.charSet('utf-8');

var

SR={iRst:Rst};

res.send(SR);

});

}

function

OverStay(req, res, next) {

console.log("OverStay

param:"+JSON.stringify(req.params));

var

RoomId=req.params.roomid;

var

StayTime=req.params.staytime;

GuestModel.OverStay(Mysql,RoomId,StayTime,function(Rst){

res.charSet('utf-8');

var

SR={iRst:Rst};

res.send(SR);

});

}

function

GetRoomBooking(req, res, next)

{

console.log("GetRoomBooking

query:"+JSON.stringify(req.query));

var

RoomId=req.params.roomid;

var

NowTime=req.params.thistime;

GuestModel.GetRoomBooking(Mysql,RoomId,NowTime,function(Data){

res.charSet('utf-8');

res.send(Data);

});

}

function

GetGuestInfoById(req, res, next)

{

console.log("GetGuestInfoById

query:"+JSON.stringify(req.query));

var

UserId=req.params.uid;

GuestModel.GetGuestInfoById(Mysql,UserId,function(Data){

res.charSet('utf-8');

res.send(Data);

});

}

}

exports.GuestControll=GuestControll;

Controller都是中转控制啦, 业务逻辑都在Module层里,

第一句就告诉我们又要再建一个Module文件夹和Guest.js 的Module.

唯一让我觉得不够爽的地方是注册各个请求的接收参数名, 这个必须由后台私下和前端事先约定, 在nodejs上无法自描述...

var

JsOper=require("../Tool/JsOper.js");

var

DataTable=require("../Tool/CDataTableName.js");

var

GuestModel={

GetTodayGuests:function(MySql,aUTCDate,aResponse)

{

var QueryCmd=['SELECT

t1.ROOM_ID,t1.GASTNR,t1.GASTNAME,t2.SEX,t2.VIP,t1.ANREISE,t1.ABREISE,t1.CHECK_FLAG

'];

QueryCmd.push(' FROM

',DataTable.TableGuestCheckIn,' t1,

',DataTable.TableGuestInfo,' t2 ' );

QueryCmd.push(' WHERE

t1.GASTNR=t2.NUMMER  AND ((t1.ANREISE

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/554591.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

红碎茶的制作

传统的红碎茶在采摘的鲜叶经萎凋后,茶坯采用平揉、平切,后经发酵、干燥制成。该类产品外形美观,但内质香味刺激性较小,因成本较高,目前我国仅少量地区生产。后来卧式揉捻机开始出现,部分茶厂(场)将其联装成…

mysql主从增量同步_生产环境中mysql主从同步/完整/增量备份

环境:某项目的DB19数据库服务器,无从库也无开过binlog日志,负载有时比较高但基本运行稳定。备份情况:本地每天完整备份保留一周再rsync到异地备份机保留一月,由于数据量的增长加上每天晚上rsync到异地机时流量非常大&a…

win10如何删除注册表残留文件

win10如何删除注册表残留文件?下面一起来看看如何操作吧。 1、按下“winr”打开运行,输入“regedit”,点击“确定”; 2、依次展开“HKEY_LOCAL_MACHINESOFTWAREMicrosoftwindowsCurrentVersionUninstall”; 3、在该子键下根据已卸载的应用程序软件图标…

mysql 设计模式_mysql – 你会推荐什么版本设计模式

我不认为版本控制中没有特定的GoF设计模式本身,因为它存在许多实现。版本控制的最简单的实现是对象的链表。其中列表中的每个节点都是可版本化对象的新版本。为了节省空间,您还可以实现某种diff,以显示修订版本之间的区别。这样,您…

win7中如何设置默认打印机

1、单击win7电脑的开始菜单,然后在打开的菜单中选择设备和打印机。 2、之后出现新的窗口,在新窗口中就可以找到目前win7电脑中连接的所有的打印机了。 3、只需要选中自己想要设置的打印机,然后点击鼠标右键,在出现的下滑菜单中选…

jmeter连接mysql数据库驱动_十八、JMeter实战-JDBC连接MySQL数据库

前言连接数据库进行测试在工作中会比较常用,首先可以读取数据库的数据进行参数化、关联等,批量添加测试数据以及清理数据,还可以直接对SQL语句进行压测。一、基本介绍1. 首先第一步要导入mysql驱动包,放到jmeter/lib目录下&#x…

xp电脑怎么取消开机密码

1.点击菜单,选择并打开控制面板 2.找到用户账号 3.点击更改密码 4.输入你想修改的密码,不要密码就不用输,直接保存更改即可,接着重启电脑就可以看到没有开机密码的提示了。 ​转:浏览器大全 xp电脑怎么取消开机密码…

下如何查看mysql表单_Navicat 教程:如何进行表单查看

Navicat 表单查看方便表单查看、更新或删除数据,显示当前的记录:栏位名及其值。表单的弹出菜单包括这些功能:设置栏位值为 Null 或空白字符串、使用当前栏位值为筛选、设置表单查看格式及更多,导览栏可以快速切换记录、插入、更新…

鼠标有拖尾怎么办

1、首先依次打开“开始菜单-控制面板”选项; 2、在控制面板中找到并打开“鼠标”选项; 3、在弹出来的鼠标属性窗口中,切换到“指针选项”标签下,然后在下方的可见性一栏中将“显示指针轨迹”前面的勾取消掉,点击确定按钮退出即可。 转&…

怎么禁止开机启动nvidia

1、单击开始菜单,选择运行,打开运行后输入services.msc 确定。 2、打开本地服务后,在列表中找到NVIDIA Display Driver Service服务。 3、双击打开该服务,然后将NVIDIA Display Driver Service服务的启动类型设置为禁用&#x…

mysql insert 错误码_利用 MySQL 自身错误诊断区域-爱可生

原标题:利用 MySQL 自身错误诊断区域-爱可生背景本篇文章来源于今天客户问的一个问题。问题大概意思是:我正在从 Oracle 迁移到 MySQL,数据已经转换为单纯的 INSERT 语句。由于语句很多,每次导入的时候不知道怎么定位到错误的语句…

win7打不开qq文件怎么办

1、这种情况是因为QQ为了用户安全,防止传过来的文件是病毒,在电脑上自动运行而做的修改,针对的是.EXE等WINDOWS系统可执行的文件,会自动在文件名称后面加上.重命名三个字。如果确认不是病毒,在该文件点击右键&#xff…

mysql子查询_笔记之MySQL子查询

子查询students(学生表),scores(成绩表)、courses(课程表)子查询:在select 语句中,嵌入了另外一个 select 语句, 那么被嵌入的 select 语句称之为子查询语句,子查询分(标量子查询、列子查询、行子查询、表子查询)标量子查询: 子查询返回的结果…

win7开机后所有程序都打不开怎么办

win7开机后所有程序都打不开怎么办?下面一起来看看解决方法吧。 win7开机后所有程序都打不开怎么办 方法一: 1、开机按F8进入安全模式; 2、安装杀毒软件,全盘杀毒; 3、重启电脑电脑可以正常使用。 方法二、系统故障或病毒彻底损坏系统无法修复&am…

mac版crt8.0.2打开无响应怎么办_Mac电脑程序无响应怎么办?教你强制退出无响应程序...

Mac电脑运行时间长了,难免也会遇到程序卡死无响应的情况,可能是由于程序冲突、缓存不足或者一些bug等情况导致,这个时候我们就需要强制退出这个程序了,一起来看看如何强制退出无响应程序吧!快捷键强制退出当前运行的应…

win7自带防火墙怎么关闭

1、首先点击win7系统的开始菜单,在菜单中找到并点击打开“控制面板”; win7自带防火墙怎么关闭 2、进入控制面板后,点击窗口右上角的查看方式的“类别”,选择大图标显示; 3、接着在界面里面选择并打开“Windows防火墙”; 4、进入Windows防…

python拼写_python 拼写检查器

简短到爆的py脚本import refrom collections import Counterdef words(text):return re.findall(r\w,text.lower())Words Counter(words(open(big.txt).read()))def P(word,Nsum(Words.values())):return Words[word] / Ndef correction(word):return max(candidates(word), k…

win7如何关闭密码保护共享

1、首先打开控制面板,选择用户账户和家庭安全。 2、其次点击用户账户。 3、然后选择管理其他账户。 4、接着点击Guest,点击启用。 5、之后关闭窗口,右击点击计算机,选择管理。 6、接着按顺序点击本地用户和组、用户&#xff0…

python英文字典小程序_python 小程序—三级菜单—循环和字典练习

程序中利用多级字典来存储三级菜单, 通过一系列while循环和for循环,实现了三级菜单的查询,选择,退回上级菜单,退出程序几个功能。缺点:程序语句过于重复,效率低。#-*-coding:utf-8-*-date{北京:…

win7电脑假死机怎么办

1、正在使用电脑,如果网页或一些页面卡住不动,我们首先要保持电脑的正常运行。这时候可以同时按WinD,可以马上回到桌面。然后尝试着刷新几次。 2、当回到桌面后,我们试着看看是不是运行的软件太多了,造成电脑运行不动…