我们刚开始学新东西的时候,往往希望能从一个实例进行入手学习。接下来的系列连载文章也主要是围绕这个实例进行。这个实例原形是从电子书《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. ubuntu 更改时区

    更改/etc/timezone Asia/Chongqing sudo dpkg-reconfigure tzdata

  2. 详解一个自己原创的正则匹配IP的表达式

    这里给大家详细讲解一下一个匹配IP地址的正则表达式, 有关正则方面的知识,会在详细的讲解中提到. 在讲解之前,我先给大家介绍一下,ip地址的生成规则. IP地址,是由32位数字二进制转为四个十进制的字 ...

  3. ionic实现点击popup区域外部分来关闭popup

    var htmlEl = angular.element(document.querySelector('html')); htmlEl.on('click', function (event) { ...

  4. jQuery初始化加载的实现

    与jQuery事件模块的其他事件不同,其他事件是通过数据缓存实现的,而初始化事件,jQuery.ready则是通过回调函数列表实现的.$()的参数如果是函数就向回调函数列表中添加回调函数,同时为DOM ...

  5. nginx 客户端不缓存header

    location ~* \.(html|htm)$ { add_header Cache-Control no-store; }

  6. c语言简易版文法

    文法 <程序>→<外部声明>|<程序><外部声明> <外部声明>→<函数定义>|<声明> <函数定义>→ ...

  7. TP框架常用(一)

    25.显示最后一条查询的sql语句:主要用于在连贯操作时,检测拼接的sql语句是否正确 echo $this->db->last_query();//如:select * from pt_ ...

  8. javascript 中的 let 作用域

    let 声明了一个块级域的局部变量,并且可以给它一个初始化值. 语法EDIT let var1 [= value1] [, var2 [= value2]] [, ..., varN [= value ...

  9. 与资源库同步时,我的svn报错 Previous operation has not finished; run 'cleanup' if it was interrupted

    解决办法:选择你的项目,右键,小组(Team),刷新或清理(Refresh or Clean)即可.

  10. Android--RecyclerView的封装使用

    1,用了很长一段时间的RecyclerView,在项目中用的频率也越来越频繁(因为踩得坑也越来越多了),或过头来看,感觉一直在写RecyclerView.Adapter中的三个方法和一个内部类,感觉很 ...