AgileEAS.NET平台开发实例-药店系统-数据库设计

简介: 开篇            上篇,我们分析了,功能需求和非功能性的需求,本篇我们就来看下,如何设计数据库,当然数据库的设计也是有一些技巧性而已,不过大家经常做数据库设计的朋友都 知道,如果我们的数据库设计完全符合数据库要求的第三范式的话,那么我们可能在通过ORM框架来使用这个数据库设计的时候,会有不方便的地方,因为ORM在多表关联 上的处理或者说是支持的并不好,所以我们常常在数据库设计的时候,会允许在表中存在冗余字段,这样我们能够在查询的过程中可以很方便的读取数据,而不用关联查询, 当然也有不错的方案去处理这方面的需求,比如通过视图等。

 

开篇

 

         上篇,我们分析了,功能需求和非功能性的需求,本篇我们就来看下,如何设计数据库,当然数据库的设计也是有一些技巧性而已,不过大家经常做数据库设计的朋友都

知道,如果我们的数据库设计完全符合数据库要求的第三范式的话,那么我们可能在通过ORM框架来使用这个数据库设计的时候,会有不方便的地方,因为ORM在多表关联

上的处理或者说是支持的并不好,所以我们常常在数据库设计的时候,会允许在表中存在冗余字段,这样我们能够在查询的过程中可以很方便的读取数据,而不用关联查询,

当然也有不错的方案去处理这方面的需求,比如通过视图等。

        下面我们就来看看,如果设计药店系统的数据库,后面我们会附上数据库设计文档的下载。

 

大纲

 

 

         1、设计功能模块的数据库设计。

         2、分析设计的合理性。

 

设计每个功能模块的数据库设计

 

 

         我们本节将会根据上篇的需求文档来进行数据库的设计,来分析每个模块的数据库设计,我们采取的方式还是从整体上去考虑,我们在每个模块都要使用的公共的基础设

计等是否需要单独维护和管理等。

         下面我们来分析下我们需要设计出的单独的表:

          image

          下面我们来分析下每个模块的数据库表的设计:

      1、基础数据

           药品字典:

           image

           当然上面的有些字段并没有完全的体现出来,具体的一些补充设计,大家可以基于这个基础之上进行完善和改进。

           供应商:

           image

            供应商信息主要是为了药品的采购和退药提供帮助,有了供应商信息后,后期可以直接进行拨款操作,当然这是根据这种按消耗付给供应商钱成为可能,HIS医院系统

一般都会有这样的机制。

             image

              药品类型的维护,方便后期进行扩展和编辑等,一般不推荐直接删除药品类型,会造成数据的丢失和失效性,建议可设计启用禁用字段。

        2、药品入库

              image

              药品入库一方面是需要引用药品字典表中的药品信息,还要保存供应商信息,同时还要引用药品类型。

        3、药品出库(顾客发药)

               image

               这里的药品出库,就是药店系统中的顾客发药,里面需要保存顾客的姓名,发药日期,数量,等等,这样可以为后期的顾客退药提供帮助。

         4、库存管理

                image

                 库存管理,是所有模块的药品数据流的流入或流出。

         5、供应商退药

                 image

                  供应商退药,主要是药店退药到供应商,记录药店退供应商的药品记录明细。

          6、顾客退药

                  image

                   顾客退药。必须包含退药的顾客姓名和数量,日期等信息,方便后期的统计查询等,并详细记录明细信息。

           7、药品调价

                    image

                    详细记录,调价原因,调价的药品数量,调价日期,新旧价格等信息。

           8、药品报损

                  image

                  记录报损的数量,原因,日期等。

          9、药品盘点

                image

               盘点表记录盘点的信息,账目库存与实际库存信息,记录盘点的日期,盘点记录的状态,是否进行过调整操作等。

               药店系统目前涉及到的主要模块都已经涵盖,大家可以从上面的设计中看到很多的冗余信息,比如关于药品信息的内容,有很多的内容都冗余。主要是为了方便

基础信息的读取,防止过多的关联查询,当然通过视图也可以解决,但是还是会在编码中使用起来会有一定的不方便,当然,冗余字段会造成数据库物理存储太大,当然如果

说我们的数据的数量级很大的话,可能我们需要在设计的时候,考虑这个方面的要求,当我们的数据量不是太大的时候,可能我们更讲究效率优先。

 

设计分析

 

 

           通过上面的数据库设计文档,我们发现了以下的几点,我们在每个表里面都保存了药品的如下几个字段的信息:

           image 

           我们是否应该直接保存药品字典中的主键信息,然后其他表里面直接引用药品字典中的主键作为外键即可,那么可能有这样的一个好处,如果我们后期维护一个药品字

典后,信息变更后,所有的药品信息,都会跟着同步,但是也有一个不好处,也许我们有时候需要保留原有的药品字典信息时,用于跟踪历史记录时,就会出问题。而且。维

护时。我们必须要关联药品字典表,当然建立视图可以解决。

            并且我们在设计数据库时,对于像基础数据这些信息时,一定要设计为不要轻易删除的字段,伪删除比较好,例如我们添加如下字段。

           image 

        当然不删除会造成冗余数据太多,但是删除后会造成部分数据的信息错误,或者说无效的引用,那么我们如何来做,上面我们在每个表中都保存相关的药品信息,从侧面

