sqlite - SQLite:将文件扩展名与路径隔离

标签 sqlite

我需要从SQLite中的路径中隔离文件扩展名。我在这里(SQLite: How to select part of string?)看过这篇文章,那里的帖子占99%。

但是,解决方案:

 select distinct replace(column_name, rtrim(column_name, replace(column_name, '.', '' ) ), '') from table_name;

如果文件没有扩展名(即文件名中没有'。')失败,则该文件应返回一个空字符串。有什么办法可以解决这个问题吗?

请注意,在这种情况下,文件名是最后'\'之后的位-不应像现在一样在完整路径中搜索'.'s

我认为应该可以使用进一步嵌套的rtrimsreplaces来做到这一点。

最佳答案

谢谢。是的,您可以这样做:

1)在SQLiteStudio的QtScript中创建一个称为“扩展”的标量函数

2)代码如下:

if ( arguments[0].substring(arguments[0].lastIndexOf('\u005C')).lastIndexOf('.') == -1 )
{
  return ("");
}
else
{
  return arguments[0].substring(arguments[0].lastIndexOf('.'));
}

3)然后,您可以在SQL查询编辑器中使用
select distinct extension(PATH) from DATA

...以逐项列出名为DATA的表中名为PATH的列的不同文件扩展名。

请注意,在此实现中,PATH字段必须包含反斜杠('\'),即,它必须是完整路径。

关于sqlite - SQLite:将文件扩展名与路径隔离,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34407028/

相关文章:

django - Jython,带Sqlite3的Django

android - 如何将预制数据库导入由 ormlite 管理的 sqlite

如果匹配,SQLite 减去两个表之间的时间差

python - Cython 回调中的段错误

c# - Xamarin MySQLite - 无法从本地存储加载错误

php - 使用 PHP PDO 在 sqlite 中启用共享寻呼机缓存

android - onUpgrade 数据库安卓版本号不增加

javascript - 如何使用 sql.js 创建 someFileName.sqlite 数据库,无需 NodeJs 和 Coffeescript,而仅使用 Javascript 并使用它?

ios - 如何删除 SQLite swift 4 中的 TableView 行

c - 为什么 sqlite 告诉我 "out of memory"?