这里GET和POST没有明确的含义,GET也可以新增
path = /{版本}/{具体的业务功能}/{表名}/{行为}
{具体的业务功能}:
{表名}:就是数据的表名
http协议 | 方法 | 行为path | 说明 |
---|---|---|---|
POST | add(POJO) | /add | 添加一个对象,接收json信息 |
GET | insert(param …) | /insert?param1=?¶m1=? | 插入一个对象,多个参数的方式,作用和add一样,只是传参数方式不同 |
GET | deleteById(long) | /delete_by_id?id=? | 数据库不删除,但是业务上有删除的语意 |
POST | update(POJO) | /update | 更新一个对象,接收json信息 |
GET | updateById(long) | /update_by_id?id=? | {表名}中已经具体指明了实体,所有这里可以不用update_pojo_by_id |
GET | getById(long) | /get_by_id?id=? | {表名}中已经具体指明了实体,所有这里可以不用get_pojo_by_id |
GET | listByParam(Object) | /list_by_param?param=?&page=2&perPage=100 | list查询多个,默认全部,可以带上limit,offset,page,sortBy,order等参数 |
参考数据库设计
https://blog.csdn.net/zengqiang1/article/details/79338660
【推荐】表的命名最好是加上“业务名称_表的作用”。
正例:app_user / trade_config
【推荐】库名与应用名称尽量一致,{业务项目}_{功能},业务项目和功能怎么写参考
{"token":"123","timestamp":"1234","userId":"123","channel":"123","channelCode":"123","pushId":"134","initStamp":"123","device":"123","deviceId":"123","systemVersion":"123","come_from":"123","platformId":"123","appName":"123","appVersion":"123","extra":"123"}
CREATE TABLE `user_extra_relation` (
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增主键',
`user_id` bigint(20) DEFAULT NULL COMMENT 'user表中的id',
`come_from` varchar(64) NOT NULL DEFAULT '' COMMENT '项目来源,例如APP要做一个母亲节的活动,或者520活动,from=母亲节活动,from=520活动,表明我做活动的一个转化率,这个也必须有一个对照表,
`device_id` varchar(64) NOT NULL DEFAULT '' COMMENT '第一次产生用户注册的设备id',
`channel_code` varchar(32) NOT NULL DEFAULT 'self' COMMENT '渠道标识,self:自有渠道,其他外部渠道也可以注册用户,非必传,默认 self',
`platform_id` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '平台ID,platformId 对照表,例如 1:web,2:iOS,3:Android,4:miniApp',
`app_name` varchar(32) NOT NULL DEFAULT '' COMMENT 'appName 应用名称,
`token` varchar(64) NOT NULL DEFAULT '' COMMENT '用户token',
`timestamp` varchar(64) NOT NULL DEFAULT '' COMMENT '发送请求时间戳',
`channel` varchar(32) NOT NULL DEFAULT '' COMMENT '渠道来源,从哪个渠道上面下载的包(iOS就只有一个App Store,Android有小米,应用宝,豌豆荚等国内的渠道),这个也必须有一个对照表https://lexiangla.com/docs/27c78dba373e11e8892b5254004fae61',
`push_id` varchar(64) NOT NULL DEFAULT '' COMMENT '假如产品或者运营需要我们给部分用户推送消息,可以根据其他公共参数把用户分群,然后拿到pushid给他push消息。',
`init_stamp` varchar(64) NOT NULL DEFAULT '' COMMENT '首次安装包时间戳',
`device` varchar(64) NOT NULL DEFAULT '' COMMENT '设备名',
`system_version` varchar(32) NOT NULL DEFAULT '' COMMENT '系统版本',
`app_version` varchar(32) NOT NULL DEFAULT '' COMMENT '我们自己APP的版本号',
`extra` varchar(128) NOT NULL DEFAULT '' COMMENT '额外参数,后续做ABTesting等场景的时候会用到,也可以做一些额外的业务需求字段,视各业务而定',
`is_delete` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '是否删除 0-未删除、1-删除',
`gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '修改时间',
PRIMARY KEY (`id`),
UNIQUE KEY `uk_user_id` (`user_id`)
) ENGINE=InnoDB COMMENT='用户附加信息表,表明用户来源等,第一次产生userId时插入信息到此表'
{
"code" : 0,
"msg" : "Something bad happened",
"data" : {
}
}
不要直接将异常抛给客户端处理,一般需要一个统一的异常处理类,并且以统一格式将异常信息返回前端,统一格式参照目录“Response”
保留错误码,可以自定义错误码,错误码全部参考
错误码 | 描述 |
---|---|
0 | 请求成功 |
性别关系映射
id | 性别 |
---|---|
0 | 未设置 |
1 | 男 |
2 | 女 |
platformId 描述
platformId | 平台 |
---|---|
1 | web |
2 | iOS |
3 | Android |
4 | miniApp |
5 | mp微信公众号 |
appName 描述
appName | 应用名称 |
---|---|
app | XXXapp |
jincai | 竞猜小程序 |
channelCode 渠道标识描述,默认为self(自有渠道),来源于哪次活动,添加活动,需要在这里添加相应标识
channelCode | 渠道标识 |
---|---|
self | 自有渠道 |
userCateGorg 用户类别,默认为客户。以后可能我们还会有销售,或者其他
userCateGorg | 用户类别 |
---|---|
co | 客户 |