2011年10月25日火曜日

SQL Anywhere ランダムな結果を取得

SQL Anywhereで複数の行からランダムに1件選びたい場合はtop句とrand関数を使う。

たとえばテーブルmytableのランダムな1行を返す場合は次のようなselect文を書けばいい。

SELECT TOP 1 * FROM mytable
ORDER BY RAND()


rand関数はSQL2003 Vendor extension。他のDBでは使えるものとダメなものがある。

MySQLとSQLServerはrand関数だが、PostgreSQL はrandom関数。
Oracleはまた違うようである。(dbms_random.random関数?)
SQL Anywhere以外は未検証です。

コマンドプロンプト派のためのPowerShell - ファイル削除

PowerShellでのファイル削除はコマンドプロンプトと同じdelコマンド。
オプションが違う。

よく使う「強制削除」del /f に相当するのは -Force オプションを使う。

del {ファイル} -Force