欢迎来到皮皮网官网

【自建拨号工具源码】【分屏源码】【战队源码】query builder源码

时间:2024-12-31 23:06:04 来源:c rand 源码

1.七爪源码:如何使用 Java 访问 BigQuery 数据仓库
2.SQLiteDatabase query 和 rawQuery 的区别
3.ES 使用BoolQueryBuilder删除条件

query builder源码

七爪源码:如何使用 Java 访问 BigQuery 数据仓库

       在本文中,源码我们将深入探讨如何利用Java应用程序通过BigQuery Java SDK访问数据仓库。源码

       首先,源码要访问BigQuery,源码自建拨号工具源码你需要进行一些基本的源码配置。这包括设置BigQuery的源码权限,确保你的源码Java应用具有足够的访问权限以执行查询操作。

       接下来,源码初始化一个BigQuery对象是源码关键步骤。这涉及到引入SDK库,源码设置连接参数,源码分屏源码并创建一个代表查询的源码实例。

       以下是源码一段实际的代码示例,展示了如何执行查询:

       java

       import com.google.cloud.bigquery.BigQuery;

       import com.google.cloud.bigquery.QueryJob;

       import com.google.cloud.bigquery.QueryJobConfiguration;

       // 初始化BigQuery对象

       BigQuery bigQuery = BigQueryOptions.getDefaultInstance().getService();

       // 设置查询配置

       QueryJobConfiguration queryConfig = QueryJobConfiguration.newBuilder("YOUR_QUERY_HERE")

        .build();

       // 执行查询

       QueryJob queryJob = bigQuery.query(queryConfig);

       queryJob.run();

       这段代码可以作为一个模板,源码你可以从用户界面(UI)接收查询参数,源码然后执行并返回查询结果给UI。战队源码

SQLiteDatabase query 和 rawQuery 的区别

       åˆšæ‰åœ¨ CSDN 上看见有人问说在 Android SQLiteDatabase 里,query() 和 rawQuery() 方法的区别。对于这种问题,其实最好的办法就是参看源码,结果确实这样,通过源代码,很快就找到了问题的答案了。

       å’±ä»¬å…ˆçœ‹çœ‹ query() 是怎么实现的。

       public Cursor query(String table, String[] columns, String selection,

        String[] selectionArgs, String groupBy, String having, String orderBy) {

        return query(false, table, columns, selection, selectionArgs, groupBy,

        having, orderBy, null /* limit */);

       }

       public Cursor query(boolean distinct, String table, String[] columns,

        String selection, String[] selectionArgs, String groupBy,

        String having, String orderBy, String limit) {

        return queryWithFactory(null, distinct, table, columns, selection, selectionArgs,

        groupBy, having, orderBy, limit, null);

       }

       è¿™å‡ ä¸ªæ–¹æ³•éƒ½æ²¡æœ‰å…·ä½“实现。

       public Cursor queryWithFactory(CursorFactory cursorFactory,

        boolean distinct, String table, String[] columns,

        String selection, String[] selectionArgs, String groupBy,

        String having, String orderBy, String limit, CancellationSignal cancellationSignal) {

        acquireReference();

        try {

        String sql = SQLiteQueryBuilder.buildQueryString(

        distinct, table, columns, selection, groupBy, having, orderBy, limit);

        return rawQueryWithFactory(cursorFactory, sql, selectionArgs,

        findEditTable(table), cancellationSignal);

        } finally {

        releaseReference();

        }

       }

       æœ€ç»ˆè°ƒç”¨çš„就是这个方法。

       public Cursor rawQueryWithFactory(

        CursorFactory cursorFactory, String sql, String[] selectionArgs,

        String editTable, CancellationSignal cancellationSignal) {

        acquireReference();

        try {

        SQLiteCursorDriver driver = new SQLiteDirectCursorDriver(this, sql, editTable,

        cancellationSignal);

        return driver.query(cursorFactory != null ? cursorFactory : mCursorFactory,

        selectionArgs);

        } finally {

        releaseReference();

        }

       }

       å’±ä»¬å†çœ‹çœ‹ rawQuery() 是怎么实现的。

       public Cursor rawQuery(String sql, String[] selectionArgs) {

        return rawQueryWithFactory(null, sql, selectionArgs, null, null);

       }

       è¿˜æ˜¯è¿™ä¸ªæ–¹æ³•ã€‚

       public Cursor rawQueryWithFactory(

        CursorFactory cursorFactory, String sql, String[] selectionArgs,

        String editTable, CancellationSignal cancellationSignal) {

        acquireReference();

        try {

        SQLiteCursorDriver driver = new SQLiteDirectCursorDriver(this, sql, editTable,

        cancellationSignal);

        return driver.query(cursorFactory != null ? cursorFactory : mCursorFactory,

        selectionArgs);

        } finally {

        releaseReference();

        }

       }

       å¯ä»¥çœ‹åˆ°ï¼Œæœ€åŽï¼Œè°ƒç”¨çš„都是rawQueryWithFactory(CursorFactory,String,String[],String,CancellationSignal) 这个方法,你完全可以代码都不用看懂都可以找到答案。

       å›žåˆ°é—®é¢˜ä¸Šï¼Œè¿™ä¸¤ä¸ªæ–¹æ³•çš„区别在于,最终的 SQL 语句,谁来拼?query() 做的一件事就是帮你拼写 SQL 语句,而调用 rawQuery() 是你自己拼写好语句。我认为的差别仅次而已。

ES 使用BoolQueryBuilder删除条件

       在使用JestClient客户端执行ES查询时,若采用BoolQueryBuilder添加查询条件,通常操作为追加式,这在处理复杂查询逻辑时显得不够灵活。特别是坐骑源码当添加了多余的查询条件后,直接重新实例化BoolQueryBuilder并赋值无法解决,因为这只会传递引用而非创建新对象。那么,如何有效删除多余的查询条件呢?

       深入源码,我们发现添加查询条件的源码学长入口在于调用add方法。关键在于理解,BoolQueryBuilder内部维护了一个mustClauses集合,用于存储必须执行的查询条件。因此,我们的思路是:获取当前的mustClauses集合,然后执行remove操作以删除不必要的条件。

       实现步骤包括查找获取集合的方法,接着获取该集合,最后执行删除操作。例如,`must.remove(2);` 表示删除索引为2的查询条件。请注意,不同的查询可能涉及不同的集合对象,因此在操作前需准确识别。

       总结来说,ES的查询条件添加方式采用的是追加策略,而删除条件则需要通过访问并操作查询条件的集合实现。这种方式不仅允许对查询逻辑进行动态调整,还提高了查询语句的灵活性和可控性。通过深入理解BoolQueryBuilder的内部机制并掌握集合操作,开发者可以更高效地管理ES查询条件,满足复杂的应用需求。

copyright © 2016 powered by 皮皮网   sitemap