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,如需转载请自行联系原作者

目录
相关文章
|
9天前
|
前端开发 C# 开发者
.NET使用Umbraco CMS快速构建一个属于自己的内容管理系统
.NET使用Umbraco CMS快速构建一个属于自己的内容管理系统
26 12
|
9天前
|
Linux API C#
基于 .NET 开发的多功能流媒体管理控制平台
基于 .NET 开发的多功能流媒体管理控制平台
|
9天前
|
Web App开发 前端开发 调度
一款基于 .NET + Blazor 开发的智能访客管理系统
一款基于 .NET + Blazor 开发的智能访客管理系统
|
9天前
|
开发框架 JavaScript 前端开发
精选2款.NET开源的博客系统
精选2款.NET开源的博客系统
|
9天前
|
前端开发 JavaScript C#
基于.NET8+Vue3开发的权限管理&个人博客系统
基于.NET8+Vue3开发的权限管理&个人博客系统
|
15天前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
40 3
|
15天前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
43 3
|
15天前
|
SQL 关系型数据库 MySQL
数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog
《数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog》介绍了如何利用MySQL的二进制日志(Binlog)恢复误删除的数据。主要内容包括: 1. **启用二进制日志**:在`my.cnf`中配置`log-bin`并重启MySQL服务。 2. **查看二进制日志文件**:使用`SHOW VARIABLES LIKE 'log_%';`和`SHOW MASTER STATUS;`命令获取当前日志文件及位置。 3. **创建数据备份**:确保在恢复前已有备份,以防意外。 4. **导出二进制日志为SQL语句**:使用`mysqlbinlog`
58 2
|
29天前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
196 15
|
22天前
|
SQL 关系型数据库 MySQL
数据库数据恢复—Mysql数据库表记录丢失的数据恢复方案
Mysql数据库故障: Mysql数据库表记录丢失。 Mysql数据库故障表现: 1、Mysql数据库表中无任何数据或只有部分数据。 2、客户端无法查询到完整的信息。