最老程序员创业开发实训14---PHP---用户体系数据库设计

在做完了之前的一系列工作之后,终于要进行应用后台的设计和实现环节了。在后台设计中,我们觉得数据库的设计是最重要的根基,因为所有业务逻辑均是架构在数据库的基础之止,如果对数据库进行修改,程序可能需要大改,工作量将非常之大,所以数据库设计必须非常重视。

在谈数据库设计之前,我们先谈一下ORM,即关系数据库与面向对象系统的映射,其理由是面向对象开发人员,不了解关系型数据库,因些引入ORM,使其不需要学习关系型数据库就可以进行数据库开发。我们认为,关系型数据已经有了几十年的发展历史,理论和实践都很成熟,反观ORM发展不过十来年左右,理论、功能和性能方面,都有很多问题,虽然在当前大行其道,但是我们认为其引入的问题,远比所解决的问题要多。我们认为,如果一个面向对象程序员,如果学习关系型数据库觉得有困难,那么不是这种技术不好,而是他可能根本不适合编程。因此我们倡导直接采用关系型数据库技术,不采用任何ORM框架。

回到数据库设计的话题,说到数据库设计,其理论基础是范式,尤其是第二和第三范式,是数据库设计的基础,我们必须对这些范式非常熟悉。当然,因为在其际项目中,由于性能方面的考虑,可能会违反范式,引入数据冗余,但是理解和掌握范式,对于我们设计出合理的数据库逻辑模型还是非常有帮助的。

关于数据库设计范式的详细内容,大家可对考百度百科的词条(百度百科数据库范式)。这里就不再讨论了。

我们这里讨论的是用户注册,看似用户数据库设计很简单,但是在实际应用中,却是一个比较复杂的问题。比如,在移动医疗应用中,我们应用的用户比如说是张三,他直接作为患者是一种简单的情况,但是他可能要替他的父母和孩子挂号看病,这时张三还是用户,但是实际接受服务的主体是他的父母和孩子,这需要怎么表示呢?还不仅如此,到医院就诊还需要就诊卡,而通常情况下,一个人可能有多张就诊卡,医院是只认就诊卡的,怎么将就诊卡对应到真实患者呢?再有,有些医院有会员系统,用户可以给会员卡充值,从而享受优惠,张三的会员卡,可以同时给父母和孩子使用,这种情况又如何表示呢?

以上分析的还仅仅是医疗方面的应用,在其他方面的应用,同样存在这样的问题,例如社区O2O中,社区便利店,实际服务的是某个房间,可能与业主是无关,同时,业主可能同时有几套房,O2O运营商怎么识别出该业主同时有几套房需要服务的信息,或者是业主全家迁移到新的住处,按照其以往的消费习惯,直接配送其所需的产品和服务。

上面所讲的应用场景,都需要在用户数据库设计中加以考虑。为了讨论问题方便,这里以移动医疗的用户数据库设计为例,讨论如何设计出更好的数据库结构,以满足实际应用的需要。

我们先对用户进行分类,明确以下几个概念:用户是直接使用我们产品的人,在上面的例子中,就是张三;客户是为产品和服务付费的实体,可以是张三绑定了会员卡;消费者是享受我们产品和服务的人,如果张三替父母或孩子咨询问题,那么张三的父母和孩子就是消费者,消费者是一个通用的概念,在这里就是患者。

如上图所示,用户只保存用户登录所需要的基本信息,这里需要注意的一点,虽然很多应用都是用手机号登录,但是千万不要把手机号作为登录名,因为用户手机号可能改变,所以用专门的手机号来存储比较合理,可以取登录名初始时与手机号一致。

系统的会员卡用账户来表示,一个会员卡代表一个账户,用户绑定一个账户后,就变成了客户,客户是用于付款的实体。

张三、张三的父母和孩子都是消费者,对应于consumer表中的一条记录,当用户登录后,会自动绑定自己缺省的consumer。当张三想要给自己的父母咨询时,其可以绑定父母的consumer,然后进行咨询,这时与医生聊天时,就会显示张三父母的头像,点击头像就可以显示张三父母的病历。系统记录本次咨询记录时,记录user_consumer_id作为咨询者信息,如果医生想要联系患者,可以通过这条记录,找到用户,然后通过用户信息,联系到患者。如果联系不上的话,还可以查看该consumer下还有哪些用户,然后依次与这些用户联系,达到最终联系患者的目的。

华丽的分隔线
******************************************************************************************************************************************************************************
希望大家多支持,有大家的支持,我才能走得更远,谢谢!
银行账号:622202 0200 1078 56128 闫涛
我的支付宝:[email protected]

时间: 2024-10-24 18:27:49

最老程序员创业开发实训14---PHP---用户体系数据库设计的相关文章

最老程序员创业开发实训4---IOS平台下MVC架构

在前面几篇文章中,我们大致研究了一下,在Android平台,以应用开始时的Splash页面为例,讲述了怎样利用MVC架构来实现这一简单功能,有可能有朋友认为,对于这样简单的功能,采用MVC架构有些过了.但是,如果需求变为,需要根据时间.地点等,显示从服务器上下载的图片,那么我们所采用的架构,就具有一定的优势了. 下面,我们将讲述在IOS平台怎样实现相同的功能.我们知道在IOS平台上开发原生应用,有两种技术可供选择,即Objective-C或Swift.如果对于找工作而言,当前最好的选择依然是Ob

