.SQL Server中 image類型資料的比較

來源:互聯網
上載者:User

標籤:

原文:.SQL Server中 image類型資料的比較

在SQL Server中如果你對text、ntext或者image資料類型的資料進行比較。將會提示:不能比較或排序 text、ntext 和 image 資料類型,除非使用 IS NULL 或 LIKE 運算子。不過image也是不支援like比較的。
那怎麼樣對資料庫中的圖片做比較呢。
對於這種大型物件的處理,在Oracle中有有專門的函數DBMS_LOB.COMPARE,而SQLSERVER中沒有專門的處理函數,
只能通過使用substring函數一段一段的從image資料中截取放到varbinary類型資料,最長8060位元組(8k),
然後再對varbinary類型資料進行比較。以下是一個比較image的函數例子:注意: 局部變數的類型是任何由系統提供的或使用者定義的資料類型。變數不能是 text、ntext 或 image 資料類型,請在查詢中直接使用。
/****** Object:  UserDefinedFunction [dbo].[FuncCompareImage]    Script Date: 2016-09-01 11:18:53 ******/SET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGOALTER FUNCTION [dbo].[FuncCompareImage] ( @a1 IMAGE, @a2 IMAGE )RETURNS INT-- if match, return 1AS    BEGIN        DECLARE @n INT ,            @i INT ,            @j INT;        DECLARE @b1 VARBINARY(8000) ,            @b2 VARBINARY(8000);        SET @n = 1;        IF DATALENGTH(@a1) <> DATALENGTH(@a2) -- different length            SET @n = 0;        ELSE            BEGIN                SET @i = 0;                SET @j = ( DATALENGTH(@a1) - 1 ) / 8000 + 1;                WHILE @i <= @j                    BEGIN                        SET @b1 = SUBSTRING(@a1, @i * 8000 + 1,                                            CASE @i                                              WHEN @j                                              THEN DATALENGTH(@a1) % 8000                                              ELSE 8000                                            END);                        SET @b2 = SUBSTRING(@a2, @i * 8000 + 1,                                            CASE @i                                              WHEN @j                                              THEN DATALENGTH(@a2) % 8000                                              ELSE 8000                                            END);                        IF @b1 <> @b2                            BEGIN                                SET @n = 0;                                BREAK;                            END;                        SET @i = @i + 1;                    END;            END;        RETURN(@n);    END;

 


 

.SQL Server中 image類型資料的比較

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.