todo-mvvm-databinding源码分析

MVVM框架 todo-mvvm-databinding 项目例子。

MVP框架 todo-mvp 项目例子。

目的

分析和学习官方mvvm框架的设计模式和数据绑定在其中的具体用法,制作一套符合当前公司业务场景的mvvm框架。其中也分析一下数据源在项目中的设计以及框架中单元测试的实施。

设计模式

MVVM框架中的`ViewModel`相比MVP框架中的`Presenter`起着类似的作用。两种框架结构的不同之处在于View分别与`ViewModel`或`Presenter`进行通信:

  • 当MVVM框架中数据发生变化时会影响`ViewModel`的改变,`View`会自动更新库或框架。你不能直接通过`ViewModel`来修改`View`。
  • 在这个项目中,你可以使用布局文件将`ViewModel`中的变量绑定到特定的UI元素上(如`TextView`或`ImageView`)。数据绑定可以确保View和ViewModel保持双向同步,如下图所示。

继续阅读todo-mvvm-databinding源码分析

SQL中MAX函数与Group By获取同一字段重复的数据最大的一条

SQLMAX函数与Group By一起使用,获取同一字段重复的数据只取记录最大的一条,如下:

mysql> select * from test;
+----+-------+------+-------+
| id | name  | age  |  clz  |
+----+-------+------+-------+
|  1 | qiu   |   22 |     1 | 
|  2 | liu   |   42 |     1 | 
|  4 | zheng |   20 |     2 | 
|  3 | qian  |   20 |     2 | 
|  0 | wang  |   11 |     3 | 
|  6 | li    |   33 |     3 | 
+----+-------+------+-------+
6 rows in set (0.00 sec)

如果想找到每个clz里面的最大的age,则需要使用Group By和Max

如下的SQL语句,则输出结果有错误:

mysql> select id,name,max(age),clz from test group by clz;
+----+-------+----------+-------+
| id | name  | max(age) |  clz  |
+----+-------+----------+-------+
|  1 | qiu   |       42 |     1 | 
|  4 | zheng |       20 |     2 | 
|  0 | wang  |       33 |     3 | 
+----+-------+----------+-------+
3 rows in set (0.00 sec)

虽然找到的age是最大的age,但是与之匹配的用户信息却不是真实的信息,而是Group By分组后的第一条记录的基本信息。

如果我使用以下的语句进行查找,则可以返回真实的结果。

mysql> select * from (
    -> select * from test order by age desc) as b
    -> group by clz;
+----+-------+------+-------+
| id | name  | age  |  clz  |
+----+-------+------+-------+
|  2 | liu   |   42 |     1 | 
|  4 | zheng |   20 |     2 | 
|  6 | li    |   33 |     3 | 
+----+-------+------+-------+
3 rows in set (0.00 sec)

参考链接