Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sqlite/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Winforms 如何查询“字符串以字符串结尾”SQLite_Winforms_Sqlite - Fatal编程技术网

Winforms 如何查询“字符串以字符串结尾”SQLite

Winforms 如何查询“字符串以字符串结尾”SQLite,winforms,sqlite,Winforms,Sqlite,我有一个数据库,它有一个filename列。我希望我的用户能够选择一个扩展名,并提取所有具有该扩展名的文件名 关于如何做到这一点,已经有很多线程,我也遵循了一些不同的示例,但我不知道为什么我的查询不起作用 private void button1_Click(object sender, EventArgs e) { string query = "SELECT * FROM " + tableName + " WHERE "; //string

我有一个数据库,它有一个filename列。我希望我的用户能够选择一个扩展名,并提取所有具有该扩展名的文件名

关于如何做到这一点,已经有很多线程,我也遵循了一些不同的示例,但我不知道为什么我的查询不起作用

    private void button1_Click(object sender, EventArgs e)
    {
        string query = "SELECT * FROM " + tableName + " WHERE ";

        //string ext = "'%*" + comboBox1.Text + "%'";

        query += "filename LIKE '*.rtf';";

        queryDB(query);

    }
comboBox1是进行选择的地方,但是我停止了尝试,直到我能够找出像.rtf这样的硬编码文件名不起作用的原因

如何检查以.rtf结尾的文件?我做错了什么

谢谢


编辑:我知道我的queryDB函数可以工作,我可以从tablename运行SELECT*,它工作得很好。还值得注意的是,我在屏幕上显示了我的数据库。默认情况下,它们全部显示,但您可以修剪结果。当我尝试运行此查询时,所有条目都显示在datagrid中。

对于LIKE,*字符不是有效的通配符。改为使用%s


i、 e.与“%.rtf”类似,构造此特定查询的正确方法是使用以下语法:

LIKE '%.rtf'
您不应该在字符串中使用*进行匹配,因为这是一个操作系统通配符,而不是SQL通配符,这意味着除非您有一个名为*.rtf ie的实际文件。该名称确实包含该asterix,否则它将不匹配

但是,这是一个糟糕的解决方案,因为以字符串结尾的匹配不能使用索引。它最终总是会进行一次完整的表扫描。这很糟糕

在数据库中执行此操作的正确方法是执行以下操作:

在表中添加一个额外的列,称之为extension或类似的名称 将索引添加到此列 当插入或更新行时,用编程语言提取文件扩展名,通常它有例程来完成这项工作,这样您就不必去寻找点并将其放入这个新列中。 查询此列,而不是对文件名使用LIKE,然后您可以简单地使用以下条件:

WHERE extension = '.dbf'

从长远来看,这通常会快得多。

我建议使用stringbuider类型,而不是string类型。我不确定这是否是后续问题的适当位置,但我如何才能用准备好的语句做到这一点??