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

简介:

开篇

 

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

知道,如果我们的数据库设计完全符合数据库要求的第三范式的话,那么我们可能在通过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 

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

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

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

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

 

总结

 

 

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

断的改进。





本文转自何戈洲博客园博客,原文链接:http://www.cnblogs.com/hegezhou_hot/archive/2011/04/02/2003805.html,如需转载请自行联系原作者

目录
相关文章
|
7天前
|
存储 安全 API
陪玩平台中支付与结算模块的代码,陪玩系统数据库设计与代码实现
第三方支付平台对接涉及与微信支付、支付宝等API接口的调用,确保用户支付流程顺畅。结算模块根据业务规则计算陪玩师收益,强调安全性、异常处理、可扩展性和日志记录。数据库设计涵盖用户、陪玩者、订单等信息的存储管理,确保系统稳定运行。
|
6天前
|
JavaScript NoSQL Java
基于SpringBoot+Vue实现的大学生就业服务平台设计与实现(系统源码+文档+数据库+部署等)
面向大学生毕业选题、开题、任务书、程序设计开发、论文辅导提供一站式服务。主要服务:程序设计开发、代码修改、成品部署、支持定制、论文辅导,助力毕设!
29 6
|
10天前
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
27 2
|
30天前
|
SQL 关系型数据库 API
HarmonyOs开发:关系型数据库封装之增删改查
每个方法都预留了多种调用方式,比如使用callback异步回调或者使用Promise异步回调,亦或者同步执行,大家在使用的过程中,可以根据自身业务需要进行选择性调用,也分别暴露了成功和失败的方法,可以针对性的判断在执行的过程中是否执行成功。
92 13
|
1月前
|
Linux API C#
基于 .NET 开发的多功能流媒体管理控制平台
基于 .NET 开发的多功能流媒体管理控制平台
44 9
|
1月前
|
Web App开发 前端开发 调度
一款基于 .NET + Blazor 开发的智能访客管理系统
一款基于 .NET + Blazor 开发的智能访客管理系统
|
29天前
|
存储 前端开发 关系型数据库
鸿蒙开发:实现键值数据库存储
对于数据量比较的小的,我们直接选择轻量级的用户首选项方式即可,而对于数据量比较大的情况下,直接可以使用数据库,而对于相对来说,比较大的数据,我们就可以使用键值型数据库方式
101 2
|
6天前
|
JavaScript NoSQL Java
基于SpringBoot+Vue实现的冬奥会科普平台设计与实现(系统源码+文档+数据库+部署)
面向大学生毕业选题、开题、任务书、程序设计开发、论文辅导提供一站式服务。主要服务:程序设计开发、代码修改、成品部署、支持定制、论文辅导,助力毕设!
23 0
|
6天前
|
关系型数据库 MySQL 数据库连接
数据库连接工具连接mysql提示:“Host ‘172.23.0.1‘ is not allowed to connect to this MySQL server“
docker-compose部署mysql8服务后,连接时提示不允许连接问题解决
|
10天前
|
缓存 关系型数据库 MySQL
【深入了解MySQL】优化查询性能与数据库设计的深度总结
本文详细介绍了MySQL查询优化和数据库设计技巧,涵盖基础优化、高级技巧及性能监控。
97 0

热门文章

最新文章