《仿盒马》app开发技术分享-- 插入积分信息(65)

简介: 上一节我们实现了积分页面的大概框架,那么现在我们开始进行数据的填充和查询,积分相关的内容现在之后当回收订单结算之后才会进行积分数据的添加,那我们想查询出对应的积分数据,还需要新增一张积分信息表

技术栈

Appgallery connect

开发准备

上一节我们实现了积分页面的大概框架,那么现在我们开始进行数据的填充和查询,积分相关的内容现在之后当回收订单结算之后才会进行积分数据的添加,那我们想查询出对应的积分数据,还需要新增一张积分信息表

功能分析

现在积分相关的有订单结算以及后续的积分兑换功能,我们先实现订单结算的积分新增以及用户信息表的积分总额计算。
首先在回收单待完成页面点击确认按钮时进行数据的添加,我们这里要用type去区分积分数据的状态,状态分为收入和支出。然后我们修改userinfo的积分信息,在积分列表全部选项里查询出积分的数据在list列表中进行展示

代码实现

首先我们创建对应的表、实体、db类

{
   
  "objectTypeName": "points_info",
  "fields": [
    {
   "fieldName": "id", "fieldType": "Integer", "notNull": true, "belongPrimaryKey": true},
    {
   "fieldName": "user_id", "fieldType": "Integer", "notNull": true, "defaultValue": 0},
    {
   "fieldName": "points", "fieldType": "String"},
    {
   "fieldName": "create_time", "fieldType": "String"},
    {
   "fieldName": "points_type", "fieldType": "String"},
    {
   "fieldName": "address", "fieldType": "String"},
    {
   "fieldName": "year", "fieldType": "String"},
    {
   "fieldName": "month", "fieldType": "String"},
    {
   "fieldName": "day", "fieldType": "String"},
    {
   "fieldName": "time", "fieldType": "String"}
  ],
  "indexes": [
    {
   "indexName": "field1Index", "indexList": [{
   "fieldName":"id","sortType":"ASC"}]}
  ],
  "permissions": [
    {
   "role": "World", "rights": ["Read", "Upsert", "Delete"]},
    {
   "role": "Authenticated", "rights": ["Read", "Upsert", "Delete"]},
    {
   "role": "Creator", "rights": ["Read", "Upsert", "Delete"]},
    {
   "role": "Administrator", "rights": ["Read", "Upsert", "Delete"]}
  ]
}



class PointsInfo {
   
    id: number;
    user_id: number = 0;
    points: string;
    create_time: string;
    points_type: string;
    address: string;
    year: string;
    month: string;
    day: string;
    time: string;

    constructor() {
   
    }



    setId(id: number): void {
   
        this.id = id;
    }

    getId(): number  {
   
        return this.id;
    }

    setUser_id(user_id: number): void {
   
        this.user_id = user_id;
    }

    getUser_id(): number  {
   
        return this.user_id;
    }

    setPoints(points: string): void {
   
        this.points = points;
    }

    getPoints(): string  {
   
        return this.points;
    }

    setCreate_time(create_time: string): void {
   
        this.create_time = create_time;
    }

    getCreate_time(): string  {
   
        return this.create_time;
    }

    setPoints_type(points_type: string): void {
   
        this.points_type = points_type;
    }

    getPoints_type(): string  {
   
        return this.points_type;
    }

    setAddress(address: string): void {
   
        this.address = address;
    }

    getAddress(): string  {
   
        return this.address;
    }

    setYear(year: string): void {
   
        this.year = year;
    }

    getYear(): string  {
   
        return this.year;
    }

    setMonth(month: string): void {
   
        this.month = month;
    }

    getMonth(): string  {
   
        return this.month;
    }

    setDay(day: string): void {
   
        this.day = day;
    }

    getDay(): string  {
   
        return this.day;
    }

    setTime(time: string): void {
   
        this.time = time;
    }

    getTime(): string  {
   
        return this.time;
    }

}

export {
    PointsInfo };


import {
    cloudDatabase } from '@kit.CloudFoundationKit';

class points_info extends cloudDatabase.DatabaseObject {
   
  public id: number;
  public user_id = 0;
  public points: string;
  public create_time: string;
  public points_type: string;
  public address: string;
  public year: string;
  public month: string;
  public day: string;
  public time: string;

  public naturalbase_ClassName(): string {
   
    return 'points_info';
  }
}

export {
    points_info };

在订单确认完成按钮处我们实现云数据库数据新增

 let points=new points_info()
                        points.id=Math.floor(Math.random() * 1000000)
                        points.user_id=this.user!.user_id
                        points.points=String(item.money)
                        points.points_type='0'
                        points.address='客户端下单奖励'
                        points.year=this.year
                        points.month=this.month
                        points.day=this.day
                        points.time=this.time
                        points.create_time=this.year+"-"+this.month+"-"+this.day+" "+this.time
                        let points_nums =  await databaseZone.upsert(money);

