2
SQLiteQueryBuilder
クラスで生成されたSQLをAndroidで簡単に見る方法があるのだろうか?私はこれをデバッグの目的で使用したいと思います。Android/SQLite用に生成されたSQL文を表示する方法
私は見回して検索しましたが、何も見つかりませんでした。それは簡単ではないか、それとも明らかに分かりやすいかです。
SQLiteQueryBuilder
クラスで生成されたSQLをAndroidで簡単に見る方法があるのだろうか?私はこれをデバッグの目的で使用したいと思います。Android/SQLite用に生成されたSQL文を表示する方法
私は見回して検索しましたが、何も見つかりませんでした。それは簡単ではないか、それとも明らかに分かりやすいかです。
基本的には、SQLiteQueryBuilder#buildQueryString
という静的メソッドを呼び出すことで、正しいメソッドを呼び出すことができます。 Thisは方法がどのように見えるかです:
public static String buildQueryString(
boolean distinct, String tables, String[] columns, String where,
String groupBy, String having, String orderBy, String limit) {
if (TextUtils.isEmpty(groupBy) && !TextUtils.isEmpty(having)) {
throw new IllegalArgumentException(
"HAVING clauses are only permitted when using a groupBy clause");
}
if (!TextUtils.isEmpty(limit) && !sLimitPattern.matcher(limit).matches()) {
throw new IllegalArgumentException("invalid LIMIT clauses:" + limit);
}
StringBuilder query = new StringBuilder(120);
query.append("SELECT ");
if (distinct) {
query.append("DISTINCT ");
}
if (columns != null && columns.length != 0) {
appendColumns(query, columns);
} else {
query.append("* ");
}
query.append("FROM ");
query.append(tables);
appendClause(query, " WHERE ", where);
appendClause(query, " GROUP BY ", groupBy);
appendClause(query, " HAVING ", having);
appendClause(query, " ORDER BY ", orderBy);
appendClause(query, " LIMIT ", limit);
return query.toString();
}
私は回避策だと思いますが、私のpurposes.Iあなたはデバッグ目的のSQLトレースを有効にすることができます別のJPA実装のような構成を期待していたために、それは十分に良いことです。 – Magnus