首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >如何处理复杂的用户状态?

如何处理复杂的用户状态?
EN

Stack Overflow用户
提问于 2015-12-30 18:16:00
回答 3查看 107关注 0票数 3

我的应用程序涉及用户支付。在公司中,该用户具有以下状态:

  • 符合要求(用户支付了迄今为止所有债务)
  • 逾期/违约(用户至少注册3个月且尚未偿还至少1笔债务)
  • 不活动(用户注册时间少于3个月且未还清任何债务)

如何在应用程序内部的多个地方(和规则)处理这些规则?

我是否需要一个像status_id这样的字段和一个cron来每小时更新一次?

没有status_id字段并在每个需要显示状态的查询中写入SQL规则?

加载User模型并调用具有规则的->status()方法?在这种情况下,我如何显示“总计”,例如:我们有3000个逾期用户,15000个不活跃的用户等等。

这让我头疼了好几个月,我真的需要帮助哈哈。我们目前有一个解决方案,但它太复杂,无法处理。由于在处理支付的应用程序中似乎很常见,所以必须有更简单的方法来做到这一点:P

谢谢!

Notes

  • 应用程序目前有90.000用户。
  • 我们需要实时的信息。
  • 此信息在报表中用于生成字符。
  • 此信息显示在用户配置文件中。
  • 此信息如清单所示。
  • 当用户在这些状态之间发生更改时,会通知用户(例如,当用户输入“逾期”时,“您有债务”)。
  • 此信息不是由应用程序用户管理的。
  • 状态需要被追踪。
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2015-12-30 19:02:44

有趣的问题,但也不是一个单一的答案。

我认为这里的复杂性可能来自于周围的代码,而不是核心业务逻辑和需求。我这么说是因为三种状态类型都是从内部应用程序派生出来的,并不是太糟糕。

一种可能的解决方案,我假设某种级别的MVC或类似的。

考虑到您的模型,user,并扩展了一个类似ORM的口才(我将从Laravel那里雄辩,因为我对它最熟悉,但任何ORM都会奏效):

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
use Illuminate\Database\Eloquent\Model;
use App\DebtCollector;

public class User extends Model
{
    // Assuming model has the following fields
    // id, status, registration_date, and a one to many
    // relationship with debts 

    protected $fillable = [
        'raw_status',
        'registration_date',
    ];

    public function debts()
    {
        return $this->hasMany(Debt::class);
    }

    public function refreshStatus()
    {
        $dc = new DebtCollector();

        // Business logic inside the "DebtCollector" class
        $this->raw_status = $dc->resolveStatus($this->debts, $this->registration_date);

        // Save value to the underlying datebase
        $this->save();            
    }

    // If you fetch a status directly, it will refresh first, 
    // then return the value
    // 
    public function getStatusAttribute()
    {
        $this->refreshStatus();
        return $this->raw_status;
    }
}


// Schedule task somewhere - ran nightly, or whenever
// 
// This way you can refresh the status only on certain groups
// of data - for example, if the business flow means that once
// they become compliant, they can't go back, there is no need
// to refresh their status anymore 
//
User::where('raw_status', '<>', 'compliant')->refreshStatus();

// Alternatively, the schedule could chunk results and do an update
// only to those not updated in the last 24 hours
//
$date = new DateTime;
$date->modify('-24 hours');
$formatted_date = $date->format('Y-m-d H:i:s');
User::where('last_updated', '>', $formatted_data)->refreshStatus();
票数 1
EN

Stack Overflow用户

发布于 2015-12-30 18:29:07

如果您在多个地方使用这个字段,那么您应该将状态存储在一个地方并酌情更新它(我也会保存状态的历史记录,但这是另一回事)。

如果状态由于某些用户操作(例如正在处理的支付)而发生变化,则可以在操作上使用触发器。但是,您的状态更改似乎是基于事件发生后的时间变化。在这种情况下,您应该运行一个定期调度的作业(作为cron作业或数据库事件)。

我有点搞不懂你为什么每小时都这么做。看来每天一次是最合适的。如果“债务”是在任意时间支付的,则支付过程应更新状态。对于降级状态,一天一次的工作就足够了。

