本论文介绍的主要内容是从武警警官医院在线预约平台系统的需求分析到详细设计,最后到测试部分的整个过程。其实现主要功能有患者信息、医务人员、科室信息的管理和在线咨询、在线预约信息管理等五个主要模块。系统实现了用户信息在线管理、浏览以及在线咨询与预约信息的交互和数据汇总统计分析。
武警警官医院在线预约平台系统是对部队武警医院的一种支持手段,传统的对武警警官医院预约管理模式还处于手工处理阶段,管理效率极低。随着患者的不断增多,传统基于手工管理模式已经无法满足当前用户需求,随着信息化时代的到来,使得患者在线预约平台系统的开发成了必然[1]。通过该系统,管理员可以高效的进行对在线预约相关信息管理,为了能够提高医院的工作效率和就医的方便性,需要不断完善武警警官医院在线预约平台系统的管理和更新,使得患者从预约到就医系统化、高效化[6]。
登录界面
患者信息添加界面
患者信息添加。设置11个TextBox控件和1个Button按钮来实现患者信息的填写,其中一个通过DropDownList控件选择性别,设置用户名及密码等必填信息的TextBox中的内容不允许为空,并且设置用户名在数据库中不可重复,否则系统提示错误:另外年龄未填时,设置默认值为0。信息填写完毕后,通过按钮控制事件,将数据保存至数据库,而后反馈添加成功
患者信息查看界面
在窗体顶部设置1个用以输入“用户名”等关键字的TextBox控件和1个用于触发查询事件Button控件。使用Like语句,调用GetDataSet方法从数据库查询到相关的患者信息,以表格的形式将查询结果全部显示
新增医务人员信息界面
设置13个TextBox控件和1个Button按钮来实现医务人员信息的填写,其中通过2个DropDownList控件实现性别及所在科室的选择,设置用户名、密码及就诊人数等必填信息的TextBox中的内容不允许为空,否则系统将会提示错误信息。其中就诊人数则是限制该医生一天内被预约数的最大限制额。信息填写完毕后,通过按钮控制事件,将数据保存至数据库,而后反馈添加成功
医务人员信息查看界面
科室信息添加界面
界面通过4个TextBox控件和1个Button控件来实现科室信息的填写,并且在科室名称、联系电话、科室主任及科室说明必填TextBox中设置内容不允许为空,最后通过保存按钮控制事件,将数据写入数据库
在线预约挂号界面图
患者登陆账号,通过添加在线预约信息进入预约信息添加界面。设置4个的TextBox控件和1个Button按钮控件供患者填写预约信息与保存,其中通过3个DropDownList控件来进行选择预约时间、科室及医生的选择,同时,设置所有TextBox规则为必填:另外,设置当预约的医生当天预约已到限制额时,则会显示错误信息,或者预约的科室或医生不存在则不会显示:并且设置同一个账号一天只可预约同一个医生一次。最后通过保存按钮触发写入事件,将所填预约信息写入数据库表中。此时患者将会得到一个预约号码牌,设置此预约号码由各个患者预约时间顺序确定
预约信息列表界面图
在线预约信息列表中,所有预约信息会以表格形式呈现出来,并且设置状态是“未就诊”的预约信息背景为红色填充显示以作提醒。上方设置1个用于输入“医生”等关键字信息的TextBox控件和1个用于触发查询事件的Button控件。使用Like语句,调用GetDataSet方法从数据库查询到相关的咨询信息,以表格的形式将查询结果全部显示。其中患者可在预约信息列表下方查看自己的排队情况
<?php
error_reporting(E_ALL ^ E_NOTICE);
$conn=@mysql_connect("localhost","root","root") or die("数据库链接失败".mysql_error());
mysql_select_db("daizu",$conn) or die("数据库链接失败".mysql_error());
mysql_query('set names utf8');
//设置时区
date_default_timezone_set('asia/shanghai');
define('SYS_ROOT', str_replace("\\", '/', dirname(__FILE__)));
define('File_ROOT', SYS_ROOT."/upload/");
define('IMG_ROOT', SYS_ROOT . "/upload/");
@extract($_POST);
@extract($_GET);
function getfirst($sql)
{
$res=mysql_query($sql);
$rows=mysql_fetch_array($res);
return $rows;
}
//
function getcount($sql){
$res=mysql_query($sql);
return mysql_num_rows($res);
}
function get_name($id,$table)
{
$sql="select * from $table where id='$id'";
$rows=getfirst($sql);
return $rows[name];
}
//遍历创建目录
function Remkdir($path) {
if (!file_exists($path)) {
Remkdir(dirname($path));
@mkdir($path, 0777);
}
}
//上传图片
function upload_image($inputname, $image=null, $type='upimages', $width=440) {
$n = time().rand(1000,9999).'.jpg';
$z = $_FILES[$inputname];
if ($z && strpos($z['type'], 'image')===0 && $z['error']==0) {
if (!$image) {
Remkdir( IMG_ROOT . '/' . "{$type}/" );
$image = "{$type}/{$n}";
$path = IMG_ROOT . '/' . $image;
} else {
Remkdir( dirname(IMG_ROOT .'/' .$image) );
$image = "{$type}/{$n}";
$path = IMG_ROOT . '/' .$image;
}
//echo $path ;
move_uploaded_file($z['tmp_name'], $path);
//echo $image;exit;
return $image;
}
return $image;
}
//获取文件后缀名
function get_extend($file_name)
{
$extend = pathinfo($file_name);
$extend = strtolower($extend["extension"]);
return $extend;
}
//文件上传实现
function upload_file($inputname, $file=null)
{
$year = date('Y'); $day = date('md');
$z = $_FILES[$inputname];
$file_ext=get_extend($z['name']);
$n = time().rand(1000,9999).".".$file_ext;
if ($z && $z['error']==0) {
if (!$file) {
Remkdir( File_ROOT . '/' . "{$day}" );
$file = "{$day}/{$n}";
$path = File_ROOT . '/' . $file;
} else {
Remkdir( File_ROOT . '/' . "{$day}" );
$file = "{$day}/{$n}";
$path = File_ROOT . '/' .$file;
}
//echo $path ;
move_uploaded_file($z['tmp_name'], $path);
//echo $file;exit;
return $file;
}
return $file;
}
//分页函数.
function get_pager($url, $param, $count, $page = 1, $size = 10)
{
$size = intval($size);
if($size < 1)$size = 10;
$page = intval($page);
if($page < 1)$page = 1;
$count = intval($count);
$page_count = $count > 0 ? intval(ceil($count / $size)) : 1;
if ($page > $page_count)$page = $page_count;
$page_prev = ($page > 1) ? $page - 1 : 1;
$page_next = ($page < $page_count) ? $page + 1 : $page_count;
$param_url = '?';
foreach ($param as $key => $value)$param_url .= $key . '=' . $value . '&';
$pager['url'] = $url;
$pager['start'] = ($page-1) * $size;
$pager['page'] = $page;
$pager['size'] = $size;
$pager['count'] = $count;
$pager['page_count'] = $page_count;
if($page_count <= '1')
{
$pager['first'] = $pager['prev'] = $pager['next'] = $pager['last'] = '';
}
else
{
if($page == $page_count)
{
$pager['first'] = $url . $param_url . 'page=1';
$pager['prev'] = $url . $param_url . 'page=' . $page_prev;
$pager['next'] = '';
$pager['last'] = '';
}
elseif($page_prev == '1' && $page == '1')
{
$pager['first'] = '';
$pager['prev'] = '';
$pager['next'] = $url . $param_url . 'page=' . $page_next;
$pager['last'] = $url . $param_url . 'page=' . $page_count;
}
else
{
$pager['first'] = $url . $param_url . 'page=1';
$pager['prev'] = $url . $param_url . 'page=' . $page_prev;
$pager['next'] = $url . $param_url . 'page=' . $page_next;
$pager['last'] = $url . $param_url . 'page=' . $page_count;
}
}
return $pager;
}
?>
目录
1 绪论 1
1.1课题背景 1
1.2课题研究现状 1
1.3初步设计方法与实施方案 2
1.4本文研究内容 2
2 系统开发环境 4
2.1 使用工具简介 4
2.2 环境配置 4
2.3 B/S结构简介 4
2.4 MySQL数据库 5
2.5 框架介绍 5
3 系统分析 6
3.1系统可行性分析 6
3.1.1经济可行性 6
3.1.2技术可行性 6
3.1.3运行可行性 6
3.2系统现状分析 6
3.3功能需求分析 7
3.4系统设计规则与运行环境 8
3.5系统流程分析 8
3.5.1操作流程 8
3.5.2添加信息流程 9
3.5.3删除信息流程 10
4 系统设计 11
4.1系统设计主要功能 11
4.2数据库设计 11
4.2.1数据库设计规范 11
4.2.2 E/R图 11
4.2.3数据表 12
5 系统实现 25
5.1系统功能模块 25
5.2后台模块 27
5.2.1管理员功能模块 27
5.2.2用户功能模块 30
6 系统测试 33
6.1功能测试 33
6.2可用性测试 33
6.3性能测试 34
6.4测试结果分析 34
7结 论 35
参考文献 36
致 谢 37