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

    数据库配置 django默认支持sqlite,MySQL,Oracle,postgresql数据库 如何将数据库设置为MySQL 将setting中的database修改: DATABASES = { ...

  2. win7 WindowsImageBackup 无法识别

    控制面板\所有控制面板项\备份和还原

  3. Go语言的GOPATH与工作目录详解

    这篇文章主要介绍了Go语言的GOPATH与工作目录详解,本文详细讲解了GOPATH设置.应用目录结构.编译应用等内容,需要的朋友可以参考下 GOPATH设置 go 命令依赖一个重要的环境变量:$GOP ...

  4. uploadify使用教程

    <div> <input type="file" id="uploadify" name="uploadify" /> ...

  5. LeetCode First Unique Character in a String

    原题链接在这里:https://leetcode.com/problems/first-unique-character-in-a-string/ 题目: Given a string, find t ...

  6. jS正则和WEB框架Django的入门

    JS正则 -test 判断字符串是否符合规定的正则表达式 -exec 获取匹配的数据 test的例子: 从上述的例子我们可以看出,如果rep.test匹配到了就返回true,否则返回false exe ...

  7. js贪吃蛇源码

    1.注意,自己引入jquery,这个demo基于jquery的,我的jquery是写的本地的 2.没有写注释,看不懂的再问我吧, <!DOCTYPE html><html> & ...

  8. CryptographicException异常处理方法

    在调用System.Security.Cryptography.ProtectedData.Protect方法来保护私密信息时,IIS可能会报以下错误:CryptographicException: ...

  9. 全国城市三级联动 html+js

    全国城市三级联动,没有css,所以屏幕的自适应必须自己想办法,手机端慎用(最好不要用,因为有些我也说不出的展示问题). html页面 <!DOCTYPE html> <html> ...

  10. 【unity3d游戏开发脚本笔记之一:坐标系选择对物体运动的影响】

    时间:2016年9月24日17:38:21   作者:yexiaopeng 博客园     在unity3d的世界中,其坐标系可分为四种,世界坐标系-WorldSpace   本地坐标系-LocalS ...