田舎エンジニアのBlog

~自宅も会社も田んぼに囲まれてますが何か?~

目次

Blog 利用状況

ニュース

自己紹介

リンク

スポンサー

書庫

日記カテゴリ

インラインユーザー定義関数

[@IT]ユーザー定義関数から正しくない答えが返される

 

SQLServerでは、テーブル型を返すユーザー定義関数をインラインユーザー定義関数と呼ぶそうです。

例えば、以下のようなテーブルを作り、データを格納します。

(環境:SQL Server 2005 Express Edition)

[テーブル]
member_table
member_code int
member_name nvarchar(50)
[データ]
member_code member_name
1           中博俊
2           じゃんぬねっと
3           nakaP

 

member_codeを指定して、該当する行を返すユーザー定義関数を作ります。

CREATE FUNCTION dbo.Test(@code INT)
RETURNS TABLE
AS RETURN (SELECT * FROM member_table WHERE member_code = @code)
GO

 

そしてユーザー定義関数を実行すると、以下のような結果が返ります。

SELECT * FROM Test(1)
[結果]
member_code member_name
1           中博俊

 

ここでテーブルに列を追加し、データを編集します。

[テーブル]member_table
member_code  int
memver_class nvarchar(50)
member_name  nvarchar(50)
[データ]
member_code member_class member_name
1           代表         中博俊
2           代表         じゃんぬねっと
3           下っ端       nakaP

 

そして再度ユーザー定義関数を実行すると、以下のような結果に変わります。

SELECT * FROM Test(1)
[結果]
member_code member_name
1           代表

 

列名と内容が一致していません。なぜでしょうか。

まず、sys.objectsのid列を利用して、sys.columnsの情報を取得します。

(SQL Server 2000 ではsysobjects、syscolumns)

それぞれの詳細は以下をご覧ください。

sys.objects

sys.columns

なお参考にsys.parametersもご覧になられるといいかもしれません。

(SQL Server 2000 ではsysparameters)

sys.parameters

SELECT * FROM sys.columns WHERE object_id = (SELECT object_id FROM sys.objects WHERE name = 'Test')
object_id name column_id ・・・
*******   id   1
*******   name 2

 

項目数は多いですが、member_code列とmember_name列が返されることが分かります。

ここでも列名と内容が一致していません。

次にsp_sproc_columnsの情報を見てみます。

sp_sproc_columns

EXEC sp_sproc_column @procedure_name = 'Test'

この結果のTYPE_NAME列を見ると、「table」となっています。

以上の結果より、インラインユーザー定義関数はテーブルを返しますが、戻り値の列数は2つしかないことが分かります。

つまり、テーブル定義の変更後は、3列の結果を2列のテーブルとして返しているのです。

そして、戻り値の列名は便宜上の列名であり、必ずしも元テーブルの列名と同期が取られているわけではないようです。

 

この問題を解決するには、

1.インラインユーザー定義関数で個別に列名を指定しておく

2.sp_refreshsqlmoduleを実行する

ことになります。

 

 

 

これがバグなのか仕様なのかは分かりませんが、知っていないとハマりそうですね。

「select * は便利だけど便利じゃないよ」

ってことですね。

投稿日時 : 2009年9月3日 15:34

コメントを追加

# re: INI 編集ツール IniModifier を作成してみる (1) 2018/08/20 13:42 chenlixiang

2018.8.20chenlixianghttp://www.nikefree-5.com
http://www.ghdhair.me.uk
http://www.gucci.in.net
http://www.airmax90.in.net
http://www.air-max-2017.net
http://www.reebok.us.org
http://www.cheap-jordans.in.net
http://www.orologi-rolex.it
http://www.nikeoutletonline.org
http://www.jordan31.org
http://www.poloralph.in.net
http://www.swarovskicrystaljewelrys.us.com
http://www.nike--store.fr
http://www.michael--korsoutlet.ca
http://www.ferragamosunglasses.us
http://www.oakleys-sunglasses.net.co
http://www.nike-freerun.com
http://www.kobe10.us
http://www.nikeairmaxinc.net
http://www.air-jordanshoes.net
2018.8.20chenlixiangコメント

# ivermectin 9 mg 2021/09/28 18:35 MarvinLic

generic stromectol https://stromectolfive.com/# ivermectin 12

# ivermectin drug 2021/10/31 18:09 DelbertBup

