网络编程经常涉及数据库访问,电子商务更离不开数据库。例如用户请求股票报价、产品价格查询、网上交易等请求,服务器则需要连接对应的数据库,发送查询指令,得到数据库记录,经过处理后,发送给提出这个请求的用户。
在实际应用中,数据库经常由专门管理数据库的服务器运行。由于用户端程序通过服务器端程序,而不直接访问数据库服务器,我们称这种服务器为后台服务器(Back-end server)。而运行服务器端程序的服务器常常需要与更多的后台服务器,如文件服务器、网页服务器等进行通信,构成多层次-多用户-服务器系统程序设计(Multi-tier client-server programming)。
下面利用一个实战项目一步步详细讨论多用户-服务器数据库编程以及模拟运行测试。
1、项目分析
这个实战项目是多层次-用户-服务器程序开发的实例。具体讲,是一个利用Socket技术实现多用户-服务器-数据库编程的典型例子。为了增加程序的可读性和实用性,在用户端代码中应用GUI组件,如窗口、选项框、单选按钮、文本框以及按钮来实现对服务器发出对数据库指定记录的提取和显示指令。用户可以对MySQL数据库ProductDB中的两个不同数据表Products以及Books的记录,按照单选按钮组中的不同价格选项,进行查询访问。如下是在Eclipse中运行服务器程序MultTierSocketServer并显示服务器正在与两个本机用户连接并运行的信息:
Welcome! The