最老程序员创业开发实训8---IOS---在Swift中用定时任务显示Splash页面

在上一节中,我们用Swift实现了Splash页面的显示,但是仅仅显示Splash页面是不够的,我们需要显示Splash页面2秒,然后跳转到下一个页面,因此需要实现定时任务的功能.在Android中,我们采用了系统的函数postDelayed来实现这一功能,在IOS系统中,我们需要使用GCD. 首先我们简单了解一下GCD.我们知道,对于手机而言,多核CPU用得越来越多,这样真正的多任务就是益成为现实,因为每个CPU核都可以独立地执行单独的任务.GCD正是为了使程序员更方便地使用多核CPU而引入的

最老程序员创业开发实训2---采用MVC架构的应用Splash页面实现

在基本所有的应用中,一点应用图标,都会弹出一个Splash页面,显示几秒钟,然后再进入到程序的主页面中(如果是用户第一次使用,会进入一个新手引导系列页面,介绍产品的主要功能).今天我们就来开发这个页面. 这个页面是几乎所有应用都会用到的页面,所以我们希望在多个应用中重用,怎么来实现呢?在Android中,我们可以将这个页面做成一个工程项目,所有其他应用项目,都引用这个工程项目,就可以直接使用这个Splash页面的实现了. 我们先建立一个普通的Android工程(我们在调通这个功能之后,我们会将其

最老程序员创业开发实训13---Android---网络请求与异步任务

在完成了用户注册和登录页面的界面设计工作之后,我们就需要让我们的程序向后台发起请求,请求后台PHP程序实际进行用户注册操作.在新版本的Android系统中,所有的网络请求必须以异步的方式来进行,我们既可以通过线程方式也可以通过Android系统为我们提供的异步任务方式来完成,我们在这里选择采用异步任务的方式来进行网络操作. 根据异步任务的原理,当应用调用异步任务时,异步任务会在后台完成相应的网络操作,在完成之后,在onPostExecute方法中通知界面,更新操作状态.有两种方法可以完成这项任务

最老程序员创业开发实训12---Android---在MVC架构下Activity设计及实现

在上一节中,我们讲述了如何在Android平台下,以MVC架构为指导,实现模型类的方法.在本节中,我们要重点讨论一下,怎样设计Activity类,作为MVC中的控制器,并在其中使用我们在上节所讲述的模型类.在这里我们只讨论重要的代码,对于资源文件及Activity页面设计及实现细节,由于篇幅所限,就只能略过了,大家可以在稍后公布的项目下载包中查看相应的代码. 我们以具体项目WkgJys项目为例,项目在首次运行时,Splash页面之后,会进入JysAppTourActivity,在看完所有介绍页面

最老程序员创业开发实训7---Cocoa Touch Framework实现Splash屏幕功能

在Xcode中建立好工程空间(Work Space)之后,并且建立Cocoa Touch Framework工程WkyLib和应用工程WkgJys工程,下面我们就可以开始进行正式开发了. 首先我们进入Cocoa Touch Framework工程WkyLib,先在下面创建如下组用于组织代码:common, model, view, controller,如下图所示: 同时,在WkyLib的目录下,创建相同的目录common, model, view, controller, images: 在v

最老程序员创业开发实训6---用Swift创建Framework工程重用代码

由于我们要开发一系列应用,很多基础功能是通用的,我们希望这些通用功能可以实现不同程序之间重用,在IOS开发中,可以通过静态库和Framework两种方式来实现,我们选择采用Framework方式,因为这种方式更加灵活.在本节中,我们将创建一个CocoaTouch Framework工程WkyLib,实现Splash屏幕功能,然后创建WkgJys应用,调用WkyLib中的Splash屏幕功能. 新建一个在文件=>新建中选择新建Workspace,如下图所示: 在Xcode中建立Cocoa Touc

最老程序员创业开发实训3---采用MVC架构的应用Splash页面实现

在上篇文章中,我们已经将Splash页面显示封装到了WkyLib工程中,在本节中,我们将建立一个具体应用工程:维康基因基因师版(WkgJys),是一款面向基因师的工具软件,可以使基因师更好的管理客户,建立自己的个人品牌,向客户提供在线咨询.线下预约咨询等功能.这只是一款假想中的软件,我们不用太去考虑软件的商业价值,我们的重点是如体来实现这款软件. 建立WkgJys工程,首先我们设定这个工程需要依赖于我们上节所建立的库工程WkyLib,方法是选中WkgJys项目,按右键,选择项目属性=>Andro

最老程序员创业开发实训10---Android---注册登录功能实现1

用户在观看完应用介绍页面之后,会点击进入应用按钮,这时由于用户是第一次运行,所以会弹出注册页面.如果是老用户,启动应用时,在Splash页面之后,如果应用记录着用户的登录信息,测直接进入主页面,如果从本地取不到用户登录信息,则将显示登录页面. 注册和登录功能看起来很简单,但是由于我们这里需要实现一个完整的应用支撑基础设施,因此需要分几个部分来进行.我们首先会讨论怎样创建并使用Activity中会用到的Model类,在这中间我们会采用Application对象作为中心信息仓库,每个Model类只是