举个例子,一个实体类Fruit中有apple、pear、banana等几十个int类型变量。
而数据库中是按照如下方式存储的,type表示水果类型,1是apple,2是pear
count, type, date
1, 1, 2019-01-01
6, 2, 2019-01-01
-3, 2, 2019-01-02
需要统计出每天的水果数量变动,怎么样根据type选取setter,用if或者switch感觉代码太过臃肿了,有没有更科学的方式
举个例子,一个实体类Fruit中有apple、pear、banana等几十个int类型变量。
而数据库中是按照如下方式存储的,type表示水果类型,1是apple,2是pear
count, type, date
1, 1, 2019-01-01
6, 2, 2019-01-01
-3, 2, 2019-01-02
需要统计出每天的水果数量变动,怎么样根据type选取setter,用if或者switch感觉代码太过臃肿了,有没有更科学的方式
收起
首先需要一个map或者enum由于关联type和具体的水果名称,比如apple,"1":"apple"
然后通过数据库查询数据后,需要一个map用于存储每个type具体的变动,比如"1":"1"
最后通过反射,通过方法名,循环类的所有方法,对比第一个map中的apple拼接方法名setApple获取对应的方法,将第二个map中的值作为参数,调用该方法。
报告相同问题?