介绍
校友录小程序采用腾讯云开发技术,云开发提供了一个 JSON 数据库,顾名思义,数据库中的每条记录都是一个 JSON 格式的对象。一个数据库可以有多个集合(相当于关系型数据中的表),集合可看做一个 JSON 数组,数组中的每个对象就是一条记录,记录的格式是 JSON 对象。
其主要特性:
- 安全性:对于数据库而言,数据安全是第一位的;
- 易用性:与小程序的特征类似,“开箱即用,用完即走”,简单上手,免运维;
- 低成本:按量收费,精细化成本控制;
- 高性能:Nosql,支持高并发读写;
- 灵活性:无固定的数据库表模式(
no-schema
),支持弹性伸缩;
在本案例中,校友录小程序总共用到了16个集合,包含校友用户,校友相册,校友活动,校友互助,校友聚会,校友后台管理员,校友资讯,校友日志等
在云开发控制台有个高级操作,这里可以执行开发者输入的脚本,比如清空集合,根据某个条件删除集合内部分数据,查询集合等等
常用脚本
1、清空操作
清空校友用户集合
db.collection('t_user')
.where({
_id: _.exists(true)
})
.remove()
2、删除操作
删除1990年入学的校友用户
db.collection('t_user')
.where({
USER_ENROLL: 1990
})
.remove()
3、查询操作
查询名字为“覃建平”的校友用户的所有数据
db.collection('t_user')
.where({
USER_NAME: '覃建平'
})
.get()
多条件,指定字段查询
db.collection('t_user')
.where({
USER_INVITE_ID: ''
})
.field({
USER_INVITE_ID:true
})
.skip(0)
.limit(10)
.get()
4、去掉某个字段
删除校友用户集合的USER_VIP_MONEY,USER_VIP_RETURN_MONEY,UER_VIP_LEAVE_MONEY字段
db.collection('t_user').where({_id:_.neq(1)})
.update({
data: {
USER_VIP_MONEY:_.remove(),
USER_VIP_RETURN_MONEY:_.remove(),
USER_VIP_LEAVE_MONEY:_.remove(),
}
})
5、更新某个字段或者新增某个字段
更新校友用户集合的USER_VIP_MONEY字段,如果原来没有这个字段,则自动新增该字段且赋值
db.collection('t_user').where({_id:_.neq(1)})
.update({
data: {
USER_VIP_MONEY: 1111,
}
})
6、复杂的多条件查询
对于校友用户集合按毕业年份,行业,学校,班级,专业,用户身份,最近来访,访问次数等多维度查询,排序
/** 取得用户分页列表 */
async getUserList(userId, {
search, // 搜索条件
sortType, // 搜索菜单
sortVal, // 搜索菜单
orderBy, // 排序
whereEx, //附加查询条件
page,
size,
oldTotal = 0
}) {
orderBy = orderBy || {
USER_LOGIN_TIME: 'desc'
};
let fields = FILEDS_USER_BASE;
let where = {};
where.and = {
USER_OPEN_SET: ['>', 0],
USER_STATUS: [
['>=', UserModel.STATUS.COMM],
['<=', UserModel.STATUS.VIP]
],
_pid: this.getProjectId() //复杂的查询在此处标注PID
};
if (util.isDefined(search) && search) {
where.or = [{
USER_NAME: ['like', search]
},
{
USER_ITEM: ['like', search]
},
{
USER_COMPANY: ['like', search]
},
{
USER_TRADE: ['like', search]
},
{
USER_TRADE_EX: ['like', search]
},
];
} else if (sortType && util.isDefined(sortVal)) {
let user = {};
// 搜索菜单
switch (sortType) {
case 'companyDef':
// 单位性质
where.and.USER_COMPANY_DEF = sortVal;
break;
case 'trade':
// 行业
where.and.USER_TRADE = ['like', sortVal]
break;
case 'workStatus': //工作状态
where.and.USER_WORK_STATUS = sortVal;
break;
case 'same_enroll': //同级
user = await UserModel.getOne({
USER_MINI_OPENID: userId
});
if (!user) break;
where.and.USER_ENROLL = user.USER_ENROLL;
break;
case 'same_item': //同班
user = await UserModel.getOne({
USER_MINI_OPENID: userId
});
if (!user) break;
where.and.USER_ITEM = user.USER_ITEM;
break;
case 'same_trade': //同行
user = await UserModel.getOne({
USER_MINI_OPENID: userId
});
if (!user) break;
let trade = user.USER_TRADE;
if (trade.includes('-')) trade = trade.split('-')[0];
where.and.USER_TRADE = ['like', trade];
break;
case 'same_city': //同城
user = await UserModel.getOne({
USER_MINI_OPENID: userId
});
if (!user) break;
where.and.USER_CITY = user.USER_CITY;
break;
case 'enroll': //按入学年份分类
switch (sortVal) {
case 1940:
where.and.USER_ENROLL = ['<', 1950];
break;
case 1950:
where.and.USER_ENROLL = [
['>=', 1950],
['<=', 1959]
];
break;
case 1960:
where.and.USER_ENROLL = [
['>=', 1960],
['<=', 1969]
];
break;
case 1970:
where.and.USER_ENROLL = [
['>=', 1970],
['<=', 1979]
];
break;
case 1980:
where.and.USER_ENROLL = [
['>=', 1980],
['<=', 1989]
];
break;
case 1990:
where.and.USER_ENROLL = [
['>=', 1990],
['<=', 1999]
];
break;
case 2000:
where.and.USER_ENROLL = [
['>=', 2000],
['<=', 2009]
];
break;
case 2010:
where.and.USER_ENROLL = ['>=', 2010];
break;
}
break;
case 'sort':
// 排序
if (sortVal == 'new') { //最新
orderBy = {
'USER_LOGIN_TIME': 'desc'
};
}
if (sortVal == 'last') { //最近
orderBy = {
'USER_LOGIN_TIME': 'desc',
'USER_ADD_TIME': 'desc'
};
}
if (sortVal == 'enroll') { //入学
orderBy = {
'USER_ENROLL': 'asc',
'USER_LOGIN_TIME': 'desc'
};
}
if (sortVal == 'info') {
orderBy = {
'USER_INFO_CNT': 'desc',
'USER_LOGIN_TIME': 'desc'
};
}
if (sortVal == 'album') {
orderBy = {
'USER_ALBUM_CNT': 'desc',
'USER_LOGIN_TIME': 'desc'
};
}
if (sortVal == 'meet') {
orderBy = {
'USER_MEET_CNT': 'desc',
'USER_LOGIN_TIME': 'desc'
};
}
if (sortVal == 'login_cnt') {
orderBy = {
'USER_LOGIN_CNT': 'desc',
'USER_LOGIN_TIME': 'desc'
};
}
break;
}
}
let result = await UserModel.getList(where, fields, orderBy, page, size, true, oldTotal, false);
return result;
}
查询结果
交流vx: cclinux0730