用户账号内的总积分数修改

 let userData=new user_info()
                        userData.id=this.userInfo!.id
                        userData.user_id=this.userInfo!.user_id
                        userData.sex=this.userInfo!.sex
                        userData.bind_phone=this.userInfo!.bind_phone
                        userData.create_time=this.userInfo!.create_time
                        userData.nickname=this.userInfo!.nickname
                        userData.head_img=this.userInfo!.head_img
                        if (this.userInfo?.money!=null) {
   
                          userData.money=this.userInfo!.money+item.money
                        }else {
   
                          userData.money=item.money
                        }
                        if (this.userInfo?.points!=null) {
   
                          userData.points=this.userInfo!.points+item.integral
                        }else {
   
                          userData.points=item.integral
                        }
                       let s= await databaseZone.upsert(userData);

到这里我们就实现了用户积分信息的插入

相关文章
uni-app 9.2聊天信息设置页(二)
uni-app 9.2聊天信息设置页(二)
141 1
uni-app 9.2聊天信息设置页(二)
uni-app 9.3聊天信息设置页(三)
uni-app 9.3聊天信息设置页(三)
107 0
uni-app 9.3聊天信息设置页(三)
|
5月前
|
人工智能 文字识别 小程序
旅游社用什么工具收报名 + 资料?不开发 App 也能自动收集信息
本文探讨了旅游行业中报名信息收集的常见痛点及解决方案,重点介绍了二维码表单工具在提升信息收集效率、简化操作流程方面的优势。通过对比多种工具,分析其适用场景与实际应用逻辑,为一线旅游从业者提供高效、低成本的执行参考。
|
7月前
|
移动开发 缓存 开发框架
轻型社交同城交友圈子系统/兴趣爱好搭子聊天APP/同城本地行业信息圈子论坛
基于 UniApp 和 ThinkPHP6 构建,实现多端同步的轻量级社交系统。前端采用 UniApp 跨端开发框架,支持微信小程序、H5、APP 等多平台,结合 Vue.js 语法与图鸟 UI 组件库,快速构建美观界面。后端使用 TP6 提供 RESTful API,搭配 MySQL 数据库与 Redis 缓存优化性能。核心功能包括兴趣圈子管理、即时通讯、付费圈子、广告与会员体系等。同时,通过七牛云内容检测与实名认证保障社区安全,采用 Nginx+Redis 高并发架构确保稳定性。免费源码,适合开发者快速搭建同城社交平台,并可通过 AI 推荐与 AR 功能进一步提升用户体验。
697 6
|
8月前
|
存储 监控 API
【Azure App Service】分享使用Python Code获取App Service的服务器日志记录管理配置信息
本文介绍了如何通过Python代码获取App Service中“Web服务器日志记录”的配置状态。借助`azure-mgmt-web` SDK,可通过初始化`WebSiteManagementClient`对象、调用`get_configuration`方法来查看`http_logging_enabled`的值,从而判断日志记录是否启用及存储方式(关闭、存储或文件系统)。示例代码详细展示了实现步骤,并附有执行结果与官方文档参考链接,帮助开发者快速定位和解决问题。
263 22
|
JSON API 开发工具
【Azure 应用服务】调用Azure REST API来获取 App Service的访问限制信息(Access Restrictions)以及修改
【Azure 应用服务】调用Azure REST API来获取 App Service的访问限制信息(Access Restrictions)以及修改
143 1
|
Java 应用服务中间件 开发工具
[App Service for Windows]通过 KUDU 查看 Tomcat 配置信息
[App Service for Windows]通过 KUDU 查看 Tomcat 配置信息
186 2
|
Go 开发者
【应用服务 App Service】App Service发生错误请求时,如何查看IIS Freb日志,从中得知错误所发生的模块,请求中所携带的Header信息
【应用服务 App Service】App Service发生错误请求时,如何查看IIS Freb日志,从中得知错误所发生的模块,请求中所携带的Header信息
199 2
|
JavaScript Java 测试技术
基于SpringBoot+Vue+uniapp的电影信息推荐APP的详细设计和实现(源码+lw+部署文档+讲解等)
基于SpringBoot+Vue+uniapp的电影信息推荐APP的详细设计和实现(源码+lw+部署文档+讲解等)
124 6
|
JavaScript Java 测试技术
基于SpringBoot+Vue+uniapp的电影信息推荐APP的详细设计和实现
基于SpringBoot+Vue+uniapp的电影信息推荐APP的详细设计和实现
115 16

热门文章

最新文章