這是SQL Server的bug麼?

來源:互聯網
上載者:User

在論壇上看到這樣一個文章, 原文如下:

在我的SQL Server2008R2上, 試了一下, 果然是這樣, 轉換成numeric時報錯..

看樣子很奇怪, 明明函數ISNUMBERIC的傳回值是1, 但是轉換卻不成功, 為什麼呢?

查了一下BOL, 發現如下的解釋:

ISNUMBERIC函數判斷運算式是否是以下類型之一:

 

int real

numeric bigint 

money smallint 

smallmoney tinyint 

float decimal 


看樣子ISNUMBERIC不只判斷是否是NUMBERIC類型, 也判斷其他如money等類型.

試了一下轉換成money型, 結果就沒有報錯, 語句如下:

SELECT cast('14,3434' AS money);

另外如果有$符號, 也是可以轉換成功的, 語句如下:

SELECT ISNUMERIC('$123');
SELECT cast('$123' AS money);

總結一下, 這不是SQL Server的bug, 只是使用者容易從函數ISNUMBERIC望文生義, 以為這個函數返回1的運算式一定是可以轉化為NUMBERIC型的. 其實能轉換為money而不能轉化為numberic型的運算式, 用ISNUMBERIC判斷也是返回1的.

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.