sql server的幾個(gè)函數(shù)要記錄
今日碰到個(gè)問(wèn)題:要實(shí)現(xiàn)數(shù)據(jù)表中的一個(gè)字段中的文本為'xxx.gif'的轉(zhuǎn)換為'xxx.jpg',我不知道其具體名稱,只知道是以gif結(jié)尾。問(wèn)題解決:update pet set petPhoto=substring(petPhoto,1,datalength(petPhoto)-3)+'jpg' where petPhoto like '%.gif'注意匹配符:“%”為匹配任意長(zhǎng)度任意字符,“_”匹配單個(gè)任意字符,[A]匹配以A開(kāi)頭的,[^A]匹配除開(kāi)以A開(kāi)頭的。知道函數(shù)是解決問(wèn)題的關(guān)鍵(以下轉(zhuǎn)自網(wǎng)絡(luò)):
1,統(tǒng)計(jì)函數(shù) avg, count, max, min, sum 2, 數(shù)學(xué)函數(shù) ceiling(n) 返回大于或者等于n的最小整數(shù) floor(n), 返回小于或者是等于n的最大整數(shù) round(m,n), 四舍五入,n是保留小數(shù)的位數(shù) abs(n) 絕對(duì)值sign(n), 當(dāng)n>0, 返回1,n=0,返回0,n<0, 返回-1 PI(), 3.1415.... rand(),rand(n), 返回0-1之間的一個(gè)隨機(jī)數(shù) 3,字符串函數(shù) ascii(), 將字符轉(zhuǎn)換為ASCII碼, ASCII('abc') = 97 char(), ASCII 碼 轉(zhuǎn)換為 字符 low(),upper() 大小寫(xiě)轉(zhuǎn)換str(a,b,c)轉(zhuǎn)換數(shù)字為字符串。 a,是要轉(zhuǎn)換的字符串。b是轉(zhuǎn)換以后的長(zhǎng)度,c是小數(shù)位數(shù)。str(123.456,8,2) = 123.46 ltrim(), rtrim() 去空格 ltrim去左邊的空格,rtrim去右邊的空格left(n), right(n), substring(str, start,length) 截取字符串 charindex(子串,母串),查找是否包含。 返回第一次出現(xiàn)的位置,沒(méi)有返回0 patindex('%pattern%', expression) 功能同上,可是使用通配符 replicate('char', rep_time), 重復(fù)字符串 reverse(char),顛倒字符串 replace(str, strold, strnew) 替換字符串 space(n), 產(chǎn)生n個(gè)空行 stuff(), SELECT STUFF('abcdef', 2, 3, 'ijklmn') ='aijklmnef', 2是開(kāi)始位置,3是要從原來(lái)串中刪除的字符長(zhǎng)度,ijlmn是要插入的字符串。 3,類型轉(zhuǎn)換函數(shù): 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,日期函數(shù) day(), month(), year() dateadd(datepart, number, date), datapart指定對(duì)那一部分加,number知道加多少,date指定在誰(shuí)的基礎(chǔ)上加。datepart的取值包括,year,quarter,month,dayofyear,day,week,hour,minute,second,比如明天dateadd(day,1, getdate()) datediff(datepart,date1,date2). datapart和上面一樣。整個(gè)函數(shù)結(jié)果是date2 - date1 datename(datepart, date) 取那一部分,返回字符串。 datepart(datepart, date) 取一部分,返回整數(shù)。 getdate()當(dāng)前時(shí)間 5,系統(tǒng)函數(shù) col_length('tablename','colname') col_name, SELECT COL_NAME(OBJECT_ID('Employees'), 1) = EmployeeID datalength, example: datalenght('abc') =3, datalength(pub_name) --列名