ivermectin 50 mg http://stromectolivermectin19.com/# ivermectin 4000 mcg
ivermectin drug

# ivermectin 10 mg 2021/11/02 15:04 DelbertBup

ivermectin oral 0 8 http://stromectolivermectin19.com/# how much is ivermectin
stromectol ivermectin 3 mg

# ivermectin 8 mg 2021/11/03 10:20 DelbertBup

ivermectin 1 cream generic http://stromectolivermectin19.com/# ivermectin 18mg
ivermectin lice

# cheap generic ed pills 2021/12/04 0:06 JamesDat

http://genericpillson.com/# generic ed pills from canada dapoxetine

# sildenafil citrate tablets 100 mg 2021/12/10 5:13 JamesDat

http://viasild24.com/# sildenafil 20 mg tablet

# best place to buy careprost 2021/12/11 21:47 Travislyday

http://stromectols.online/ ivermectin rx

# bimatoprost generic best price 2021/12/12 16:42 Travislyday

https://bimatoprostrx.com/ careprost for sale

# bimatoprost generic https://bimatoprostrx.com
bimatoprost ophthalmic solution careprost
2021/12/13 16:11 Hksfnjkh

bimatoprost generic https://bimatoprostrx.com
bimatoprost ophthalmic solution careprost

# bimatoprost buy 2021/12/15 2:42 Travislyday

http://bimatoprostrx.com/ careprost for sale

# ivermectin 2mg 2021/12/17 13:40 Eliastib

ytpoia https://stromectolr.com cost of ivermectin 1% cream

# ivermectin where to buy for humans 2021/12/18 15:50 Eliastib

lyqzly https://stromectolr.com ivermectin 80 mg

# stromectol australia http://stromectolabc.com/
generic ivermectin for humans 2022/02/08 2:53 Busjdhj

stromectol australia http://stromectolabc.com/
generic ivermectin for humans

# ivermectin 3mg tablets price http://stromectolabc.com/
stromectol usa 2022/02/08 9:41 Busjdhj

ivermectin 3mg tablets price http://stromectolabc.com/
stromectol usa

# ivermectin over the counter http://stromectolabc.com/
ivermectin over the counter canada 2022/02/08 16:44 Busjdhj

ivermectin over the counter http://stromectolabc.com/
ivermectin over the counter canada

# doxycycline hyclate 100 mg cap https://doxycyline1st.com/
doxycycline 100mg dogs 2022/02/26 20:12 Doxycycline

doxycycline hyclate 100 mg cap https://doxycyline1st.com/
doxycycline 100mg dogs

# canadian pharmacies that ship to us https://allpharm.store/ 2022/07/22 6:03 AllPharm

canadian pharmacies that ship to us https://allpharm.store/

# covid traitement https://paxlovid.best/
when will paxlovid be available 2022/09/08 7:46 Paxlovid

covid traitement https://paxlovid.best/
when will paxlovid be available

# buy cytotec in usa - https://cytotecsale.pro/# 2023/04/28 23:34 Cytotec

buy cytotec in usa - https://cytotecsale.pro/#

# over the counter sleep aid https://overthecounter.pro/# 2023/05/08 18:17 OtcJikoliuj

over the counter sleep aid https://overthecounter.pro/#

# canadian drug store prices https://pillswithoutprescription.pro/# 2023/05/16 4:48 PillsPro

canadian drug store prices https://pillswithoutprescription.pro/#

# ed pills for sale https://edpill.pro/# - herbal ed treatment 2023/06/27 10:20 EdPills

ed pills for sale https://edpill.pro/# - herbal ed treatment

# paxlovid generic https://paxlovid.pro/# - paxlovid buy 2023/07/02 23:15 Paxlovid

paxlovid generic https://paxlovid.pro/# - paxlovid buy

# ï»¿plavix generic https://plavix.guru/ Clopidogrel 75 MG price 2023/10/23 21:18 Plavixxx

plavix generic https://plavix.guru/ Clopidogrel 75 MG price

# ï»¿farmacia online migliore https://farmaciait.pro/ farmacie online sicure 2023/12/04 7:08 Farmacia

farmacia online migliore https://farmaciait.pro/ farmacie online sicure

# prednisone 10mg price in india https://prednisone.bid/ how can i get prednisone 2023/12/27 6:56 Prednisone

prednisone 10mg price in india https://prednisone.bid/ how can i get prednisone

タイトル
名前
URL
コメント