gpt4 book ai didi

android - 我应该如何在 Sqlite 中执行此查询?

转载 作者:行者123 更新时间:2023-11-30 04:17:35 26 4
gpt4 key购买 nike

我有一个包含以下列的数据库:id、pdate、pvalue1、pvalue2。首先,我使用游标进行查询:

Cursor c = ourDatabase.query(DATABASE_TABLE, new String[] { "_id","pdate","pvalue1","pvalue2"},
"pdate >= ? AND pdate <= ?", new String[] { datefrom, dateto }, null, null, null);

这给了我一些行,例如,如果 pdate = 20120318,则 pvalue1 = 58,pvalue2=29。这些是字符串,所以我可以给 pvalue2 一个值“XX”。我想对给定的 datefrom 和 dateto 之间的 pvalue1 求和,并按 pdate 对它们进行分组,其中 pvalue2 = XX。我的问题是我无法将此条件放入查询中(它的工作原理,如“pvalue2 = XX”..),因为我也需要其他数据。

if (c.moveToFirst())
{
do{
if (c.getString(3).equals("XX")){
Log.i("XX", c.getString(1) + " " + c.getString(2)) + " " + c.getString(3));

}
else {
Log.i("NotXX", c.getString(1) + " " + c.getString(2)) + " " + c.getString(3));

}

while (c.moveToNext());
}
}

到目前为止一切正常,所以我可以用 where pvalue2 = XX and NotXX 记录数据并得到类似这样的东西:(pdate,pvalue1,pvalue2) 20120317,48,29;-----;20120317,21,54;------20120317,11,XX;-----20120318,79,71; ------20120318,21,XX;

我想做什么?

首先:按 pdate 对总和 (pvalue1) 进行分组,并指出 pvalue2 是 XX 还是不是 XX,所以像这样:20120317,NotXX,69(因为 48+21=69)-------- 20120317,XX,11 ------ 20120318,NotXX,79 ------ 20120318,XX ,21

在此之后,我想每天从 NotXX 总和中减去 XX 总和。我想得到: 20120317,58(自 69-11)------ 20120318,58(自 79-21)

我该怎么做?非常感谢您!

最佳答案

My problem is that I cannot put this condition into the query

你可能错了。您可以添加类似的内容(语法可能包含错误)

“选择总和(从 DATABASE_TABLE 中选择 pdate,其中 pdata > x 和 pdate < y)作为总和”

到投影参数,您将得到该结果作为名为 sum 的列。唯一的问题是投影中不支持?(至少我没试过,但我猜是不行的)

如果这不是您想要的,那么很可能有不同的方法。 SQLite 非常强大。

编辑:

这就是你想要的吗?它不是在 SQL 中完成的,但它会打印你想要的每一天的总和。

Cursor c = ourDatabase.query(DATABASE_TABLE, new String[] { "_id","pdate","pvalue1","pvalue2"},
"pdate >= ? AND pdate <= ?", new String[] { datefrom, dateto }, null, null, "pdate");
boolean first = true;
if (c != null) {
String currentDate = null;
int sum = 0;
while (c.moveToNext()) {
String date = c.getString(1);
int value1 = c.getInt(2);
String value2 = c.getString(3);
if (!date.equals(currentDate)) {
if (!first) {
Log.d("TAG", "The result for " + currentDate + " is: " + sum);
} else {
Log.d("TAG", "Date has changed, but we don't have data yet.");
}
first = false;
currentDate = date;
sum = 0;
}
if ("XX".equals(value2)) {
Log.d("TAG", "new line: " + date + ", " + value1 + ", " + value2 + " -");
sum -= value1;
} else {
Log.d("TAG", "new line: " + date + ", " + value1 + ", " + value2 + " +");
sum += value1;
}
}
if (!first) {
Log.d("TAG", "The last result: " + currentDate + " is: " + sum);
}
c.close();
}

Edit2:当您希望由数据库完成时,这可能会起作用。

Cursor c = ourDatabase.rawQuery(
"SELECT pdate, sum(sum2) AS sum1 FROM " +
"(" +
" SELECT pdate, pvalue1, pvalue2, -sum(pvalue1) AS sum2 " +
" FROM " + DATABASE_TABLE +
" WHERE pvalue2='XX' GROUP BY pdate" +
" UNION " +
" SELECT pdate, pvalue1, pvalue2, sum(pvalue1) AS sum2 " +
" FROM " + DATABASE_TABLE +
" WHERE pvalue2!='XX' GROUP BY pdate" +
") " +
" WHERE pdate>=? AND pdate<=? " +
" GROUP BY pdate",
new String[] { datefrom, dateto });
if (c != null) {
while (c.moveToNext()) {
String date = c.getString(0);
int value1 = c.getInt(1);
Log.d("TAG", "The result for " + date + " is: " + value1);
}
c.close();
}

关于android - 我应该如何在 Sqlite 中执行此查询?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9751846/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com