Sql Server函數全解(三)數據類型轉換函數和文本圖像函數


一:數據類型轉換函數

  在同時處理不同數據類型的值時,SQL Server一般會自動進行隱士類型轉換。對於數據類型相近的值是有效的,比如int和float,但是對於其它數據類型,例如整型和字符類型,隱士轉換就無法實現了,此時必須使用顯示轉換。為了實現這種顯示轉換,T-SQL提供了兩個顯示轉換函數,分別是CAST和CONVERT函數。
 CAST(x AS type)和CONVERT(type,x)函數將一個類型的值轉換為另一個類型的值。
eg: select CAST('121231' AS DATE),CAST(100 AS CHAR(3)),CONVERT(TIME,'2012-05-01 12:11:10')
 可以看到,CAST('121231' AS DATE)將字符串值轉換為了相應的日期值;CAST(100 AS CHAR(3))將整數100轉換為帶有3個顯示寬度的字符串類型,結果為字符串"100";CONVERT(TIME,'2012-05-01 12:11:10')將datetime類型的值,轉換為time類型值,結果為"12:11:10.0000000"。

 

二:文本和圖像函數

文本和圖像函數用於對文本或圖像輸入值或字段進行操作,並提供有關該值的基本信息。T-SQL中常用的文本含函數有兩個,即TEXTPTR函數和TEXTVALID函數。
1.TEXTPTR函數

TEXTPTR(column)函數用於返回varbinary格式的text、ntext或者image字段的文本指針值。查找到的文本指針值可應用於readtext,writetext和updatetext語句。其中參數column是一個數據類型為text、ntext或者image的字段列。
【例】查詢authors表中name字段十六字節文本指針;
 首先創建表authors, name字段為text類型,T-SQL代碼如下:
create table authors(id int ,name text);
 insert into authors values(1,'this is a text');
使用TEXTPTR查詢authors表中name字段的十六字節文本指針
select id, TEXTPTR(name)from authors where id=1

2. TEXTVALID函數

  TEXTVALID('table.column',text_ptr)函數用於檢查特定文本指針是否為有效的text、ntext或image函數。table.column為指定數據表和字段,text_ptr為要檢查的文本指針。
【例】檢查是否存在用於authors表中decription字段中的各個值的有效文本指針。
  select id,'this is a text' = TEXTVALID(('authors.name'),TEXTPTR(name)) from authors;
 第一個1為id的值,第二個1表示查詢的值存在.

   


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM