1、UML系统建模基础,图书管理系统的分析与设计 基于UML的系统建模,2011.6.1,图书管理系统的分析与设计,UML建模概述,图书管理系统的分析与设计,UML模型与软件工程过程,需求分析,系统分析,实现,测试,用例图,类图,顺序图 协作图,状态图 活动图,组件图 部署图,图书管理系统的分析与设计,图书管理系统的UML建模,第1章 系统需求 第2章 用例模型 第3章 静态结构模型 第4章 动态行为模型 第5章 物理模型 第6章 数据库模型,用例图,类图,顺序图 协作图,状态图 活动图,组件图 部署图,图书管理系统的分析与设计,第1章 系统需求,图书管理系统的域描述如下:在图书管理系统中,要为每
2、个借阅者建立一个帐户,并给借阅者发放借阅卡,帐户中存储借阅者的个人信息、借阅者信息以及预定信息。持有借阅卡的借阅者可以借阅书刊、返还书刊、查询书刊信息、预定书刊并取消预定。在借阅书刊时,需要输入所借阅的书刊名、书刊的ISBN/ISSN2号,然后输入借阅者的图书卡号和借阅者名,完成提交所填表格,系统验证借阅者是否有效(在系统中存在帐户),若有效,借阅请求被接受,系统查询数据库系统,看借阅者所借阅的书刊是否存在,若存在,则借阅者可借出书刊,建立并在系统中存储借阅记录。借阅者还书后,删除关于所还书刊的借阅记录。如果借阅者所借的书刊被借出,借阅者还可以预定该书刊,一旦借阅者预定的书刊可以获得,就将书刊
3、直接寄给预订人(为了简化系统,暂时假定预定书刊可获得时就不通知借阅者了;也暂不考虑书刊的最长借阅期限,假设借阅者可以无限期地保存所借阅的书刊)。通过对图书管理系统进行分析,可以获得如下功能性需求图:,图书管理系统的分析与设计,第1章 系统需求,图书管理系统的分析与设计,第2章 用例模型,面向对象的需求分析是采用用例驱动的分析方法来表述用户的功能性需求,分析需求的主要任务是识别出系统中的参与者和用例,并建立用例模型,并给出系统用例的事件流描述。1. 识别参与者;2. 识别用例及关系;3. 建立用例模型;4. 描述用例。,图书管理系统的分析与设计,2.1 识别参与者,通过对系统需求的分析,可以确定
4、系统中有两个参与者:BorrowerActor(借阅者。为了与后面的类Borrower区别)、Librarian(图书管理员)。参与者的描述如下:BorrowerActor描述:借阅者可以借阅、预定、归还物理书刊,还可以取消预定。示例:持有借阅卡的任何人或组织。Librarian描述:图书管理员维护系统,可以创建、修改、删除借阅者的信息,可以添加、编辑、删除书刊信息,即维护目录,还可以添加、编辑、删除物理书刊信息。示例:图书管理员。,图书管理系统的分析与设计,2.2 识别用例,前面已经识别出了参与者,通过对需求的进一步分析,可以确定系统中有如下用例存在: Borrow Book (借书) 本用
5、例提供了借阅物理书刊的功能。 Return Book (还书) 本用例提供了返还物理书刊的功能。 Reserve Title (预定书刊) 本用例提供了预定书刊的功能。,图书管理系统的分析与设计,2.2 识别用例,Cancel Reservation (取消预定) 本用例提供了取消预定的功能。 Maintain Borrower Info (维护借阅者信息) 本用例提供了创建、修改以及取消借阅者帐户的功能。 Maintain Title Info (维护书刊信息) 本用例提供了添加、修改、以及删除书刊信息的功能。 Maintain Book Info (维护物理书刊信息) 本用例提供了添加、修
6、改以及删除物理书刊信息的功能。 Log In (登录) 本用例描述了用户如何登录进入软件系统。,图书管理系统的分析与设计,在识别出参与者和用例后,要建立用例图,并描述出他们之间的关系。,图2.1 系统用例图,图书管理系统的分析与设计,2.3 用例的事件流描述,用例的事件流是对完成用例行为所需的事件的描述。它描述系统应该做什么,而不是描述系统应该怎样做。图书管理系统的用例事件流描述如下:,图书管理系统的分析与设计,1 .借阅物理书刊,用例编号 US01 用例名 Borrow Book 用例描述 完成借阅物理书刊的功能 参与者 图书管理员 前置条件 管理员登录成功. 后置条件 可以将物理书刊借给借
7、阅者、更新相关数据记录等操作。 基本路径 (1)提供书刊种类、借阅者信息。 (2)检索书刊种类(Title) (E-1) (3)确定所借阅的物理书刊是否可以获得 (E-2),也即物理书刊是否已借出。 (4)检索借阅者 (E-3) (5)图书馆将物理书刊借给借阅者。 (6)创建借阅记录。 (7)存储借阅记录。 扩展点E-1: 该种书刊不存在,系统显示提示信息,用例终止。E-2: 物理书刊都已借出,系统显示提示信息,用例终止。E-3: 系统中不存在该借阅者,系统显示提示信息,用例终止 补充说明 无,图书管理系统的分析与设计,备选流 :通过预定借阅物理书刊 提供书刊种类、借阅者信息。 检索书刊种类
8、(Title) (E-1)。 检索借阅者 (E-3)。 确定该种类书刊的物理拷贝是否可以获得 (E-2) 将物理书刊发给借阅者。 创建借阅记录。 存储借阅记录。 删除预定记录。 扩展点: E-1: 该种书刊不存在,系统显示提示信息,用例终止。 E-2: 物理书刊都已借出,系统显示提示信息,用例终止。 E-3: 系统中不存在该借阅者,系统显示提示信息,用例终止,查看时序图,查看活动图,图书管理系统的分析与设计,2.返还物理书刊,用例编号 US02 用例名 Return Book 用例描述 完成借阅物理书刊的功能 参与者 图书管理员 前置条件 在这个用例开始前,Librarian必须登录到系统中
9、后置条件 如果这个用例成功,当借阅者返还所借的物理书刊时,用例启动。 基本路径 (1)检索物理书刊 (E-1)。 (2)查询物理书刊的借阅记录 (E-2)。 (3)删除借阅记录。 扩展点: E-1: 物理书刊不存在,系统显示提示信息,用例终止。 E-2: 若借阅记录不存在,系统显示提示信息,用例终止。,查看时序图,图书管理系统的分析与设计,3. 预定书刊,用例编号 US03 用例名 Reserve Title (预定书刊) 用例描述 完成预定书刊的完整过程。 参与者 图书管理员 前置条件 在这个用例开始前,Librarian必须登录到系统中 后置条件 如果这个用例成功,系统建立预定记录。否则,
10、系统的状态没有变化 基本路径 (1)提供书刊种类、借阅者信息。 (2)检索书刊种类 (E-1)。 (3)检索借阅者 (E-2)。 (4)系统接收预定,创建预定记录。 (5)将预定记录存储在系统中。 扩展点: E-1: 该种书刊不存在,系统显示提示信息,用例终止。 E-2: 系统中不存在该借阅者,系统显示提示信息,用例终止。,图书管理系统的分析与设计,4. 取消预定,用例编号 US04 用例名 Cancel Reservation (取消预定) 用例描述 完成取消预定的功能 参与者 图书管理员 前置条件 在这个用例开始前,Librarian必须登录到系统中 后置条件 如果这个用例成功,系统删除预
11、定记录 。 基本路径 (1)提供所预定的书刊种类、借阅者信息。 (2)检索所预定的书刊种类 (E-1)。 (3)检索借阅者 (E-2)。 (4)从系统中删除预定记录 (E-3) 。 扩展点 E-1: 该种书刊不存在,系统显示提示信息,用例终止。 E-2: 系统中不存在该借阅者,系统显示提示信息,用例终止。 E-3: 预定信息不存在,系统显示提示信息,用例终止。,图书管理系统的分析与设计,5. 维护借阅者信息,用例编号 US05 用例名 Maintain Borrower Info 用例描述 完成系统添加、修改或删除借阅者信息功能 参与者 图书管理员 前置条件 在这个用例开始前,Libraria
12、n必须登录到系统中 后置条件 如果这个用例成功,系统添加、修改或删除借阅者信息。 基本路径 (1)添加借阅者 (2)提供借阅者的信息,如姓名、地址、邮政编码和身份证号码等。 (3)系统存储借阅者信息 (E-1)。,图书管理系统的分析与设计,备选流-1: 删除借阅者 提供借阅者的信息。 查询借阅者 (E-2)。 查询借阅者的借阅记录 (E-3)。 从系统中删除借阅者的信息,以及借阅者的预定记录。 备选流-2: 更改借阅者 提供借阅者的信息。 查询并显示借阅者的信息 (E-2),修改相应的信息。 更新系统中借阅者的信息。 扩展点: E-1: 若借阅者已存在,系统显示提示信息,用例终止。 E-2:
13、若查询不到借阅者,系统显示提示信息,用例终止。 E-3: 若存在借阅记录,系统显示提示信息,用例终止。,图书管理系统的分析与设计,6. 维护书刊信息,用例编号 US06 用例名 Maintain Title Info 用例描述 完成书刊的添加、修改或删除功能 参与者 图书管理员 前置条件 在这个用例开始前,Librarian必须登录到系统中 后置条件 系统添加、修改或删除书刊种类信息。否则,系统的状态没有变化。 基本路径(1) 添加书刊信息 (2) 提供书刊的书名、作者、ISBN/ISSN5号等信息。 (3) 在系统中添加该书刊信息 (E-1)。,图书管理系统的分析与设计,备选流-2:(1)删
14、除书刊信息 (2)提供所要删除的书刊信息。 (3)查询所要删除的书刊 (E-2)。 (4)删除该书刊的所有物理书刊的信息 (E-3)。 (5)删除书刊信息,以及相关的预定信息。 备选流-3: (1)更改书刊信息 (2)提供要修改的书刊信息。 (3)查询并显示书刊信息 (E-2)。 (4)修改相应的信息。 (5)更新系统中的书刊信息。 E-1: 若书刊信息已存在,系统显示提示信息,用例终止。 E-2: 若查询不到该书刊,系统显示提示信息,用例终止。 E-3:若有物理书刊借出,系统显示提示信息,用例终止。,图书管理系统的分析与设计,7. 维护物理书刊信息,用例编号 US07 用例名 Maintai
15、n Book Info 用例描述 完成书刊的添加、修改或删除功能 参与者 图书管理员 前置条件 在这个用例开始前,Librarian必须登录到系统中 后置条件 系统添加、修改或删除物理书刊种类信息。否则,系统的状态没有变化。 基本路径 (1)添加物理书刊信息 (2)提供物理书刊种类信息。 (3)查询物理书刊的种类(Title),确定系统中已存在该书刊种类 (E-1)。 (4)添加物理书刊。 (5)将物理书刊信息存储到系统中。,图书管理系统的分析与设计,备选流-2:(1)删除物理书刊信息 (2)提供物理书刊的种类信息。 (3)查询物理书刊的种类(Title) (E-1)。 (4)删除物理书刊。
16、(5)从系统中删除物理书刊信息,并更新相关信息。 备选流-3: (1)修改物理书刊信息 (2)提供物理书刊的种类信息。 (3)查询物理书刊的种类(Title)(E-1)。 (4)查询并显示该种书刊的所有物理书刊。 (5)选择物理书刊并修改其信息。 (6)更新系统中物理书刊的信息。 E-1: 若系统中不存在该书刊种类,添加该书刊种类信息,图书管理系统的分析与设计,8. 登录,用例编号 US08 用例名 Log In (登录) 用例描述 完成书刊的添加、修改或删除功能 参与者 图书管理员 前置条件 无 后置条件 参与者可以启动系统并使用系统所提供的功能 基本路径 (1)系统提示用户输入用户名和密码
17、。 (2)用户输入用户名和密码。 (3)系统验证输入的用户名和密码,若正确(E-1),则用户登录到系统中。 E-1: 如果用户输入无效的用户名和/或密码,系统显示错误信息。用户可以选择返回基流6的起始点,重新输入正确的用户名和/或密码;或者取消登录,用例结束。,图书管理系统的分析与设计,第3章 静态结构模型,根据需求分析,发现系统类以及类之间的关系,确定它们的静态结构和动态行为,是面向对象分析的基本任务。系统的静态结构模型主要用类图和对象图描述。识别实体类,定义系统中对象;识别边界类,定义系统界面;定义控制类,简化系统的实现层次;,图书管理系统的分析与设计,3.1 识别实体类,定义系统中对象,
18、系统对象的识别可以通过寻找系统域8描述和需求描述中的名词来进行。从前述的系统需求描述中可以找到的名词有:借阅者(Borrower)、物理书刊(Book)、书刊(Title)、借阅记录(Loan)和预定记录(Reservation),这些都是对象图中的候选对象。判断是否应该为这些候选对象创建类的方法是:是否有与该对象相关的身份和行为?借阅者(Borrower)借阅者是有身份的,具有相同名字和不同身份证号码的两个人也是不同的。在这个系统中,借阅者有相关的行为,借阅者可以借阅、返还、预定书刊或取消预定,所以借阅者应该成为系统中的一个对象。,图书管理系统的分析与设计,3.1识别实体类,定义系统中对象,
19、书刊(Title) 书刊也有身份,可以通过不同的ISBN/ISSN号来区别书刊。在这个系统中,书刊也有相关的行为,书刊可以被预定或被取消预定,所以,书刊也是系统中的一个对象。 物理书刊(Book) 物理书刊也有身份,物理书刊可以被彼此区别,在图书馆中通过独一无二的索引号来区别物理书刊,不同的物理书刊不会被搞混。在这个系统中,物理书刊也有相关的行为,物理书刊可以被借阅或被返还,所以,物理书刊也是系统中的一个对象。,图书管理系统的分析与设计,3.1识别实体类,定义系统中对象,若系统是采用面向对象数据库设计,为了便于从数据库文件中引用和检索对象,需要一个描述对象ID的类。另外,由于上述5个类都是持久
20、性类,因此还可以抽象出一个代表持久性的父类,该类实现了面向对象数据库文件的读、写、存储、检索、删除、更新等操作。综上所述,系统中还应该有两个与数据库有关的类:对象ID(OID)和持久类(Persistent) 类Persistent(相当于VC MFC中的CRcordSet类) 类Persistent是类Borrower、Book、Title、Loan、Reservation的父类。类Persistent为商业对象的持久存储提供了支持,它的子类必须实现从数据库文件中读、写对象属性的操作。,图书管理系统的分析与设计,3.1识别实体类,定义系统中对象,类OID实现了对象ID。 类OID的对象可用来
21、引用系统中的持久10对象,使得从数据库文件中引用和检索对象变得容易。 抽象出系统中的类后,需要确定这些对象的属性和行为。可以根据前述的系统需求分析、用例图、用例的事件流描述和描述脚本的交互作用图,来确定并细化系统中的类、类的操作和属性。,图书管理系统的分析与设计,3.1识别实体类,定义系统中对象,借阅记录(Loan) 借阅记录也有身份,借阅记录可以被彼此区别,不会被搞混。例如,同一个人关于不同书刊的借阅记录是不同的。在这个系统中,借阅记录也有相关的行为,它可以被创建或删除,因此,借阅记录也是系统中的一个对象。 预定记录(Reservation) 预定记录也有身份,预定记录可以被彼此区别,不会被
22、搞混。例如,同一个人关于不同书刊的预定记录是不同的,同一种书刊但不同借阅者的预定记录也是不同的。在这个系统中,借阅记录也有相关的行为,它可以被创建或被删除,因此,借阅记录也是系统中的一个对象。 上述5个类都是实体类,都是持久性的,需要存储在数据库中。,图书管理系统的分析与设计,图3.2 Title类,图书管理系统的分析与设计,3.2 识别边界类,定义系统界面,通过对系统的不断分析和细化,可识别出下述界面类、类的操作和属性。 类MainWindow MainWindow是系统的主界面,系统的主界面具有菜单和菜单项,当选择不同的菜单项时,用户可以执行不同的操作。当程序退出时,主界面窗口关闭。 类M
23、essageWindow 信息窗口类LoginDialog是用来显示提示信息的对话框。 类LoginDialog 界面类LoginDialog是用来输入用户名和密码的对话框。,图书管理系统的分析与设计,图书管理系统的分析与设计,3.2识别边界类,定义系统界面,类BorrowerDialog 界面类BorrowerDialog是进行操作“添加借阅者”、“修改借阅者”或“删除借阅者”时所需的对话框。 类FindBwrDialog 界面类FindBwrDialog是用来根据借阅者ID号查找借阅者的对话框。当主窗口中的菜单项“删除借阅者”或“修改借阅者”被选择时,该对话框弹出,图书管理员输入借阅者ID
24、,单击按钮“OK”,系统查询数据库中具有指定ID号的借阅者信息。,图书管理系统的分析与设计,图书管理系统的分析与设计,3.2识别边界类,定义系统界面,类TitleDialog 界面类TitleDialog是进行操作“添加书种”、“修改书种”或“删除书种”时所需的对话框。 类FindTDialog 界面类FindTDialog是用来根据书刊种类的ISBN/ISSN信息查找书刊种类的对话框。当主窗口中的菜单项“删除书种”或“修改书种”被选择时,该对话框弹出,图书管理员输入书刊种类的ISBN/ISSN信息,单击按钮“OK”,系统查询数据库中具有指定ISBN/ISSN号的Title信息。,图书管理系统
25、的分析与设计,图书管理系统的分析与设计,3.2识别边界类,定义系统界面,类BorrowDialog 界面类BorrowDialog是进行借阅操作时所需的对话框。当主窗口中的菜单项“借阅”被选择时,该对话框弹出,图书管理员输入书刊名、书刊的ISBN/ISSN信息和借阅者信息,然后单击按钮“OK”,借阅动作被确认,系统创建并保存借阅记录。 类ReturnDialog 界面类ReturnDialog是进行还书操作时所需的对话框。当主窗口中的菜单项“还书”被选择时,该对话框弹出,图书管理员输入书刊名、书刊的ISBN/ISSN信息、物理书刊的index号,然后单击按钮“OK”,还书动作被确认,系统中相关
26、的借阅记录被删除。,图书管理系统的分析与设计,3.2识别边界类,定义系统界面,类RsvDialog 界面类RsvDialog是进行操作“预定”或“取消预定”时所需的对话框。,图书管理系统的分析与设计,3.3 定义控制类,控制类(control class)是实体类和边界类之间的润滑剂,是从控制对象中归纳和抽象出来的,用于协调系统内边界类和实体类之间的交互。例如,某个边界对象必须给多个实体对象发送消息,多个实体对象完成操作后,传回一个结果给边界对象,这时,我们可以使用控制类来协调这些实体对象和边界对象之间的交互关系。 根据系统的功能分析,可以定义控制类: 类Control完成系统界面对象对实体对
27、象的添加、修改、删除等操作。,图书管理系统的分析与设计,3.4 确定类之间的关系并建立类图 绘制包图,将类图分类存放,为了更好的表述类之间的关系,可将系统中的类分为3个包:实体类包、接口类包和控制类包。如果包中的类有依赖关系,则认为包之间有依赖关系。 (我们可以从下面的关系中理解),图书管理系统的分析与设计,3.5 确定类之间的关系并建立类图,1.包用户边界类中界面类之间关系窗口MessageWindow和对话框BorrowerDialog、FindBwrDialog、FindTDialog、TitleDialog、BorrowDialog、RsvDialog、ReturnDialog是主窗口
28、MainWindow的一部分。它们之间存在组合关系。MainWindow类LoginDialog与类MainWindow之间存在“一对一”的关联关系。类FindBwrDialog与类BorrowerDialog之间也是“一对一”的关联关系。类FindTDialog与类TitleDialog之间的关系也是“一对一”的关联关系。,图书管理系统的分析与设计,3.5 确定类之间的关系并建立类图,用户边界类关系图,图书管理系统的分析与设计,3.5 确定类之间的关系并建立类图,2.包中的实体类关系类Book、类Title、类Reservation、类Borrower、类Loan都是永久类,它们都是包DB中
29、的类Persistent的子类。类Title与类Book之间存在“一对多”的关联关系,每个Title对象至少有一个Book对象,每个Book对象只对应于一个Title对象。类Title与类Reservation之间存在“一对多”的关联关系,每个Title对象没有或可有多个Reservation(预定),每个Reservation(预定)只能预订一个Title。类Borrower与类Reservation之间存在“一对多”的关联关系,每个Borrower对象可以没有或可有多个Reservation(预定),每个Reservation(预定)只能由一个Borrower预定。类Borrower与类L
30、oan之间存在“一对多”的关联关系,每个Borrower对象可以没有或可有多个Loan(借阅),每个Loan(借阅)只能由一个Borrower借阅。类Loan与类Book之间也存在关联关系,每个Loan只能借阅一个Book,每个Book也至多能对应一个Loan对象(因为每个Book在一个时间段内至多只能被一个人借阅,因此至多只能对应一个借阅记录)。,图书管理系统的分析与设计,3.5 确定类之间的关系并建立类图,2.包中的实体类关系,图书管理系统的分析与设计,3.5 确定类之间的关系并建立类图,3. 预订界面类与实体类之间的关系,图书管理系统的分析与设计,3.5 确定类之间的关系并建立类图,4.
31、 BorrowDialog和ReturnDialog与其他类关系类BorrowDialog依赖于类Book、类Loan、类Reservation、类Borrower和类Title;类ReturnDialog依赖于类Book、类Loan、类Borrower和类Title,图书管理系统的分析与设计,3.5 确定类之间的关系并建立类图,4. orrowDialog和ReturnDialog与其他类关系,图书管理系统的分析与设计,3.5 确定类之间的关系并建立类图,5.借阅者管理界面与实体类之间的关系类BorrowerDialog依赖于类Reservation、类Borrower和类Title;类Fi
32、ndBwrDialog依赖于类Borrower。,图书管理系统的分析与设计,3.5 确定类之间的关系并建立类图,6. 书刊管理界面与实体类之间的关系类TitleDialog依赖于类Book、类Reservation、类Borrower和类Title;类FindTDialog依赖于类Title。,图书管理系统的分析与设计,第4章 动态行为模型,系统的动态行为模型由交互作用图(时序图和协作图)、状态图、活动图来描述。 4.1 系统时序图模型根据需求分析创建的系统用例图,我们主要创建如下11个时序图:添加和删除借阅者、添加和删除书种、添加和删除物理书刊、借书、还书、预订与取消预订、登录。,图书管理系
33、统的分析与设计,时序图描述用例图的基本工作流程的实现。我们为需求分析阶段建立的用例图创建对应的时序图:添加和删除借阅者、添加和删除书种、添加和删除物理书刊登录。,图书管理系统的分析与设计,时序图描述用例图的基本工作流程的实现。我们为需求分析阶段建立的用例图创建对应的时序图:借书、还书、预订与取消预订。,图书管理系统的分析与设计,1. 登录时序图,“登录“的时序图如图所示,图书管理员运行系统,类LoginDialog的方法createDialog()被调用,创建对话框。图书管理员键入用户名和密码,提交,类LoginDialog的方法validate()被调用,验证用户名和密码是否正确,如若正确,
34、发送消息createWindow()给类MainWindow,启动系统,显示系统主界面。,图书管理系统的分析与设计,2. 添加借阅者,“添加借阅者”的过程是:图书管理员选择菜单项“添加借阅者”,对话框弹出,图书管理员输入借阅者信息,提交,系统根据借阅者ID号查询数据库,看数据库中是否已存在借阅者,若不存在,创建借阅者帐户,并存储借阅者信息。“添加借阅者”的时序图如图4.1所示,,图书管理系统的分析与设计,添加时序图中的对象,添加对象时,先选中添加的时序图中的对象图符,打开其“Specifecation”窗口,选中其中的类,是后继创建消息的前提。,图书管理系统的分析与设计,添加消息: “选中消息
35、号”单击右键选中要调用的对象的操作。 右操作是由父类继承来的,则选中“more”进而选中其父类的操作。,图书管理系统的分析与设计,添加借阅者时序图:,图书管理系统的分析与设计,3.删除借阅者时序图,图书管理员选择菜单项“删除借阅者”,类MainWindow的方法delBorrower()被调用,然后通过调用类FindBwrDialog的方法createDialog()创建对话框。图书管理员输入借阅者ID号后,提交信息,类FindBwrDialog的findBorrower()方法被调用,通过调用类Borrower的方法findBorrower(id:String)来确定该借阅者的帐户是否存在,
36、若存在,返回Borrower对象的OID,然后调用类BorrowerDialog的方法createDialog(OID)显示借阅者信息,,图书管理系统的分析与设计,3.删除借阅者时序图,图书管理系统的分析与设计,4.添加书种时序图,图书管理员选择菜单项“添加书种“,类MainWindow的方法addTitle()被调用,然后通过调用类TitleDialog的方法createDialog()创建对话框,图书管理员输入书刊种类信息后,提交,类TitleDialog的方法addTitle()被调用,通过调用类Title的方法findTitle(isbn: String)来确定该书刊种类是否已存在,若
37、不存在,则调用类Title的方法findTitle(isbn: String)来确定该书刊种类是否已存在,若不存在,则调用类Title的createTitle()方法创建Title对象,并调用类Book的方法newBook()创建物理书刊对象,并调用方法store()将Book对象存储到数据库中,然后调用类Title的方法addBook(OID)将物理书刊添加到Title中,然后将Title对象存储到数据库中。,图书管理系统的分析与设计,4.添加书种时序图,图书管理系统的分析与设计,5. “删除书种“时序图,“删除书种“的过程如下。 图书管理员选择菜单项“删除书种”,对话框弹出,图书管理员输入
38、书刊的ISBN/ISSN号,提交。系统查询数据库,显示书刊信息(若书刊信息不存在,给出提示信息,结束删除动作)。检查物理书刊是否有借出。若有,给出提示信息,结束删除动作:若没有,删除物理书刊信息。检查是否有预定记录。若有,删除预定记录并通知借阅者。确认之后删除书种。 图书管理员选择菜单项“删除书种“,类MainWindow的delTitle()方法被调用。然后通过调用类FindTDialog的方法createDialog()创建对话框,图书管理员输入书刊的ISBN/ISSN信息后,提交。类FindTDialog的方法findTitle()被调用。通过调用类Title的方法,图书管理系统的分析与
39、设计,5. “删除书种“时序图,图书管理系统的分析与设计,5. “删除书种”时序图(续上图),图书管理系统的分析与设计,6.添加物理书刊时序图,“添加物理书刊”的过程是: 图书管理员选择菜单项“添加物理书刊“,对话框弹出,图书管理员输入书刊的ISBN/ISSN号,提交,系统查询数据库,显示书刊信息,图书管理员添加物理书刊,单击按钮确认添加,系统创建并存储物理书刊对象,然后将物理书刊添加到书刊种类中,更新书刊种类信息。,图书管理系统的分析与设计,6.添加物理书刊时序图,图书管理系统的分析与设计,7. 删除物理书刊时序图,“删除物理书刊“的过程是:图书管理员选择菜单项“删除物理书刊“,对话框弹出,
40、图书管理员输入书刊的ISBN/ISSN号,提交,系统查询数据库,显示书刊信息,图书管理员从物理书刊列表中删除物理书刊,单击确认按钮删除,系统删除物理书刊对象,并从书刊种类信息中删除物理书刊,最后更新书刊种类信息。,图书管理系统的分析与设计,7. 删除物理书刊时序图,图书管理系统的分析与设计,8. 预定书刊时序图,“预定书刊“的过程是:图书管理员选择菜单项“预定书刊“,对话框弹出,图书管理员输入书刊和借阅者的信息,提交。系统查询数据库,确定该种书刊是否存在。若存在,确定借阅者是否有效;若不存在,则显示提示信息,图书管理员重新输入书刊信息或中止预定操作。若借阅者有效,创建并存储预定记录,并将预定记
41、录添加到相应的借阅者和书刊种类信息中;若借阅者无效,则显示提示信息,图书管理员重新输入借阅者信息或中止预定操作。,图书管理系统的分析与设计,8. 预定书刊时序图,图书管理员选择菜单项“预定书刊“,类MainWindow的reserve()方法被调用,然后通过调用类RsvDialog的方法reserve()被调用,发送消息findBorrower()给类Borrower查询指定ID的借阅者,返回满足条件的Borrower对象的OID,接着调用方法getBorrower()返回对应OID的Borrower对象。发送消息findTitle()给类Title查询指定ISBN/ISSN号的书刊种类,返回
42、满足条件的Title对象的OID,调用方法getTitle()返回对应OID的Title对象。发送消息给Reservation,创建Reservation对象,调用类Reservation的方法store()将预定记录存储到数据库中。发送消息addReservation()给Borrower,将预定记录添加到借阅者信息中,然后调用类Borrower的方法update()更新数据库中的Borrower对象。最后发送消息addReservation()给类Title,将预定记录添加到书刊种类信息中,然后调用类Title的方法update()更新数据库中的Title对象。,图书管理系统的分析与设计,
43、9. 取消预定时序图,“取消预定“的过程是:图书管理员选择菜单项“取消预定“,对话框弹出,图书管理员输入书刊和借阅者的信息,提交,系统查询数据库,确定该种书刊是否存在,若存在(不存在,则显示提示信息,图书管理员重新输入书刊信息或中止取消预定操作),确定借阅者是否有效,若有效(无效,则显示提示信息,图书管理员重新输入借阅者信息或终止取消预定操作),确定预定记录是否存在,若存在(不存在,则显示提示信息,图书管理员重新输入信息或中止取消预定操作),从借阅者和书刊种类信息中删除预定记录,并更新借阅者和书刊种类信息,最后删除预定记录。,图书管理系统的分析与设计,9. 取消预定时序图,图书管理员选择菜单项
44、“取消预定“,类MainWindow的方法delReservation()被调用,然后通过调用类RsvDialog的createDialog()方法创建对话框。图书管理员填写要取消预定的书名、ISBN/ISSN号和借阅者的ID号后,提交信息,类RsvDialog的方法delReservation()被调用,发送消息findBorrower()给类Borrower,查询数据库,返回指定ID的Borrower对象的OID,调用方法getBorrower()返回对应OID的Borrower对象。接着发送消息findTitle()给类Title,查询数据库,返回指定ISBN/ISSN号的Title对象
45、的OID,调用方法getTitle()返回对应OID的Title对象。然后发送消息findRsv()给类Reservation,返回满足条件的Reservation对象的OID,调用方法getObject()返回对应OID的Reservation对象。发送消息delReservation()给类Borrower,删除借阅者信息中的预定记录,然后调用类Borrower的方法update()更新数据库中的Borrower对象。发送消息delReservation()给类Title,删除书刊种类信息中的预定记录,然后调用类Title的方法update()更新数据库中的Title对象。最后发送消息de
46、lete()给类Reservation,删除数据库中的Reservation对象。,图书管理系统的分析与设计,10. 借书时序图,“借书“的过程是:图书管理员选择菜单项“借阅“,对话框弹出,图书管理员输入书刊和借阅者的信息,提交,系统查询数据库,确定该种书刊是否存在,若存在(不存在,则显示提示信息,图书管理员重新输入书刊信息或终止借书操作),确定是否有可借阅的物理图书,若有(没有,则显示提示信息,图书管理员重新输入其它书刊信息或终止借书操作),确定借阅者是否有效,若有效(无效,则显示提示信息,图书管理员重新输入借阅者信息或终止借书操作),创建并存储借阅记录,并将借阅记录添加到物理书刊和借阅者信
47、息中,更新物理书刊和借阅者信息。,图书管理系统的分析与设计,10. 借书时序图,图书管理员选择菜单项“借阅“,类MainWindow的方法borrow()被调用,然后通过调用类BorrowDialog的方法createDialog()创建对话框,图书管理员填写所借书刊的书名、ISBN/ISSN号和借阅者的姓名、ID号,提交信息,类BorrowDialog的方法borrow()被调用,发送消息findTitle()给类Title,查询数据库,返回指定ISBN/ISSN号的Title对象的OID,然后调用方法getTitle()返回与OID对应的Title对象。发送消息getAvaliableBo
48、ok()给类Title,返回未借出的Book对象的OID;发送消息findBorrower()给类Borrower,查询数据库,返回指定ID的Borrower对象的OID;发送消息newLoan()给类Loan,创建Loan对象,并调用类Loan的方法store()将Loan对象存储到数据库中;发送消息getBorrower()给类Borrower,返回对应指定OID的Borrower对象,调用类Borrower的方法addLoan()将借阅记录添加到借阅者信息中,然后调用类Borrower的方法update()更新数据库中的Borrower对象;发送消息getObject()给类Book,返
49、回对应指定OID的Book对象,调用方法setLoan()设置物理书刊的借阅记录,然后调用类Book的方法update()更新数据库中的Book对象。,图书管理系统的分析与设计,11. 还书的时序图,“还书“的过程是:图书管理员选择菜单项“还书“,对话框弹出,图书管理员输入物理书刊的ID号,提交,系统查询数据库,确定指定ID号的物理书刊是否存在,若存在(不存在,则显示提示信息,图书管理员重新输入物理书刊ID号或终止还书操作),确定是否有借阅记录,若有(没有,则显示提示信息,图书管理员重新输入其它物理书刊ID号或终止还书操作),从物理书刊和借阅者信息中删除借阅记录,更新物理书刊和借阅者信息。最后
50、,删除借阅记录。,图书管理系统的分析与设计,11. 还书的时序图,图书管理员选择菜单项“还书“,类Mainwindow的方法return()被调用,然后通过调用类ReturnDialog的方法createDialog()创建对话框,图书管理员填写所还物理书刊的ID号后,提交信息,类ReturnDialog的方法return()被调用,发送消息findBook()给类Book,查询数据库,返回指定ID的Book对象的OID,接着调用方法getObject(),返回与OID对应的Book对象;然后发送消息getLoan()给类Book,返回Loan对象;发送消息getBorrower()给类Loan,返回Borrower对象;发送消息setLoan(null)给类Book,删除物理书刊信息中的借阅记录,然后调用类Book的方法update()更新数据库中的Book对象;发送消息delLoan()给类Borrower,删除借阅者信息中的借阅记录,然后调用类Borrower的方法update()更新数据库中的Borrower对象;最后发送消息delete()给类Loan,删除数据库中的Loan对象。,