2013年10月6日日曜日

こつこつと独自プロバイダー作成でqueryって何やってるの?

こつこつつくってるとoffsetやらdistinctやらgroupbyやらlimitなどなど使いたくなってくる。
やりたい操作によって、select構文を変化させたい。

んで、どうやったら制御できるんだろうと思ったわけです。
queryは内部でどうやって組み立てられてるのかソースを見ました。
sourceはAndroid14のものです。

色々進んでSQLiteDatabaseの1441行目にあるqueryWithFactoryというメソッドで組み立て開始。
SQLiteQueryBuilder.buildQueryStringでSQLの組み立てを実行。
SQLiteQueryBuilderの198行目にbuildQueryStringがあります。

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();
    }

0 件のコメント:

コメントを投稿