DB2 における REVERSE 関数の実装
ORACLE
SQL> select reverse('1234') from dual;
REVERSE(
--------
4321
SQL> select reverse(12121) from dual;
select reverse(12121) from dual
1行目でエラーになりました。
ORA-00932: 不整合なデータ型:CHARでなければならないのにNUMBERになっている。
oracleのreverseの引数がchar型であり、戻り値もchar型であることを意味します。
SQL> select length(reverse('1234 ')) from dual;
長さ(reverse('1234'))
-----------------------
8
SQL> select reverse('1234 ') from dual;
reverse('1234')
----------------
4321
戻り値の型が varchar の場合、長さが 4 であるため、戻り値は char になります。
sql serverを使用します。
逆関数の引数型は varchar または nvarchar で、戻り値の型も varchar または nvarchar です。
C:\&g;sqlcmd -S kermart -U sa -P sa -d master
1> select reverse('1234');
2>行く
----
4321
(1行の影響)
1> select reverse(1234); -- 実行計画から明らかなように、型変換が発生します。
2> 実行
------------
4321
(1行の影響)
オラクルをベースに、sql serverはリバース機能を内蔵しており、DB2もアプリケーションのシナリオによってはリバース機能を持たせるべきと考えます。
CREATE OR REPLACE FUNCTION REVERSE
(
p1 varchar(200)
)
RETURNS VARCHAR(200)
SPECIFIC "REVERSE"
LANGUAGE SQL
DETERMINISTIC
NO EXTERNAL ACTION
READS SQL DATA
BEGIN
declare v_str varchar(100) default '';
DECLARE v_index INTEGER; -- Define subscript
SET v_index = length(p1);
WHILE(v_index >= 1) DO
SET v_str = v_str||substr(p1,v_index,1);
SET v_index = v_index - 1;
END WHILE;
return v_str;
END@
テストする
select reverse('123456') from dual;
654321
select reverse(1234) from dual; -- 実行計画を見てください、型変換があるのがわかるはずです。
4321
関連
-
解決する db2トランザクションログがいっぱいで、ログのディスク容量がいっぱいです問題の詳細な解決方法
-
シェルによるdb2データの抽出と更新
-
DB2プログラミングのヒント
-
SQL Server 2008 Management Studio Expressのインストール方法
-
メインフレームとミニコンピュータからDB2 9データサーバーにアクセスする方法
-
DB2 9 で SQL を使用して XML データをクエリする
-
DB2データベースの作成、テーブルのixfファイルのエクスポートインポートの例
-
DB2プログラミングスキル (1)
-
DB2エキスパートのワン・ユンが語るビジネスインテリジェンスBI
-
DB2 9 と DB2 V8.x の XML 機能を比較する
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン