今天碰到個問題:要實現資料表中的一個欄位中的文字為"xxx.gif"的轉換為"xxx.jpg",我不知道其具體名稱,只知道是以gif結尾。
問題解決:update pet set petPhoto=substring(petPhoto,1,datalength(petPhoto)-3)+'jpg'
where petPhoto like '%.gif'
注意匹配符:“%”為匹配任意長度任意字符,“_”匹配單個任意字符,[A]匹配以A開頭的,[^A]匹配除開以A開頭的。知道函數是解決問題的關鍵(以下轉自網路):
1,統計函數avg, count, max, min, sum
2, 數學函數
ceiling(n) 傳回大於或等於n的最小整數
floor(n), 傳回小於或等於n的最大整數
round(m,n), 四捨五入,n是保留小數的位數
abs(n) 絕對值
sign(n), 當n>0, 回傳1,n=0,回傳0,n<0, 回傳-1
PI(), 3.1415....
rand(),rand(n), 傳回0-1之間的隨機數
3,字串函數
ascii(), 將字元轉換為ASCII碼, ASCII('abc') = 97
char(), ASCII 碼轉換為字符
low(),upper() 大小寫轉換
str(a,b,c)轉換數字為字串。 a,是要轉換的字串。 b是轉換以後的長度,c是小數位數。 str(123.456,8,2) = 123.46
ltrim(), rtrim() 去空格ltrim去左邊的空格,rtrim去右邊的空格
left(n), right(n), substring(str, start,length) 截取字串
charindex(子字串,母串),找出是否包含。 返回第一次出現的位置,沒有返回0
patindex('%pattern%', expression) 功能同上,可是使用萬用字元
replicate('char', rep_time), 重複字串
reverse(char),顛倒字串
replace(str, strold, strnew) 替換字串
space(n), 產生n個空白行
stuff(), SELECT STUFF('abcdef', 2, 3, 'ijklmn') ='aijklmnef', 2是開始位置,3是要從原來字串中刪除的字元長度,ijlmn是要插入的字串。
3,型別轉換函數:
cast, cast( expression as data_type), Example:
SELECT SUBSTRING(title, 1, 30) AS Title, ytd_sales FROM titles WHERE CAST(ytd_sales AS char(20)) LIKE '3%'
convert(data_type, expression)
4,日期函數
day(), month(), year()
dateadd(datepart, number, date), datapart指定對那一部分加,number知道加多少,date指定在誰的基礎上加。 datepart的值包括,year,quarter,month,dayofyear,day,week,hour,minute,second,例如明天dateadd(day,1, getdate())
datediff(datepart,date1,date2). datapart跟上面一樣。整個函數結果是date2 - date1
datename(datepart, date) 取那一部分,回傳字串。
datepart(datepart, date) 取一部分,傳回整數。
getdate()當前時間
5,系統函數
col_length('tablename','colname')
col_name, SELECT COL_NAME(OBJECT_ID('Employees'), 1) = EmployeeID
datalength, example: datalenght('abc') =3, datalength(pub_name) --列名