也能避免删除基础数据时造成的无法找到引用的问题等。

         数据库设计的过程中还有很多的其他的技巧,把二个都纵向变化的因素,我们会单独通过一个关联表来维护这二个都变化的因素之间的关联关系。具体的应用还有很多,

当然我的水平也是有限,不一定是很有道理,欢迎大家拍砖,如果部分内容有错误或者不正确,还请大家指正。

 

总结

 

 

         本文主要给出了药店系统的数据库设计,当然可能我的数据库设计不符合正常的实际使用,不足之处还请大家多多指点,如果你有更好的设计的思路,还请指出,我会不

断的改进。

 

 

药店系统-数据库设计文档

 

 

download3

 

 

更多交流

 

 

官方博客:http://www.smarteas.net/

官方网站:http://www.agilelab.cn/

如果您在使用AgileEAS.NET开发平台中有什么问题,请使用如下几种联系方式或者沟通方式。

1、电话-邮箱方式:

何戈洲hegezhou_hot@163.com 手机:18691480181 博客:http://www.cnblogs.com/hegezhou_hot/

2、QQ交流群:

308961614 网名:H.O.T


作者:IT行者-何戈洲
出处:http://www.cnblogs.com/hegezhou_hot/
2007年大学毕业后便投入到计算机行业中,先后涉足(电信、电子商务、教育、医疗、工程建筑、项目管理、房产)等行业,目前有比较丰富的技术及行业经验,技术方面涉及(Java、Go、.NET、Python、设计模式、系统架构、PM管理流程、软件工程、敏捷开发、SOA、云计算、大数据、区块链、WF、SAAS等领域),结合业务可提供(EIP、ERP、HIS、B2B、B2C、B2B2C、CRM、OA、O2O等)业务及技术解决方案,随着时间的推移,目前已逐步转向管理方面,欢迎同行一起交流学习,个人平时爱好体育运动、音乐、旅游等,向往丰富多彩的生活旅程。如有问题或建议,请多多赐教!
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,如有问题,可以通过hegezhou_hot@163.com  联系我,非常感谢。
其他联系方式:
电话:13716055594
联系人:何戈洲
微信联系我:

CallHot

反馈文章质量,你可以通过快速通道评论:
目录
相关文章
|
消息中间件 监控 数据可视化
一个基于.Net Core 开源的物联网基础平台
一个基于 .Net 6.0 使用C#语言编写的以实现可见与不可见的物理设备数字孪生的物联网平台。用于数据的收集、处理、可视化、设备管理、设备预警、报警的平台。
409 0
一个基于.Net Core 开源的物联网基础平台
|
存储 监控 Kubernetes
『Skywalking』.NET Core快速接入分布式链路追踪平台
📣读完这篇文章里你能收获到 - .NET Core接入Skywalking - 了解Skywalking的整体架构设计 - 了解Skywalking的各项技术指标怎么看 - 生产部署时的坑全跳过 - 感谢点赞+收藏,避免下次找不到~
734 1
『Skywalking』.NET Core快速接入分布式链路追踪平台
|
24天前
|
数据采集 存储 监控
.NET智慧手术室管理平台源码
术前访视记录单、手术风险评估表、手术安全核查表、自费药品或耗材、麻醉知情同意书、麻醉记录单、分娩镇痛记录单、麻醉复苏单、术后镇痛记录单、术后访视记录单、压伤风险评估量表、手术清点记录单、护理记录单、输血护理记录单。
26 0
|
30天前
深入.net平台的分层开发
深入.net平台的分层开发
48 0
|
4月前
|
Web App开发 开发框架 .NET
asp.net基于WEB层面的云LIS系统平台源码
结合当今各检验科管理及实验室规模的不同状况,充分吸收当今IT科技的最新成就,开发出以高度产品化、功能强大、极易实施操作、并不断升级换代为主要特点的LIS系统。彻底解决检验科的信息孤岛,全面实现全院信息互通互联、高度共享,并为检验科的规范化管理提供了有力工具。
41 0
|
4月前
|
Web App开发 开发框架 .NET
asp.net基于WEB层面的区域云LIS系统平台源码
asp.net基于WEB层面的区域云LIS系统平台源码
49 1
|
4月前
|
开发框架 小程序 数据可视化
基于.NET、Uni-App开发支持多平台的小程序商城系统 - CoreShop
基于.NET、Uni-App开发支持多平台的小程序商城系统 - CoreShop
|
5月前
|
存储 前端开发 程序员
一款基于.Net开发、开源、支持多平台云存储文件管理器
一款基于.Net开发、开源、支持多平台云存储文件管理器
42 0
|
5月前
|
数据采集 自然语言处理 监控
基于.Net开发的、支持多平台、多语言餐厅点餐系统
基于.Net开发的、支持多平台、多语言餐厅点餐系统
75 0
|
10月前
|
SQL 数据库连接 数据库
在VS2013平台下,用VB.net 连接Access数据库
从开始学习计算机,我们使用的一直是SQL数据库。这次接触了Access数据库,我将从Access创建到连接向大家分享一下我在Access数据库中的收获。
203 0