票数 3
EN

Stack Overflow用户

发布于 2016-01-02 08:10:06

我想说,这个问题有多种解决办法。

我建议不要有任何明确的地位。根据我所看到的,您可以根据其他一些数据“确定”当前的状态。例如,“到目前为止,用户已经还清了所有债务”。你只需通过分析给定时期内的所有变化就可以知道这一点。您可以聚合数据以确定您需要知道的所有信息。所以你根本不需要保存状态。它只是从客户帐户在特定时期发生的所有更改中派生出来的。

总数也是一样。您可以在数据库级别上很容易地做到这一点,甚至可以使用一些基于文档的DB或ElasticSearch。

当然,这假定您跟踪更改的历史。如果你这么做-问题解决了。如果没有-您必须将状态保存到数据库中,并且无法获得历史数据。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34540135

复制
相关文章
MSIL 静态类在 IL 定义上和非静态类的差别
本文来聊聊 MSIL 的基础知识,给一个 C# 的类标记了 static 之后和标记 static 之前,生成这个类的 IL 代码有什么不同
林德熙
2021/12/23
6330
【C++】运算符重载 ② ( 类内部定义云算符重载 - 成员函数 | 类外部定义运算符重载 - 全局函数 | 可重载的运算符 )
当使用 + 将 个对象相加时 , C++ 编译器会查找是否有定义运算符重载函数 ;
韩曙亮
2023/10/15
2710
Python中类-带括号与不带括号的区别
  有时候看到群里一些人问一些基础的知识,虽然很基础,网上随便一查即可知道,但是往往很多人就是连这些基础的知识都很模糊,甚至不清楚,这里再来复习一下python中类的一个知识点(仅此)。
