一、源码特点
java SSM酒店客房管理系统是一套完善的web设计系统(系统采用SSM框架进行设计开发,spring+springMVC+mybatis),对理解JSP java编程开发语言有帮助,系统具有完整的源代
码和数据库,系统主要采用B/S模式开发。开发环境为TOMCAT7.0,Myeclipse8.5开发,数据库为Mysql5.0,使用java语言开发。
ssm酒店客房管理系统
二、功能介绍
(1)用户管理:对用户信息进行添加、删除、修改和查看
(2)客房类型管理:对客房类型信息进行添加、删除、修改和查看
(3)客房管理:对客房信息进行添加、删除、修改和查看
(4)公告管理:对公告信息进行添加、删除、修改和查看
(5)订单管理:对订单信息进行添加、删除、修改和查看
(6)用户登录、个人信息修改
数据库设计
[表yonghu] 用户列属性表格 | |||||
序号 | 字段名称 | 数据类型 | 长度 | 主键 | 描述 |
1 | yhid | INTEGER | 11 | 是 | 用户编号 |
2 | yhm | VARCHAR | 40 | 否 | 用户名 |
3 | mm | VARCHAR | 40 | 否 | 密码 |
4 | xm | VARCHAR | 40 | 否 | 姓名 |
5 | qx | VARCHAR | 40 | 否 | 权限 |
6 | dh | VARCHAR | 40 | 否 | 电话 |
7 | dz | VARCHAR | 40 | 否 | 地址 |
8 | sfzh | VARCHAR | 40 | 否 | 身份证号 |
[表kflx] 客房类型列属性表格 | |||||
序号 | 字段名称 | 数据类型 | 长度 | 主键 | 描述 |
1 | kflxid | INTEGER | 11 | 是 | 客房类型编号 |
2 | lx | VARCHAR | 40 | 否 | 类型 |
[表kefang] 客房列属性表格 | |||||
序号 | 字段名称 | 数据类型 | 长度 | 主键 | 描述 |
1 | kfid | INTEGER | 11 | 是 | 客房编号 |
2 | kf | VARCHAR | 40 | 否 | 客房 |
3 | lx | VARCHAR | 40 | 否 | 类型 |
4 | fjh | VARCHAR | 40 | 否 | 房间号 |
5 | ms | VARCHAR | 40 | 否 | 描述 |
6 | zt | VARCHAR | 40 | 否 | 状态 |
7 | tp | VARCHAR | 40 | 否 | 图片 |
8 | jg | VARCHAR | 40 | 否 | 价格 |
[表gonggao] 公告列属性表格 | |||||
序号 | 字段名称 | 数据类型 | 长度 | 主键 | 描述 |
1 | ggid | INTEGER | 11 | 是 | 公告编号 |
2 | bt | VARCHAR | 40 | 否 | 标题 |
3 | nr | VARCHAR | 40 | 否 | 内容 |
4 | sj | VARCHAR | 40 | 否 | 时间 |
[表dingdan] 订单列属性表格 | |||||
序号 | 字段名称 | 数据类型 | 长度 | 主键 | 描述 |
1 | ddid | INTEGER | 11 | 是 | 订单编号 |
2 | ddbt | VARCHAR | 40 | 否 | 订单标题 |
3 | kf | VARCHAR | 40 | 否 | 客房 |
4 | yh | VARCHAR | 40 | 否 | 用户 |
5 | rzsj | VARCHAR | 40 | 否 | 入住时间 |
6 | jssj | VARCHAR | 40 | 否 | 结算时间 |
7 | ts | VARCHAR | 40 | 否 | 天数 |
8 | jg | VARCHAR | 40 | 否 | 价格 |
9 | jsjg | VARCHAR | 40 | 否 | 结算价格 |
10 | zt | VARCHAR | 40 | 否 | 状态 |
11 | dh | VARCHAR | 40 | 否 | 电话 |
12 | dz | VARCHAR | 40 | 否 | 地址 |
13 | xm | VARCHAR | 40 | 否 | 姓名 |
控制层代码设计
@RequestMapping(value="/add")
public String add(kefang kefang,HttpServletRequest request){
Map<String,Object> map= new HashMap<String,Object>();
//String name=(String)request.getParameter("name");
map.put("kfid", kefang.getKfid());//客房编号
map.put("kf", kefang.getKf());//客房
map.put("lx", kefang.getLx());//类型
map.put("fjh", kefang.getFjh());//房间号
map.put("ms", kefang.getMs());//描述
map.put("zt", kefang.getZt());//状态
map.put("tp", kefang.getTp());//图片
map.put("jg", kefang.getJg());//价格
String kfid=(String)kefang.getKfid();//客房编号
String kf=(String)kefang.getKf();//客房
String lx=(String)kefang.getLx();//类型
String fjh=(String)kefang.getFjh();//房间号
String ms=(String)kefang.getMs();//描述
String zt=(String)kefang.getZt();//状态
String tp=(String)kefang.getTp();//图片
String jg=(String)kefang.getJg();//价格
String sql="select count(1) as num from kefang where fjh='"+fjh+"'";
ResultSet rs=null;
DBO db=new DBO();
int num=0;
try{
rs=db.query(sql);
if(rs.next()){
num=rs.getInt("num");
}
if(num>0){
request.setAttribute("msg", "<script>alert('添加失败、房间号重复');</script>");
}else{
kefangdao.save(map);
request.setAttribute("msg", "<script>alert('添加成功');</script>");
}
}catch(Exception e){
e.printStackTrace();
}
System.out.println("addok");
return "kefang/kefangadd";
}
/**删除
*
*/
@RequestMapping(value="/del")
public String del(Integer id,HttpServletRequest request,Map<String,Object> map){
// Map<String,Object> map= new HashMap<String,Object>();
String a=(String)request.getParameter("keyid");
id=Integer.parseInt(a);
request.setAttribute("msg", "<script>alert('删除成功');</script>");
kefangdao.del(id);
return selectall(null,map,request);
}
/**
* 修改kefang信息
*/
@RequestMapping(value="/update")
public String update(kefang kefang,HttpServletRequest request,Map<String,Object> map1){
Map<String,Object> map= new HashMap<String,Object>();
map.put("kfid", kefang.getKfid());//客房编号
map.put("kf", kefang.getKf());//客房
map.put("lx", kefang.getLx());//类型
map.put("fjh", kefang.getFjh());//房间号
map.put("ms", kefang.getMs());//描述
map.put("zt", kefang.getZt());//状态
map.put("tp", kefang.getTp());//图片
map.put("jg", kefang.getJg());//价格
String kfid=(String)kefang.getKfid();//客房编号
String kf=(String)kefang.getKf();//客房
String lx=(String)kefang.getLx();//类型
String fjh=(String)kefang.getFjh();//房间号
String ms=(String)kefang.getMs();//描述
String zt=(String)kefang.getZt();//状态
String tp=(String)kefang.getTp();//图片
String jg=(String)kefang.getJg();//价格
request.setAttribute("msg", "<script>alert('修改成功');</script>");
kefangdao.update(map);
return selectall(null,map1,request);
}
持久层
public void save(Map<String, Object> map) {
sqlSession.insert("com.kefang.insertkefang", map);
}
/**
* 删除aa
* @param id
*/
public void del(Integer id) {
sqlSession.delete("com.kefang.delkefang", id);
}
/**
* 修改kefang信息
* @param map
*/
public void update(Map<String, Object> map) {
sqlSession.update("com.kefang.updatekefang", map);
}
/**
* 查询kefang信息
* @param id
* @return
*/
public List<Map<String, Object>> select(Integer id) {
return sqlSession.selectList("com.kefang.selectkefang", id) ;
}
mybatis 配置
<insert id="insertkefang" parameterType="java.util.Map">
insert into kefang(kf,lx,fjh,ms,zt,tp,jg) values(#{kf},#{lx},#{fjh},#{ms},#{zt},#{tp},#{jg})
</insert>
<delete id="delkefang" parameterType="int">
delete from kefang where kfid=#{kfid}
</delete>
<update id="updatekefang" parameterType="java.util.Map">
update kefang set kf=#{kf},lx=#{lx},fjh=#{fjh},ms=#{ms},zt=#{zt},tp=#{tp},jg=#{jg} where kfid=#{kfid}
</update>
<!-- 查询返回的是 list<map> -->
<!-- resultType 就是返回查询结果的类型,而如果是resultMap=则返回的就是你定义的javabean -->
<select id="selectkefang" parameterType="int" resultType="java.util.Map">
select * from kefang where kfid=#{kfid}
</select>
<!-- resultType 就是返回查询结果的类型,而如果是resultMap=则返回的就是你定义的javabean -->
<select id="selectall" parameterType="java.util.Map" resultType="java.util.Map">
select * from kefang where 1=1
<if test=" null != kf and kf!=''" >
and kf = #{kf}
</if>
<if test=" null != lx and lx!=''" >
and lx = #{lx}
</if>
<if test=" null != fjh and fjh!=''" >
and fjh = #{fjh}
</if>
<if test=" null != ms and ms!=''" >
and ms = #{ms}
</if>
<if test=" null != zt and zt!=''" >
and zt = #{zt}
</if>
<if test=" null != tp and tp!=''" >
and tp = #{tp}
</if>
<if test=" null != jg and jg!=''" >
and jg = #{jg}
</if>
</select>
三、注意事项
1、管理员账号:admin 密码:admin 数据库配置文件datasource.properties
2、开发环境为TOMCAT7.0,Myeclipse8.5开发,数据库为Mysql5.0,使用java语言开发。
3、数据库文件名是jspssmjdgl.sql,系统名称ssmjdgl
4、系统首页地址:http://127.0.0.1:8080/ssmjdgl/login.jsp
四 系统实现
源码获取 下方联系卡片↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