我们刚开始学新东西的时候,往往希望能从一个实例进行入手学习。接下来的系列连载文章也主要是围绕这个实例进行。这个实例原形是从电子书《Android应用开发详解》得到的,我们在这里对其进行详细的解释,并对Android的一些基础知识穿插进去,并对该例子进行一些新的扩充。

本节说阐述的很多内容可能与Android相关性并不大,但是本节确实之后的基础,也是想从一个系统架构方面来体现Anroid在一个系统之后所担当的职责。在我现在的理解之中,Android在一系统之中,其承担的职责是前端的展示以及一些逻辑的简单处理,就好比是一个浏览器,包括IOS所负责的也是前端内容的展示。(当然,如果你所做的是无关互联网的APP,如本地Anroid一些游戏的开发则另当别论)。

一.需求分析

该例子是一个无线点餐系统。简单来分析一些该系统的需求分析。在一个大的餐馆当中,面对很多的顾客,为了方便顾客点餐,提升饭店的效率,需一个无限终端实现对顾客的点餐。也就是说由一个无线客户端负责对点餐,还需有一个PC用来进行结账以及打印工作。

二.技术选型

下面具体来看我们的技术选型。

无线客户端我们使用Android客户端,网络通信部分我们使用Apache Http协议客户端,中间Web服务器采用Servlet响应客户端请求。后台数据库采用JDBC访问数据库,数据库我们采用MySql,部分存储我们使用本地的SqlLite数据库(这里涉及到MySql与SqlLite的数据同步问题),结账以及打印功能我们采取WPF去做。

看了以上这些技术,你可能会感觉有点晕,但是实现起来并没有我们想象的那么困难,之后的文章会对各个技术进行详细阐述。

三.系统功能

首先我们来看Android客户端所需实现的功能。

1.系统的登陆功能

每个系统都会有一个入口,即登陆。通过登陆可以进入系统的主菜单,转而使用其他功能。

2.点餐功能

该功能也是我们系统之中的核心功能。该功能有操作员来完成,通过输入顾客的点餐信息,通过无线网络将数据保存到系统后台的服务器当中,进而在厨房的终端进行显示。该功能主要包括三个部分:开桌,点菜和下单。

3.查台功能

即当顾客进行点餐的时候,需要首先查询有哪些桌子是空的,才可安排顾客进行就餐。

4.更新功能

为了提高程序的运行效率。我们需要将部分数据保存的手机本地的SqlLite数据库中,在此系统之中,我们需要将菜单以及桌子号码的数据保存到SqlLite数据库当中,因此当后台数据库更新菜单以及桌号时,我们自然也需要将该数据同步更新到本地SqlLite数据库当中。

5.转台功能

转台功能是指当顾客下单之后,又要求更换座位,我们这时需要将已经保存到数据库中的数据进行更新。(说白了,就是对订单的修改)

6.并台功能

并台功能是指将已经下单的两组顾客合并到同一桌子上。该功能也需要修改已经提交给服务器数据。

我们再来看看PC客户端所要实现的功能。

1.登陆功能

PC客户端的登陆。

2.结账功能

当顾客付完钱后,实现对订单的结账。

3.打印功能

对订单的打印。

4.对服务员的增删改查。

即如果餐馆新增一名服务员,则需要新添加一个新的账号,给服务员使用。

四.系统的详细设计

1.数据库的设计

Anroid客户端下的系统架构如下。

1.系统包资源的规划(就相当于我们在VS下,一个解决方案由哪些类库组成)

本系统的主要功能可以分为三类:一是访问客户端SqlLite的数据库;二是Activity界面展示;三是通过网络访问服务器数据。

表1     系统包说明

           包名称             包描述
com.golook.provider 访问本地SqlLite数据库的Provider
com.golook.util 工具类包
com.golook.wlo Activity包

对于PC客户端的设计,因为使用到的是.Net技术,相信大家都很熟悉,在之后的文章中会提及,这里就不再累述。

2.数据库的设计

之前我们提过,数据库的设计架构是服务端采用MySql数据库(我自己搭建的数据库是MySql5.7),Android客户端的数据库采用的是自身的SqlLite数据库。两个数据库之间存在着数据库的更新,而使其可以保持一致。下来我们具体来看看是如何设计表。

1.系统用户表(usertbl),登陆系统使用

Field Name Fielt Type Size Comment
id Integer 主键,自动增长
account Varchar 登陆账号
password Varchar 登陆密码
name Varchar 姓名
gender Varchar 性别
permission Integer 权限 1-管理员 2-收银员 3-服务员
remark Varchar 备注

2.菜谱分类表(menutypetbl)。将菜单信息分类,如热菜,凉菜,海鲜等等。

Field Name Fielt Type Size Comment
id Integer 主键,自动增长
name Varchar 类型名称

3.菜谱表(menutbl),用来保存菜的基本信息。

Field Name Fielt Type Size Comment
id Integer 主键,自增长
typeId Integer 外键,引用外键,引用菜谱分类表Id
name Varchar 名称
price Integer 价格
pic Varchar 图片路径
remark Varchar 备注

4.餐桌表(tabletbl)。用来表示顾客在哪个座位就餐。

Field Name Fielt Type Size Comment
id Integer 主键,自增长
num Integer 桌号
flag Integer 餐桌状态 0-空桌子 1-有人就餐
description Varchar 描述

5.订单表(OrderTbl)。