全栈测试开发日记
2023/02/02
2.6K0
【C++】运算符重载 ⑬ ( 括号 () 运算符重载 | 完整代码示例 )
上述写法 , 与函数调用很像 , 只是 s 不是函数名 , 而是一个 对象的 名称 ;
韩曙亮
2023/10/15
4150
【C++】运算符重载 ⑬ ( 括号 () 运算符重载 | 完整代码示例 )
为什么 wait/notify/notifyAll 在 Object 类定义而不是 Thread 类?
作者:Yujiaao 来源:segmentfault.com/a/1190000019962661
Java技术栈
2020/06/16
1.5K0
面向对象定义一个hero类
定义一个hero类,属性有power,name,分别代表体力值和英雄的名字,体力值默认为100;方法有:1.行走的方法如果体力值为0,则输出不能行走,此英雌已死亡的信息;2.吃的方法:参数是补充的血量,将n的值加到属性power中,power的值最大为100;3.每收到一次伤害,体力值-10,体力值最小不能小于0.
算法与编程之美
2023/01/03
4730
面向对象定义一个hero类
编译原理在类Unix/Lunix上使用flex
flex,前身是lex,lex是1975年由Mike Lesk和当时尚在AT&T实习的Eric Schmidt共同完成的基于UNIX环境的词法分析器的生成工具。这个lex很有名气,但是无奈效率太低加上有bug,让人用的很不爽。后来伯克利实验室的Vern Paxson用C重新写了lex,并命名为flex(Fast Lexical Analyzer Generator)。
里克贝斯
2021/05/21
1K0
编译原理在类Unix/Lunix上使用flex
iOS 的系统类信息在栈上?
前言 今天有位群友抛出了一个很有意思的问题:为什么系统类的 class 地址比栈区变量更高? image-20210519235852843 iOS 进程内存布局 通常情况下,我们对进程内存的布局
酷酷的哀殿
2021/06/22
8150
iOS 的系统类信息在栈上?
shell中各种括号的作用(上)
1.命令组。括号中的命令将会新开一个子shell顺序执行,所以括号中的变量不能够被脚本余下的部分使用。括号中多个命令之间用分号隔开,最后一个命令可以没有分号,各命令和括号之间不必有空格。
陈不成i
2021/06/22
9090
latex在大括号里换行_大括号的解决问题
存在问题:在编译LaTex的时候,会出现存在大括号\left( \right),但是一旦公式过长需要换行时,例如
全栈程序员站长
2022/11/10
3.5K0
latex在大括号里换行_大括号的解决问题
Java|如何用Java定义一个类
类是一种引用数据类型。类为对象的模板,简单的说就是分类。类是一个模板,它描述一类对象的行为和状态。类的定义包括“成员变量”的定义和“方法”的定义,其中“成员变量”用于描述一类对象共同的数据结构。在Java语言中,类的成员变量的定义可以使用如下语法:
算法与编程之美
2019/09/25
1.1K0
Java|如何用Java定义一个类
重温Delphi之:如何定义一个类
先谈谈工具问题: 虽然d7很经典,但毕竟是02年出的开发工具了,对于习惯了vs2008被微软宠坏的.net程序员来讲,重返d7已经有点找不着感觉了(起码连最基本的代码折叠功能都没有),还好delphi
菩提树下的杨过
2018/01/23
1.3K0
重温Delphi之:如何定义一个类
定义一个创造汽车的工厂类
# 定义奔驰车类 class BenchiCar(object): # 定义车的方法 def move(self): print('---奔驰车在移动---') def stop(self): print('---奔驰车停车了---') # 定义宝马车类 class BMWCar(object): # 定义车的方法 def move(self): print('---宝马车在移动---') def stop(
汪凡
2018/05/29
4740
在ListView上使用自定义的Adapter
需要实现的东西是: 一个DataListViewAdapter,当进行如下调用时,就能在列表上显示出数据:
LeoXu
2018/08/15
9680
怎样在Visio中插入大括号?
在标注类形状中就可以找到大括号了。可以看到,系统默认配置了两种大括号类型:双侧大括号和单侧大括号,大家可以根据实际需要自己选择。
狼啸风云
2021/05/17
12.9K0
怎样在Visio中插入大括号?
在RenderTransform上叠加一个ScaleAt
代码很简单,就是在缩放时,获取鼠标对元素的相对坐标,调用ScaleAt,然后添加到它现有的RenderTransform中
黄腾霄
2020/06/10
5470
技术猿 | CoolDrive R6机器人专用伺服在工业机器人上的应用
---- 1、概述 近两年,面对人工劳动力成本的不断提升,工业机器人日益被企业倚重,中国工业机器人市场呈现爆发式增长。据国际机器人协会(IFR)数据统计,2014年全球工业机器人销量为22.5万台左右,其中亚洲的销量几乎占到2/3.而中国市场的工业机器人销量更是增长54%,达到5.6万台左右。但值得注意的是,本土机器人供应商的销量仅为1.6万台。究其原因,很重要的一个因素就是机器人核心零部件的国产化进程较慢,国内机器人整机厂商只能进口国外产品,导致整机成本较高,在同国外厂商的竞争中处于劣势。 Cool
机器人网
2018/04/19
9620
技术猿 | CoolDrive R6机器人专用伺服在工业机器人上的应用
在LeetCode中使用我们自定义的类
在上一节中我们使用的是java提供了的类,这一小节中我们就来学习一下如何在LeetCode中使用我们自定义的类。
wfaceboss
2019/04/08
1.2K0
在LeetCode中使用我们自定义的类
见到了“公司”定义一个Company类,那么见到了“字段”是不是也可定义一个Column类?
  既然见到了公司,我们可以定义一个Class Company ,那么我们见到了字段,是不是也可以定义一个Class ColumnInfo呢? 公司的描述信息类: 代码 public class Company     {         public int CompanyId { get; set; }         public string CompanyName { get; set; }         public string Province { get; set; }         
用户1174620
2018/02/26
8260
见到了“公司”定义一个Company类,那么见到了“字段”是不是也可定义一个Column类?
点击加载更多

相似问题

在R6类定义内部:“找不到对象”(或者:如何在R6类中定义“本地”对象)

113

如何告诉R6类如何处理方括号?

17

R,R6运算符重载

10

parLapply在R6类中

13

访问实例化另一个R6类的R6类的元素

217
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文