SQLite( or PostgreSQL)でファイルパスからファイル名だけを取得する。
SQLiteでファイルパスからファイル名を取得したくなったので調べてみました。
SQLiteにはlastIndexOfのようなものがないみたいです。
instr()で文字列の位置を検索できますが、最初の位置しか返さないのでファイル名取得には使用できません。
Oracleみたいにpositionを指定できてマイナスを指定したら文末からサーチしてくれればよかったんですけど。
困ったときはstackoverflowってことで調べてみました。
ドンピシャなQuestionがありました。
これによると以下のようにすればOKということらしいです。
select replace(filepath, rtrim(filepath, replace(filepath, '\', '')), '') from table;
ほんとにとれました。
rtrimを使うなんて凡人にはできない発想ですね。
しかも1つずつ分解して考えてもどういうことなのかよくわからない。。
まー深くは考えないことにします。
rtrim?ほんまにとれるのーと疑っているそこのアナタ。
以下のページからSQLiteを選択して以下のSQLを実行してみてください。
びっくりすることにとれます。
select replace('c:\work\subwork\hogehoge.xls', rtrim('c:\work\subwork\hogehoge.xls', replace('c:\work\subwork\hogehoge.xls', '\', '')), '');
ちなみにPostgreSQLでも同じ方法でとれました。
"SQL Fiddle" ブラウザ上でいろいろなDBMSでSQLをテスト実行して、結果を確認することができるサービス。
いろいろなDBMSでSQLの挙動を確認したいけど、環境構築するのが面倒な方に朗報です。
SQL Fiddleはブラウザ上でDBMSを切り替えて、SQLを実行できるのでDBMSごとに異なるSQL関数の振る舞いの違いなどを簡単に確認できるサービスです。
2016/09/11現在、対応しているのは以下のDBMSで主要なものはすべてあるっぽいです。
- MySQL 5.5 / 5.6
- Oracle 11g R2*1
- PostgreSQL 9.3
- SQLite
- MS SQL Server 2008 / 2014
使用方法は簡単です。
まず、以下のページにいきます。
以下の様な画面が表示されます。
①左上のところでDBMSを選択します。
②左ペインの下にある"Build Schema"をクリック。
③右ペインが使用可能になるので、SQLを入力します。
④右ペインの下の"Run SQL"をクリック。
です。
こりゃ便利!
*1:なぜかエラーになりました