Field Name Fielt Type Size Comment
id Integer 主键,自增长
orderTime Varchar 下单时间
userId Interger 下单用户,外键-系统用户表Id
tableId Integer 桌号,外键-桌号的Id
personNum Integer 人数
isPay Integer 是否结算 0-未结算 1-结算
remark Varchar 备注

6.订单明细表(OrderDetailTbl),与订单表是一对多的关系。

Field Name Fielt Type Size Comment
id Integer 主键,自增长
orderId Interger 外键,参照订单Id
menuId Integer 外键,参照菜谱Id
num Integer 数量
remark Integer 备注

这是数据库的大概设计,在文末我会把MySql的数据库脚本放置出来,供大家下载。

下节会从Android的界面讲起,直到能完成登陆功能。

该无限点餐系统数据库Sql脚本。点击此处下载

从零开始学习Android(二)从架构开始说起的更多相关文章

  1. 从零开始学习jQuery (二) 万能的选择器

    本系列文章导航 从零开始学习jQuery (二) 万能的选择器 一.摘要 本章讲解jQuery最重要的选择器部分的知识. 有了jQuery的选择器我们几乎可以获取页面上任意的一个或一组对象, 可以明显 ...

  2. 从零开始学习Android(一)Android环境的搭建

    好久没有开始写博客了,最近开始学习Android,所以想把学习的笔记都一一记录下来.一来是方便自己以后资料的查询,其次也是给Android新手朋友进行学习使用,再次也希 望得到高手的指点.废话少说,我 ...

  3. oracle从零开始学习笔记 二

    多表查询 等值连接(Equijoin) select ename,empno,sal,emp.deptno from emp,dept where dept.deptno=emp.deptno; 非等 ...

  4. 从零开始学习Vue(二)

    思维方式的变化 WebForm时代, Aspx.cs 取得数据,绑定到前台的Repeater之类的控件.重新渲染整个HTML页面.就是整个页面不断的刷新;后来微软打了个补丁,推出了AJAX控件,比如U ...

  5. 从零开始学习jQuery(转)

    本系列文章导航 从零开始学习jQuery (一) 开天辟地入门篇 从零开始学习jQuery (二) 万能的选择器 从零开始学习jQuery (三) 管理jQuery包装集 从零开始学习jQuery ( ...

  6. 从零开始学习jQuery

    转自:http://www.cnblogs.com/zhangziqiu/archive/2009/04/30/jQuery-Learn-1.html 本系列文章导航 从零开始学习jQuery (一) ...

  7. android学习——android架构

    android架构:在了解全局的情况下进行细致化的分析才能更有效的学习android的运行原理,才能更深刻的理解android开发: 1.架构图直观 2.架构详解 2.1.Linux Kernel 2 ...

  8. 从零开始学习 asp.net core 2.1 web api 后端api基础框架(二)-创建项目

    原文:从零开始学习 asp.net core 2.1 web api 后端api基础框架(二)-创建项目 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.ne ...

  9. Android Animation学习(二) ApiDemos解析:基本Animators使用

    Android Animation学习(二) ApiDemos解析:基本Animatiors使用 Animator类提供了创建动画的基本结构,但是一般使用的是它的子类: ValueAnimator.O ...

随机推荐

  1. (java oracle)以bean和array为参数的存储过程及dao部分代码

    一.数据库部分 1.创建bean对象 CREATE OR REPLACE TYPE "QUARTZJOBBEAN" as object ( -- Author : Duwc -- ...

  2. golang DynamoDB sdk AccessDeniedException

    golang调用aws sdk时候提示: AccessDeniedException: User: arn:aws:sts::818539432014:assumed-role/bj-develop/ ...

  3. wamp下多域名配置问题

    1.找到wamp安装目录的apache安装目录 找到 httpd.conf文件 例如我安装的目录为 E:\wamp\bin\apache\apache2.2.8\conf\httpd.conf 也可以 ...

  4. [CC]区域生长算法——点云分割

    基于CC写的插件,利用PCL中算法实现: void qLxPluginPCL::doRegionGrowing() { assert(m_app); if (!m_app) return; const ...

  5. MongoDB win安装后无法远程连接访问

    mongoDB安装后无法远程连接访问,原因是端口没有开放允许连接的权限 开启允许连接的权限: 管理工具-高级win防火墙

  6. 为什么使用spring

    现在基本的项目都会用到spring框架,那么我们为什么要使用spring呢?下面为大家总结一下,希望大家指正. spring是一个轻量级的容器框架,其核心是IOC(控制反转也叫依赖注入)和AOP(面向 ...

  7. UVALive 7141 BombX(离散化+线段树)(2014 Asia Shanghai Regional Contest)

    题目链接:https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&category=6 ...

  8. pod install 无限卡顿

    pod install  被墙了,请大家换成pod install --verbose --no-repo-update

  9. 19.在HTTP 1.0中,状态码401的含义是(?);如果返回“找不到文件”的提示,则可用 header 函数,其语句为(?)写出http常见的状态码和含义,至少5个.[完善题目]

    状态401代表未被授权,header("Location:www.xxx.php"); 100-199 用于指定客户端应相应的某些动作. 200-299 用于表示请求成功. 300 ...

  10. Android中ListView动态加载数据

    1. 引言: 为了提高ListView的效率和应用程序的性能,在Android应用程序中不应该一次性加载ListView所要显示的全部信息,而是采取分批加载策略,随着用户的滑动,动态的从后台加载所需的 ...