有谁做过预约挂号医生排班的程序,给个思路。
个一个在线预约挂号,在医生排排班的时候,可以自定义每个时间段可以预约的人数,当然时间段也可以自定义,我这里时间段是一个小时的,比如8:00-9:00.......17:00-18:00,一天8个小时分为8个时间段。排班时间是星期一到星期日。哪位给个具体思路,谢谢了。
回复讨论(解决方案)
首先用一???????段及每???段最多可以??的人?,或者用??表也可以。
例如每???段只能??20?人。
$t = array(
array('08:00', '09:00', 20),
....
.....
array('17:00', '18:00', 20),
);
然後,用一?表????人?,大概字段如下
id 自增
mid 用?id 或什?唯一身份??的?西,或email也可以,用??查是否重???用。
date 日期
t ??段??,用????也可
num ??人?
?有用?要??,先判?是否在允?????段?,如果是,再判?,???段?是否已????,如未??增加一???。
例如有一?用?在8:00-9:00 ????段??,可以??判?。
select num from table where date='2014-06-10' and t=0;
如返回的num小於 20,?insert。
如果要加上取消??功能,可以也?一?取消??限期,起?在9:00前10分?不能取消,???好。大概思路是??。
如果星期一和星期日等的可以????不同,那$t?????再分多一?做星期的key。如果是??建?做成??表,方便管理。
$t = array(
'MON' => array(
array('08:00', '09:00', 20),
....
.....
array('17:00', '18:00', 20),
),
'TUE' => array(
)
);
先设计数据库,表doctors(医生),表order(预约),表work(排班)
每次生成预约号,先去检索排班表,排班表里面如果当天的没有创建,先创建。
排班额外建表,就可以手动修改设置。
楼上的那种虽然有道理,但是你不能保证那个医生那一天那个点就一定会上班,可能遇到某些情况不上班或者有事耽误
所以不能写死在程序中。
把时间段的时间,存入数据库或者数组,当成一个类别处理,预定的时候,选取类别即可。
学习一下~
首先用一???????段及每???段最多可以??的人?,或者用??表也可以。
例如每???段只能??20?人。
$t = array(
array('08:00', '09:00', 20),
....
.....
array('17:00', '18:00', 20),
);
然後,用一?表????人?,大概字段如下
id 自增
mid 用?id 或什?唯一身份??的?西,或email也可以,用??查是否重???用。
date 日期
t ??段??,用????也可
num ??人?
?有用?要??,先判?是否在允?????段?,如果是,再判?,???段?是否已????,如未??增加一???。
例如有一?用?在8:00-9:00 ????段??,可以??判?。
select num from table where date='2014-06-10' and t=0;
如返回的num小於 20,?insert。
如果要加上取消??功能,可以也?一?取消??限期,起?在9:00前10分?不能取消,???好。大概思路是??。
LZ用3楼的方案吧。其实你的需求,无非是要搞清楚,有哪些医生,排班的情况,预约的情况。用数据库操作灵活些。
既然复杂就用数据表来做,方便管理
数据表结构如下:
doctor 表,记录医生信息
doctor_id 医生id PK
name 医生名称
timeline 表,记录每个医生每天每个时段的能预约的信息,这个需要每隔一段时间做一次新增和删除,新增加新日期预约时间,删除过期的.星期没有用了,因为直接用日期来定比较好。
tid timeline id PK
doctor_id 医生id FK
date 日期
quota 允许预约的人数
starttime 时段开始语 例8:00
endtime 时段结束 例9:00
status 该时段是否允许预约 0 否 1允许
order 预约表,记录用户预约的情况
order_id 预约id PK
userid 用户id -> 会员系统这个你自己想 FK
tid 预约了的时段id FK
addtime 预约时间
流程:
首先先输入doctor 和 timeline 数据,如下
共有两个医生
doctor_id name
1 d1
2 d2
在2014-06-11这天的班表,doctor1别8个时间段全满,doctor2 则只有6个时间段需要工作
tid doctor_id date quota starttime endtime status
1 1 2014-06-11 10 08:00 09:00 1
2 1 2014-06-11 10 09:00 10:00 1
3 1 2014-06-11 10 10:00 11:00 1
4 1 2014-06-11 12 11:00 12:00 1
5 1 2014-06-11 12 14:00 15:00 1
6 1 2014-06-11 8 15:00 16:00 1
7 1 2014-06-11 10 16:00 17:00 1
8 1 2014-06-11 5 17:00 18:00 1
9 2 2014-06-11 10 08:00 09:00 1
10 2 2014-06-11 10 09:00 10:00 1
11 2 2014-06-11 10 10:00 11:00 1
12 2 2014-06-11 12 14:00 15:00 1
13 2 2014-06-11 10 16:00 17:00 1
14 2 2014-06-11 5 17:00 18:00 1
预约
第一位用户useid=1 要预约 2014-06-11 11:00~12:00 doctor1
首先判断timeline 中 doctor_id=1 date=2014-06-11 starttime=11:00 endtie=12:00 quota>0的记录是否存在
如果不存在,返回提示没有预约的时段或名额已满
如果存在
1。在order表新增一条记录
order_id userid tid addtime
1 1 4 2014-06-09 10:29:29
2.将timeline tid=4 的 quota-1,那记录就会变成
4 1 2014-06-11 11 11:00 12:00 1
流程就是这样,应该很明白了吧。
读不起了各位,最近一段时间出差去了,昨天才回来,看了下8楼的方法,这样的话每次都要新增一次,而且都是手动输入数据,如果按星期的话,那没个一个星期就要更新一次。好像时间是写死了
读不起了各位,最近一段时间出差去了,昨天才回来,看了下8楼的方法,这样的话每次都要新增一次,而且都是手动输入数据,如果按星期的话,那没个一个星期就要更新一次。好像时间是写死了
??不是?死的。你什??候需要工作,才添加入班表。
可以?置?期班表及??班表。
例如?生A,每?星期一~五都是8:00~12:00工作。可以?多一?表???期班表,然後另一?表????班表。
例如今天,星期一,正常是8:00~12:00?生A上班的,但??有事,需要改成下午14:00~18:00。??就把14:00~18:00?入今天??班表。但判?今日有??班表的,?按??班表去??。否?按?期班表??即可。大概思路是??了。
读不起了各位,最近一段时间出差去了,昨天才回来,看了下8楼的方法,这样的话每次都要新增一次,而且都是手动输入数据,如果按星期的话,那没个一个星期就要更新一次。好像时间是写死了
你究竟想要做什么?把思路先理清楚了!
你不是“预约”吗?怎么可能每周是一样的?
如果我约在明天,难道明天的明天也有效吗?日期当然是定死的!
我只需要7天时间进行循环,当天预约明天的,比如:2014-6-25(星期三)?2014-7-1(星期二),不管怎么排班我都是以7天时间为准,这个具体要怎么体现呢,照你那方法我都不知道在页面和程序上怎么去体现了。
读不起了各位,最近一段时间出差去了,昨天才回来,看了下8楼的方法,这样的话每次都要新增一次,而且都是手动输入数据,如果按星期的话,那没个一个星期就要更新一次。好像时间是写死了
??不是?死的。你什??候需要工作,才添加入班表。
可以?置?期班表及??班表。
例如?生A,每?星期一~五都是8:00~12:00工作。可以?多一?表???期班表,然後另一?表????班表。
例如今天,星期一,正常是8:00~12:00?生A上班的,但??有事,需要改成下午14:00~18:00。??就把14:00~18:00?入今天??班表。但判?今日有??班表的,?按??班表去??。否?按?期班表??即可。大概思路是??了。
可以这样,你先做一天排一次的,做出来以后再改成7天循环的。
可以这样,你先做一天排一次的,做出来以后再改成7天循环的。
你那个方法我可以理解成这样的吗?我做成这样的如图: ,这个是7天自动循环的,每天的时间段和人数自定义,但是这个SQL语句该怎么写呢?麻烦你了,最早那个思路客户不满意,菲的弄成这个得 字段为:
日期、专家、时段1、时段2......时段10
即每个专家每天一条记录
字段为:
日期、专家、时段1、时段2......时段10
即每个专家每天一条记录
为什么呢?
只不过是将你的表单(#14 的截图)中的每一天作为一条记录保存而已
如果你的表单是对一周的设定,那么提交后就按天保存成 7 条记录就是了
为什么呢?
只不过是将你的表单(#14 的截图)中的每一天作为一条记录保存而已
如果你的表单是对一周的设定,那么提交后就按天保存成 7 条记录就是了
首先想?下?主的是,?些????段以及???段允???的人?或者其它信息是由每??家自己?置的?是系??置的
如果是?家自己?置的那你??可以??
首先你??有一???段的配置信息表,????段如8.00, 9.00或者?以半?小?如8.30, 9.00, 9.30等,每???是一???
然後?家在?置?,把?些??全部列出?,由?生自己去定???段,如8:00-9:00,允?的??人?等信息,?置好後再?入??
患者看信息?,把最近七天的?家?置的??段以及相?信息?用出?即可.
首先想?下?主的是,?些????段以及???段允???的人?或者其它信息是由每??家自己?置的?是系??置的
如果是?家自己?置的那你??可以??
首先你??有一???段的配置信息表,????段如8.00, 9.00或者?以半?小?如8.30, 9.00, 9.30等,每???是一???
然後?家在?置?,把?些??全部列出?,由?生自己去定???段,如8:00-9:00,允?的??人?等信息,?置好後再?入??
患者看信息?,把最近七天的?家?置的??段以及相?信息?用出?即可.
如果你的输入框命名成这样的形式:
时段1
时段2
提交后不就都对应上了吗?
如果你是用 mysqli 或 pdo 扩展的话,绑定一下参数,就可循环插入,没有什么开销
如果是用 mysql 就组装一下指令串,也不是什么难事
为了系统的兼容性,最好是每天每个时段单独设置存到数据库里。
如果你的输入框命名成这样的形式:
时段1
时段2
提交后不就都对应上了吗?
如果你是用 mysqli 或 pdo 扩展的话,绑定一下参数,就可循环插入,没有什么开销
如果是用 mysql 就组装一下指令串,也不是什么难事
如果哪位真好心,直接给我写成代码吧,拜托了,问题解决,我再追加50分
其?,思路你懂了??
如果不懂,就算?你代?,也?有用。
没人愿意吗?
其?,思路你懂了??
如果不懂,就算?你代?,也?有用。
其?,思路你懂了??
如果不懂,就算?你代?,也?有用。
各位给帮忙看下这个事怎么回事,http://jcy.xys.gov.cn/已经放到服务器了,怎么还是本地路径呢,这个解决了我结贴给分,拖得时间太长了,对不起大家了。。
?片你在模板中?死吧。http://localhost/xyjcy_network/templates/default/images/xjweibo.jpg
读不起了各位,最近一段时间出差去了,昨天才回来,看了下8楼的方法,这样的话每次都要新增一次,而且都是手动输入数据,如果按星期的话,那没个一个星期就要更新一次。好像时间是写死了
你究竟想要做什么?把思路先理清楚了!
你不是“预约”吗?怎么可能每周是一样的?
如果我约在明天,难道明天的明天也有效吗?日期当然是定死的!
版主,请教下
网站上的doc文件打开时也不提示是否下载或者打开,直接打开就是乱码,不知道这是怎么回事呢?
你没有发送下载的头?
你没有发送下载的头?
文件直接是编辑器上传的,在虚拟空间都好好的,放到客户服务器上就不行了,打开内容就是乱码。

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

'블레이드 앤 소울 2' 국내 서버는 오늘 전 플랫폼 예약판매를 시작했다고 밝혔다. '블레이드 앤 소울 2' 중국판은 샤오밍타이지와 텐센트 게임즈가 공동 운영한다. Blade and Soul IP의 게임 플레이 기능을 계승하고 Ganoderma 팬들에게 더욱 극단적인 게임 경험을 제공하기 위해 "Sword and Soul 2" 개발팀은 그래픽, 전투 작전, 새로운 게임 플레이, 중국어 버전 등. 동시에 '블레이드 앤 소울 2' 중국 서버의 최적화 내용을 모두가 미리 이해할 수 있도록 개발팀에서는 중국 플레이어들에게 특별히 손편지를 보냈습니다! 엔씨소프트 개발팀이 플레이어들에게 보내는 편지: '블레이드 앤 소울 2'가 다시 탄생합니다. 안녕하세요, 중국 플레이어 여러분. 저희는 '블레이드 앤 소울 2' 개발팀으로서 블레이드 앤 소울에 관심을 가져주신 모든 분들께 인사를 드리는 것은 이번이 처음입니다. 새해가 시작되면 우리는 신난다.

오늘날 디지털 시대에 라이브 방송은 사람들에게 새로운 엔터테인먼트 경험을 제공할 뿐만 아니라 기업과 기관에 보다 직관적이고 효율적인 홍보 채널을 제공하는 매우 인기 있는 대화형 방법이 되었습니다. 부동산 분야에서 Fangtianxia는 전문적인 부동산 정보와 고품질 서비스를 통해 많은 주택 구매자와 부동산 실무자가 선호하는 플랫폼이 되었습니다. Fang Tianxia의 라이브 방송 기능은 사용자에게 부동산 시장 역학에 대한 직관적인 이해를 제공합니다. Fang Tianxia 앱에서 관심 있는 라이브 방송을 예약하는 방법에 대해 더 알고 싶은 사용자는 이 기사를 참조하세요. 위의 도시 옵션을 클릭하고 집을 사고 싶은 도시를 선택하세요. 그림과 같이 홈페이지 인터페이스에서 "라이브 뷰잉"을 클릭하세요. 사진과 같은 유형을 선택하세요. 새집 추천 또는 세컨드하우스

항공 여행 Zongheng을 이용하면 다양한 여행을 더 잘 마무리할 수 있습니다. 비행기를 타고 싶다면 여기로 와서 티켓을 구매하세요. 다양한 기능이 있고 많은 전략을 제공할 수 있습니다. 전체 여행 서비스는 매우 포괄적이고 운영하기 쉽습니다. 티켓을 예약하고 좌석을 선택할 수 있을 뿐만 아니라 항공편 정보를 확인하고 공항을 편리하게 픽업할 수 있도록 도와드립니다. 체크인과 좌석 선택에 대해 살펴보겠습니다. 다른 사람의 체크인 및 항공편 좌석 선택을 돕는 방법: 1. 먼저 소프트웨어를 열고 "도구 상자"를 선택합니다. 2. '모바일 좌석 선택'을 선택하세요. 3. 그런 다음 '여행객이 포함된 좌석 선택&'을 선택하세요.

Blue Star Travel Yao는 게임이 공개된 후 게임 예약을 시작했습니다. 많은 플레이어들이 게임의 실제 시연 영상을 보고 큰 관심을 보였습니다. 게임 예약 방법을 알고 싶다면 이 기사를 통해 Blue Star Travel Yao 예약을 하세요. 입장하시면 도움이 필요한 친구들이 와서 구경해보세요. 블루스타여행 야오예약 입구 예약입장: 1. 블루스타여행 야오 공식 홈페이지에 접속하신 후, 공식 홈페이지 왼쪽 하단에 있는 예약하기를 클릭하시면 예약이 가능한 게임이 오픈된 것을 보실 수 있습니다. 2. 그런 다음 만지우 패스를 입력하고 예약 입구에 로그인합니다. 3. 로그인 후 원하는 예약 플랫폼을 선택하면 해당 플랫폼에서 발급됩니다. 4. 선택하시면 예약이 완료됩니다.

오늘 15시, '드렁큰팔선'의 첫 번째 새해 서버가 오픈됩니다! 10년 된 턴제 시스템으로 독특한 "구름 속으로 솟아오르고 안개를 타고", "전투 날씨"와 완전한 거래 시스템이 플레이어들 사이에서 큰 인기를 끌고 있습니다~ 새 서버가 오면 Xiaolongren이 소개하겠습니다 모두에게 소개해주세요! '만취팔선'은 '팔선의 동방기행'을 배경으로 팔선과 삼계의 꿈같은 세계를 구축한다. 여기에서는 '구름을 타고 안개를 탄다'를 체험하고 '불멸 클래스 순위'를 즐길 수 있을 뿐만 아니라 시시각각 변화하는 전장을 즐길 수 있으며 '전투 기상'을 활용해 전세를 뒤집을 수도 있습니다. . 뿐만 아니라, 수백 마리의 강력하고 귀여운 애완동물과 독특한 게임 플레이를 통해 PVP, PVE, PVX에서 원하는 게임을 플레이할 수 있습니다. 요정 친구들이 몰입감 있게 체험할 수 있도록 보다 실감나는 게임 화면을 구현하기 위해

1. 소프트웨어를 열고 아래 표에 있는 네 개의 사각형 작업 아이콘을 클릭한 후 [화상 회의] 아이콘을 클릭합니다. 2. 화상회의 페이지에서 [회의 예약] 버튼을 클릭하세요. 3. 페이지 상단의 [+] 아이콘을 클릭하여 참가자를 추가하세요. 4. 미팅 주제, 미팅 시간, 미팅 시간, 기타 내용을 순서대로 입력한 후 [확인] 버튼을 클릭하세요. 5. 첫 페이지에 표시된 인원수와 미팅 시간을 확인하신 후 [미팅 시작]을 클릭하세요.

Damai의 티켓 예약 기능은 실제로 우리에게 큰 편리함을 제공합니다. 우리가 좋아하는 공연 티켓을 미리 확보하여 멋진 공연을 놓치지 않도록 할 수 있습니다. 하지만 예매 과정에서 여러 가지 이유로 잘못된 티켓을 선택하거나 다른 이유로 예매 기능을 취소해야 하는 경우도 있습니다. 하지만 많은 이용자들이 취소 방법을 모르시기 때문에 아래 글을 통해 취소의 기쁨을 전해드리겠습니다. 단계가 자세히 소개되어 있으므로 모든 사람에게 도움이 되기를 바랍니다. Damai에서 예약을 취소하고 티켓을 구매하려면 먼저 Damai 소프트웨어를 열고 홈페이지에 들어가서 사이트로 전환하세요. 회원, 요금, 내 페이지에서 여기 오른쪽 하단에 있는 [내]를 클릭하세요. 2. 그런 다음 내 페이지에서 [보고 싶은 & 놀고 싶은] 버튼을 클릭한 다음 [표시]를 클릭해야 합니다. 3. 마지막으로,

화웨이 P70Pro 출시 이후에도 지난해 출시된 화웨이 메이트60은 여전히 구매가 어려워 휴대폰을 잡기가 쉽지 않을 것으로 보인다. 그렇다면 Huawei P70Pro 구매를 예약하는 방법은 무엇입니까? 아래에서 자세히 소개해드리겠습니다. Huawei P70Pro 구매를 예약하는 방법 Huawei 공식 웹사이트에서 예약하세요. Huawei 휴대폰 공식 웹사이트에서 원하는 휴대폰 모델을 선택하고 해당 예약 정보와 배송 주소를 입력한 후 예약을 완료하세요. 공식 프로모션도 즐길 수 있습니다. JD.com에서 예약하세요. JD.com 홈페이지를 열고 제목 표시줄 아래 바로가기 버튼에서 Honor 6를 선택한 후 Honor 6 사전 판매 페이지에 들어가서 지금 검정색을 클릭하여 예약하고 이름, 이메일, 휴대폰 번호 등을 입력하세요. 예약을 위한 정보입니다. Huawei Mall 공식 웹사이트에서 예약하세요. 화웨이 매장 오픈
