Landscape トップページ | < 前の日 2003-10-08 2003-10-09 次の日 2003-10-10 >


* SQL Server で電話番号を - で連結するストアド

この記事の直リンクURL: Permlink | この記事が属するカテゴリ: [MS SQL Server]

以下のカラムを持つテーブルがある。
tel_shigai VARCHAR(6), -- 電話番号 市外局番
tel_shinai VARCHAR(6), -- 電話番号 市内局番
tel_bango VARCHAR(4), -- 電話番号
これを 出力するときは - で連結せよ、という仕様があった。

今までは単純に
tel_shigai + '-' + tel_shinai + '-' + tel_bango AS tel_no
としていたが、これだとどれかが NULL か 空文字でもハイフンがくっついてしまう。
全部空の場合は -- という出力になってしまう。

ということでユーザ定義関数を作成した。
郵便番号を連結する場合は、第三引数を null として渡す必要がある。
引数を可変長の配列で受け取ったりできればループを使って簡潔に書けそうだが、
どうも SQL Server2000 ではできないようなので if 文を連ねてみた。
-- 郵便番号、電話番号、FAX 番号を - で連結する
GO
DROP FUNCTION cat_number;
GO
CREATE FUNCTION cat_number(@arg1 VARCHAR(8), @arg2 VARCHAR(8), @arg3 VARCHAR(8))
RETURNS VARCHAR(64)
AS BEGIN

  DECLARE
    @str VARCHAR(64)
  IF (@arg1 IS NOT NULL) AND (@arg1 <> '') AND (@arg2 IS NOT NULL) AND (@arg2 <> '') BEGIN
    SET @str = @arg1 + '-' + @arg2
  END ELSE BEGIN
    SET @str = COALESCE(@arg1, '') +  COALESCE(@arg2, '')
  END

  IF (@str IS NOT NULL) AND (@str <> '') AND (@arg3 IS NOT NULL) AND (@arg3 <> '') BEGIN
    SET @str = @str + '-' + @arg3
  END ELSE BEGIN
    SET @str =  COALESCE(@str, '')  +  COALESCE(@arg3, '')
  END

  RETURN @str
END


* SQL Server で NULL と 文字列を連結する

この記事の直リンクURL: Permlink | この記事が属するカテゴリ: [MS SQL Server]

CONCAT_NULL_YIELDS_NULL をオフにしておかないと、
NULL と文字列連結した結果は必ず NULL になってしまう。

SET CONCAT_NULL_YIELDS_NULL
http://www.microsoft.com/japan/msdn/library/ja/tsqlref/ts_se ...

* おとなの小論文教室。

この記事の直リンクURL: Permlink | この記事が属するカテゴリ: [メモ]

http://www.1101.com/essay/

以前読んだ
Lesson126 考える方法をならったことがありますか?(2)
http://www.1101.com/essay/2002-12-11.html
は非常に参考になった。
自分の頭で考えるとはどういうことなのかを噛み砕いて書いてある。
すべての記事の見出し (全1029件)
全カテゴリの一覧と記事の数
カテゴリごとに記事をまとめ読みできます。記事の表題だけを見たい場合は、すべての記事の見出し (カテゴリ別表示) へ。

直近30日分の記事
2007-04-23 (Mon)
2007-03-07 (Wed)
2007-02-27 (Tue)
2007-01-17 (Wed)
2007-01-15 (Mon)
2007-01-14 (Sun)
2007-01-08 (Mon)
2006-12-01 (Fri)
2006-11-22 (Wed)
2006-11-20 (Mon)
2006-11-19 (Sun)
2006-09-30 (Sat)
2006-08-29 (Tue)
2006-08-04 (Fri)
2006-07-27 (Thu)
2006-07-23 (Sun)
2006-07-17 (Mon)
2006-07-10 (Mon)
2006-07-06 (Thu)
2006-07-03 (Mon)
2006-06-29 (Thu)
2006-06-28 (Wed)
2006-06-27 (Tue)
2006-06-25 (Sun)
2006-06-19 (Mon)
2006-06-18 (Sun)
2006-06-15 (Thu)
2006-06-11 (Sun)
2006-06-01 (Thu)
2006-05-30 (Tue)
プロファイル
斎藤 宏明。エンジニアです。宇都宮市に住んでいます。
リンク
RSS
スポンサードリンク
Powered by
さくらインターネット

© 斎藤 宏明 Saito Hiroaki Gmail Address
Landscape - エンジニアのメモ http://sonic64.com/
Landscape はランドスケープと読みます。
ひらがなだと らんどすけーぷ です。