English 中文(简体)
在Android的Sqlite语句中,
原标题:How to do this query with a complex where statement in Sqlite in Android?

我有一张有100个或100多个柱子的桌子 可能有"是"或"否"的值

我想根据用户请求( 复选框值表) 进行选择, 以提取所有在“ 是” 上具有值的行。 因此一个示例可以是 :

- 用户选择复选框1 复选框4 和复选框7, 而其他的则未选中 。

查询可以是:

从表格中选择名称, 其中 (col1 = 是 或 Col4 = 是 或 Col7 = 是) 和 (col2 = no 和 Col3 = no 和所有其它列被设置为 no)

如何在人工查询中执行这个目标?我发现这个执行并不十分优雅,有人能建议我另外执行一个目标吗?

最佳回答

这是固定代码 里面有一些测试代码

        int numColumns = 10;
        boolean[] answers = new boolean[numColumns];
        String[] colNames = new String[numColumns];
        for(int i = 0; i < colNames.length; i++) {
            answers[i] = Math.random() > 0.5;
            colNames[i] = String.format("Col%d", i);
        }
        //-----------LOGIC STARTS HERE----------------
        // use a loop
        StringBuilder yesColumns = new StringBuilder();
        StringBuilder noColumns = new StringBuilder();
        for(int i = 0; i < answers.length; i++) {
            if(answers[i]) {
                if(yesColumns.length() > 0)
                    yesColumns.append(" OR ");

                yesColumns.append(colNames[i]).append("= yes ");
            }
            else {
                if(noColumns.length() > 0)
                    noColumns.append(" AND ");
                noColumns.append(colNames[i]).append("= no ");
            }
        }

        String yesCondition = yesColumns.toString();
        String noCondition = noColumns.toString();
        String query = String.format("select name from table where (%s) AND (%s)",
                                     yesCondition,
                                     noCondition);
        System.out.println(query);
        // SQLiteDatabase db;
        // Cursor cursor = db.rawQuery(query, null);
问题回答

暂无回答




相关问题
Android - ListView fling gesture triggers context menu

I m relatively new to Android development. I m developing an app with a ListView. I ve followed the info in #1338475 and have my app recognizing the fling gesture, but after the gesture is complete, ...

AsyncTask and error handling on Android

I m converting my code from using Handler to AsyncTask. The latter is great at what it does - asynchronous updates and handling of results in the main UI thread. What s unclear to me is how to handle ...

Android intent filter for a particular file extension?

I want to be able to download a file with a particular extension from the net, and have it passed to my application to deal with it, but I haven t been able to figure out the intent filter. The ...

Android & Web: What is the equivalent style for the web?

I am quite impressed by the workflow I follow when developing Android applications: Define a layout in an xml file and then write all the code in a code-behind style. Is there an equivalent style for ...

TiledLayer equivalent in Android [duplicate]

To draw landscapes, backgrounds with patterns etc, we used TiledLayer in J2ME. Is there an android counterpart for that. Does android provide an option to set such tiled patterns in the layout XML?

Using Repo with Msysgit

When following the Android Open Source Project instructions on installing repo for use with Git, after running the repo init command, I run into this error: /c/Users/Andrew Rabon/bin/repo: line ...

Android "single top" launch mode and onNewIntent method

I read in the Android documentation that by setting my Activity s launchMode property to singleTop OR by adding the FLAG_ACTIVITY_SINGLE_TOP flag to my Intent, that calling startActivity(intent) would ...

From Web Development to Android Development

I have pretty good skills in PHP , Mysql and Javascript for a junior developer. If I wanted to try my hand as Android Development do you think I might find it tough ? Also what new languages would I ...

热门标签