[c#]asp.net开发微信公众平台(1)数据库设计
开发微信公众平台之前,先去微信官方了解下大概的情况 这里:http://mp.weixin.qq.com/wiki/index.php ;看了之后心里大致有数了,开始设计数据库,尽可能的考虑,未考虑到的,以后再补充。
1、首先是用户部分,根据微信官方的接口结合实际运用,用户部分有3个表:用户表、用户资料表、用户分组表,我设计的如下:
2、用户设计好之后就是文章部分,包括:文章分类表、文章表, 设计如下:
3、有了用户相关的表我们可以保存用户,有了文章模块的表我们可以根据用户输入的信息查询文章进行返回(返回文本、图文、图片、音乐、视频、语音等等),但是实际运用中,我们存在需要指定特定的关键字返回特定的内容的情况,那么就需要专门的特定关键字模块, 包括:关键字表、关键字返回的内容表, 这里的内容表看着像是与上面的文章表有重合,实则不然, 这里是特定关键字指定的回复内容,可以指定返回文本、图文或其他多媒体信息,当返回多媒体信息时内容中存入文件地址, 上面的文章表是标准的通用的文章内容表, 供用户查询多数情况下直接返回图文信息,且图文信息点击链接时就是这篇文章对应的展示地址, 相当于一个微网站, 所以文章和这个关键字的内容表分开设计更加方便管理。 设计如下:
4、消息记录, 把用户发来的消息进行记录,方便后续处理, 比如 根据用户上次发来的事件消息,之后再发同一个关键词时,返回对应菜单下的内容,而不用用户每次发送消息都带对应的菜单选项;客服消息根据记录的信息做个性化的服务 等等。 包括:用户发来的消息记录表、回复给用户的消息记录表 ,有了这些可以完整的还原和用户的对话,这里是记录和用户交流的过程,具体用户发来的消息需要返回什么样的消息,由项目代码中业务决定。 设计如下:
5、自定义菜单,创建和管理微信公众平台中的自定义菜单,设计如下:
6、其他, 具体根据做的实际项目来设计, 比如 用户分析、访问统计; 用户积分; 二维码相关 等等 , 此处先不设计。
以上设计中,有一些是没有设计到数据库的, 比如关键字模块中的回复消息类型、消息记录中的消息类型, 这些固定不变(由腾讯决定)的少量的单选项形式的数据,我们在具体项目中使用其他方法来实现(固定静态、配置文件、缓存等),无需设计数据库。
完整设计如下:(为了方便截图 ,我把各个模块的表拖动覆盖了)
下载脚本,如下:在数据库中创建一个名为微信(设计数据库时自己定义的)的数据库,脚本执行一下就OK,
use weixin -------微信公众平台
if exists ( select * from sysobjects where name = 'tb_User' and xtype='U')
drop table tb_User
create table tb_User------------------------------------------------------------用户表
(
ID int primary key identity(1,1) NOT NULL , --主键-主键
InId int default 0 NOT NULL , --自有系统的用户ID
OpenId varchar(150) default '' NOT NULL , --微信openid
Group int default 0 NOT NULL , --分组ID
NickName varchar(50) default '' NOT NULL , --昵称-微信
CreateTime datetime default getdate() NOT NULL , --创建时间
State int default 1 NOT NULL , --状态-1为正常
PreFirst varchar(150) default '' NOT NULL , --预留字段1
); if exists ( select * from sysobjects where name = 'tb_Group' and xtype='U')
drop table tb_Group
create table tb_Group-----------------------------------------------------------分组表
(
ID int primary key identity(1,1) NOT NULL , --主键-主键
Name varchar(50) default '' NOT NULL , --名称-本地
WeiId int default 0 NOT NULL , --对应微信分组ID
WeiName varchar(50) default '' NOT NULL , --微信分组名
Note varchar(100) default '' NOT NULL , --备注
CreateTime datetime default getdate() NOT NULL , --创建时间
State int default 1 NOT NULL , --状态
); if exists ( select * from sysobjects where name = 'tb_UserData' and xtype='U')
drop table tb_UserData
create table tb_UserData--------------------------------------------------------用户资料表
(
ID int primary key identity(1,1) NOT NULL , --主键-主键
UserId int default 0 NOT NULL , --用户表主键
Sex int default 0 NOT NULL , --性别0未知1男2女
City varchar(20) default '' NOT NULL , --城市
Country varchar(30) default '' NOT NULL , --国家
Province varchar(20) default '' NOT NULL , --省份
Language varchar(15) default '' NOT NULL , --语言
HeadImgUrl varchar(250) default '' NOT NULL , --用户头像
SubTime varchar(50) default '' NOT NULL , --最后次关注时间戳
CreateTime datetime default getdate() NOT NULL , --创建时间
State int default 1 NOT NULL , --状态
PreFirst varchar(150) default '' NOT NULL , --预留1
); if exists ( select * from sysobjects where name = 'tb_Article' and xtype='U')
drop table tb_Article
create table tb_Article---------------------------------------------------------文章表
(
ID int primary key identity(1,1) NOT NULL , --主键-主键
SortId int default 0 NOT NULL , --类别ID
ITop int default 0 NOT NULL , --置顶0不1是
TopBeginTime datetime default getdate() NOT NULL , --置顶开始时间
TopEndTime datetime default getdate() NOT NULL , --置顶结束时间
Title varchar(100) default '' NOT NULL , --标题
KeyWorld varchar(150) default '' NOT NULL , --关键字
Summary varchar(680) default '' NOT NULL , --简介//680为微信文字上限左右
Content ntext default '' NOT NULL , --内容
Source varchar(50) default '独家原创' NOT NULL , --来源
CreateTime datetime default getdate() NOT NULL , --创建时间
PublishTime datetime default getdate() NOT NULL , --发布时间
AOrder int default 99 NOT NULL , --排序
State int default 1 NOT NULL , --状态
MinImg varchar(350) default '' NOT NULL , --缩略图
); if exists ( select * from sysobjects where name = 'tb_ArtSort' and xtype='U')
drop table tb_ArtSort
create table tb_ArtSort---------------------------------------------------------文章分类表
(
ID int primary key identity(1,1) NOT NULL , --主键-主键
Name varchar(50) default '' NOT NULL , --名称
ParentId int default 0 NOT NULL , --父级ID
IndexLevel int default 1 NOT NULL , --当前级别
SOrder int default 99 NOT NULL , --排序
State int default 1 NOT NULL , --状态
Note varchar(150) default '' NOT NULL , --备注
); if exists ( select * from sysobjects where name = 'tb_KeyWord' and xtype='U')
drop table tb_KeyWord
create table tb_KeyWord---------------------------------------------------------关键字表
(
ID int primary key identity(1,1) NOT NULL , --主键-主键
Name varchar(50) default '' NOT NULL , --名称
Note varchar(250) default '' NOT NULL , --备注
State int default 1 NOT NULL , --状态
CreateTime datetime default getdate() NOT NULL , --创建时间
ReType int default 1 NOT NULL , --回复消息类型1为文本
); if exists ( select * from sysobjects where name = 'tb_KeyContent' and xtype='U')
drop table tb_KeyContent
create table tb_KeyContent------------------------------------------------------关键字返回内容表
(
ID int primary key identity(1,1) NOT NULL , --主键-主键
Title varchar(150) default '' NOT NULL , --标题
Content varchar(700) default '' NOT NULL , --内容
KeyId int default 0 NOT NULL , --关键字ID
Type int default 1 NOT NULL , --类型-文本图文等
MinImg varchar(250) default '' NOT NULL , --图片
ITop int default 0 NOT NULL , --置顶
TopBeginTime datetime default getdate() NOT NULL , --置顶开始时间
TopEndTime datetime default getdate() NOT NULL , --置顶结束时间
CreateTime datetime default getdate() NOT NULL , --创建时间
State int default 1 NOT NULL , --状态
Href varchar(250) default '#' NOT NULL , --图文时点开的链接
); if exists ( select * from sysobjects where name = 'tb_UserMsg' and xtype='U')
drop table tb_UserMsg
create table tb_UserMsg---------------------------------------------------------用户消息记录表
(
ID int primary key identity(1,1) NOT NULL , --主键-主键
MsgType int default 1 NOT NULL , --消息类型文本、事件
EventId int default 1 NOT NULL , --事件ID//自定义菜单的ID
Content varchar(700) default '' NOT NULL , --消息内容
CreateTime datetime default getdate() NOT NULL , --创建时间
State int default 1 NOT NULL , --状态
ReState int default 0 NOT NULL , --回复状态
WeiMsgId varchar(50) default '' NOT NULL , --微信消息ID
UserId int default 0 NOT NULL , --用户表主键
); if exists ( select * from sysobjects where name = 'tb_245' and xtype='U')
drop table tb_245
create table tb_245-------------------------------------------------------------回复消息表
(
ID int primary key identity(1,1) NOT NULL , --主键-主键
UserId int default 0 NOT NULL , --用户表主键
MsgID int default 0 NOT NULL , --消息表主键
ReType int default 1 NOT NULL , --回复类型//文本图文
ReFrom int default 1 NOT NULL , --回复点//1文章2关键词
ReContentId varchar(80) default '0,' NOT NULL , --回复的内容ID串
CreateTime datetime default getdate() NOT NULL , --回复记录时间
); if exists ( select * from sysobjects where name = 'tb_PersonalMenu' and xtype='U')
drop table tb_PersonalMenu
create table tb_PersonalMenu----------------------------------------------------自定义菜单表
(
ID int primary key identity(1,1) NOT NULL , --主键-主键
Name varchar(50) default '' NOT NULL , --名称
Type int default 1 NOT NULL , --类型1click2view
ParentId int default 0 NOT NULL , --父级ID
IndexLevel int default 1 NOT NULL , --当前级别
LinkUrl varchar(350) default '#' NOT NULL , --链接地址view时用
CreateTime datetime default getdate() NOT NULL , --创建时间
POrder int default 99 NOT NULL , --排序
State int default 1 NOT NULL , --状态
Note varchar(150) default '' NOT NULL , --备注
);
第一步数据库设计就到这里结束了, 后续开始项目的代码旅程...
[c#]asp.net开发微信公众平台(1)数据库设计的更多相关文章
- [C#]asp.net开发微信公众平台----目录汇总-持续更新
1.[c#]asp.net微信公众平台开发(1)数据库设计 2.[c#]asp.net微信公众平台开发(2)多层架构框架搭建和入口实现 3.[c#]asp.net微信公众平台开发(3)微信消息封装及反 ...
- [c#]asp.net开发微信公众平台(8)微信9大高级接口,自定义菜单
前7篇把最基础的消息接收和回复全做完了, 也把高级接口的入口和分拆处理写好了空方法, 此篇接着介绍微信的9大高级接口, 并着重讲解其中的自定义菜单. 微信9大接口为: 1.语音识别接口 2.客服接 ...
- [c#]asp.net开发微信公众平台(7)前6篇的整体框架demo源码
这里给出的demo是具备整体框架的微信公众平台源码, 所谓demo就是拿过去就可以直接演示使用的东西, 当然不会具备非常详细的具体到业务层面.数据层面的东西, 每个人都可以在此基础上自由发挥, 只 ...
- [c#]asp.net开发微信公众平台(6)阶段总结、服务搭建、接入
经过前5篇,跟着一步步来的话,任何人都能搭建好一个能处理各种微信消息的框架了,总结一下最容易忽略的问题: 1.文本消息中可以使用换行符\n : 2.微信发来的消息中带的那个长整型的时间,我们完全 ...
- [c#]asp.net开发微信公众平台(5)微信图文消息
上篇已经成功响应了关注事件,也实现了文本消息的发送,这篇开始图文消息处理, 微信中最常用的消息类型就是图文消息了,因为它图文并茂,最能表达信息. 图文消息在微信中的接口定义如下: <xml> ...
- asp.net开发微信公众平台----目录汇总-持续更新
1.[c#]asp.net微信公众平台开发(1)数据库设计 2.[c#]asp.net微信公众平台开发(2)多层架构框架搭建和入口实现 3.[c#]asp.net微信公众平台开发(3)微信消息封装及反 ...
- [c#]asp.net开发微信公众平台(4)关注事件、用户记录、回复文本消息
上一篇已经把所有消息封装且都各自有方法处理了,这篇从使用第一步——关注开始, 关注之后进行消息记录,同时回复文本消息给用户,关注方法:DoSub,另外新用户扫描带参数的二维码关注方法:DoCodeN ...
- [c#]asp.net开发微信公众平台(3)微信消息封装及反射赋值
上一篇已经搭建好整体框架,实现了入口的验证, 验证通过后就交给LookMsgType方法处理,LookMsgType方法主要是对微信发来的不同的消息进行分解,不同的类型交给业务逻辑层不同的方法处理 ...
- [c#]asp.net开发微信公众平台(2)多层架构框架搭建和入口实现
上篇已经设计出比较完善的数据库了,这篇开始进入代码. 首先把上篇设计的数据库脚本在数据库中执行下,生成数据库,然后在VS中建立项目,为了方便理解和查看,我设计的都是很直白的类名和文件名,没有命名空间 ...
随机推荐
- C# ORM—Entity Framework 之Code first(代码优先)(二)
一.Entity Framework Code first(代码优先)使用过程 1.1Entity Framework 代码优先简介 不得不提Entity Framework Code First这个 ...
- 【学习笔记】【oc】指针
1.取一个变量的值,可通过直接与间接的方式 直接:访问变量 间接:通过变量的内存地址来获取变量的值. 存放内存地址的变量就是指针变量. 2.定义指针变量的语法:类型* 变量名 &:取地址运算符 ...
- 新的疑问(未解决):VC项目的配置,不是都能在Project -- Properties里设置解决的
现象:死活解决不了引入外部库的LPCWSTR参数传递问题.而用VS新建的项目,就没有这个问题. 我怀疑是当初.pro文件产生VC项目文件时候,做了一些设置,但是内容太长了,又很复杂,所以没法核对. 用 ...
- MATLAB图像处理基础
MATLAB图像处理基础 2.2.1 图像文件格式及图像类型 1.MATLAB支持的几种图像文件格式: ⑴JPEG(Joint Photogyaphic Expeyts Group):一种称为联合图像 ...
- OpenStack入门之初步认识
一.OpenStack 入门 之 基础知识 二.OpenStack 入门 之 基本组件 三.OpenStack 入门 之 各组件解析(基础) 四.OpenStack 入门 之 各组件解析(进阶) 五. ...
- Cantor表(中等)
2 3 1/2 2/1 题目分析 这是NoI的一道题目,不过题目比较有创意也比较适合新生,就是一道简单的找规律的题目,首先找到第N个数应该在第几个斜行,然后判断这一行是奇数还是偶数,偶数分母递减,分子 ...
- 转:有关Java泛型的类型擦除(type erasing)
转载自:拈花微笑 自从Java 5引入泛型之后,Java与C++对于泛型不同的实现的优劣便一直是饭后的谈资.在我之前的很多training中,当讲到Java泛型时总是会和C++的实现比较,一般得出的结 ...
- JavaScript实现自定义短信模板
自定义短信模板,要求:可以插入关键字,当然是可以在点击到文本域中的任意位置,关键字以中括号包裹的形式出现[关键字],删除关键字要整个关键都删掉,而不是自己全删除. 详细在简书中 http://www. ...
- C# 我是个传奇的 using
呵呵呵: ----------------------------------------------------------------------------------------------- ...
- 浅谈MVC模式
MVC模式(三层架构模式) (Model-View-Controller)是软件工程中的一种软件架构模式,把软件系统分为三个基本部分:模型(Model).视图(View)和控制器(Controller ...