❶ sql怎麼查詢某個字元在字元串中的位置
select CHARINDEX('查詢字元',查詢欄位), * from 表
如
❷ sql 查找欄位中某字元的位置
1、創建測試表,
create table test_student(id number, remark varchar2(20));
❸ sql 查找字元串位置(從倒數算起)
declare @i int,@j int,@str varchar(20)
set @str='abc-def-h'
set @i=1
set @j=len(@str)
declare @num int
while @i<@j
begin
set @num=charindex('-',@str,@i)
set @i=@i+1
set @i=@num+1
select @num
end
❹ sql怎樣定位一個字元所在的位置
常用的字元串函數,其作用可分為四大類:串接字元、截取字元、轉換字元、其他作用的字元函數。
串接,就是把單獨的字元串組合為一個。如把人的姓和名串接在一起形成一個完整的姓名字元串。
截取,是指從字元串里提取出一部分字元,形成子串。可以分為截取字元、提取字元的位置。
轉換,是指把一個字元串中的內容或形式變換成另一個內容或形式。分為內容轉換和形式轉換。
其他作用的字元函數:以上三種作用之外的其他字元函數。
下面詳細介紹。
串接函數
可以通過+或者-,實現串接操作。在不同的資料庫管理系統中,使用的串接符號不同。
在SQL SERVER中的代碼為:SELECT 『JOHN』+ 『SON』
在MySQL中的代碼為:SELECT CONCAT(『JHON』,『SON』)
截取函數
1、SUBSTR(COLUMN NAME,STARING POSITION,LENGTH)
COLUMN NAME:欄位名稱
STARING POSITION:起始位置,即從第幾個字元開始截取
LENGTH:長度,即截取多少個字元的長度
select emp_id,substr(emp_id,1,3) from employee
從雇員表中檢索出雇員編號,雇員姓名兩個欄位。其中雇員姓名可通過從編號ID的前三個字元截取得到。
2、TRIM()、LTRIM()、RTRIM(),剪除字元串中的字元。
SQL 中的 TRIM 函數是用來移除掉一個字串中的字頭或字尾。最常見的用途是移除字首或字尾的空白。這個函數在不同的資料庫中有不同的名稱:
MySQL: TRIM( ), RTRIM( ), LTRIM( )
Oracle: RTRIM( ), LTRIM( )
SQL Server: RTRIM( ), LTRIM( )
各種 trim 函數的語法如下:
TRIM ( [ [位置] [要移除的字串] FROM ] 字串): [位置] 的可能值為 LEADING (起頭), TRAILING (結尾), or BOTH (起頭及結尾)。 這個函數將把 [要移除的字串] 從字串的起頭、結尾,或是起頭及結尾移除。如果我們沒有列出 [要移除的字串] 是什麼的話,那空白就會被移除。
LTRIM(字串): 將所有字串起頭的空白移除。
RTRIM(字串): 將所有字串結尾的空白移除
❺ SQLserver中字元串查找功能patindex和charindex的區別
charindex和patindex函數常常用來在一段字元中搜索字元或字元串。假如被搜索的字元中包含有要搜索的字元,那麼這兩個函數返回一個非零的整數,這個整數是要搜索的字元在被搜索的字元中的開始位數。patindex函數支持使用通配符來進行搜索,然而charindex不支持通配符。接下來,逐個分析這兩個函數。
怎樣使用charindex函數
charindex函數返回字元或字元串在另一個字元串中的起始位置。charindex函數調用方法如下:
charindex ( expression1 , expression2 [ , start_location ] )
expression1是要到expression2中尋找的字元中,start_location是charindex函數開始在expression2中找expression1的位置。
charindex函數返回一個整數,返回的整數是要找的字元串在被找的字元串中的位置。假如charindex沒有找到要找的字元串,那麼函數整數「0」。讓看看下面的函數命令執行的結果:
charindex(sql, microsoft sql server)
這個函數命令將返回在「microsoft sql server」中「sql」的起始位置,在這個例子中,charindex函數將返回「s」在「microsoft sql server」中的位置11。
接下來,看這個charindex命令:
charindex(7.0, microsoft sql server 2000)
在這個例子中,charindex返回零,因為字元串「7.0」 不能在「microsoft sql server」中被找到。
接下來通過兩個例子來看看怎樣使用charindex函數來解決實際的t-sql問題。
第一個例子,假設要顯示northwind資料庫customer表前5行聯系人列的last name。這是前5行數據
contactname
------------------------------
maria anders
ana trujillo
antonio moreno
thomas hardy
christina berglund
能夠看到,customname包含客戶的first name和last name,他們之間被一個空格隔開。用charindx函數確定兩個名字中間空格的位置。通過這個方法,能夠分析contactname列的空格位置,這樣能夠只顯示這個列的last name部分。這是顯示northwind的customer表前5行last name的記錄
selecttop5substring(contactname,charindex(,contactname)+1,len(contactname))as[lastname]fromnorthwind.dbo.customers
下面是這個命令輸出的結果。
last name
------------------------------
anders
trujillo
moreno
hardy
berglund
charindex函數找到first name和last name之間的空格,所以substring函數能夠分開contactname列,這樣就只有last name被選出。在charindex函數返回的整數上加1,這樣last name不是從空格開始。
在第二個例子中,即如說要計算記錄中,某一個欄位包含特定字元的任何記錄數。charindex函數能夠方便的解決的問題。計算northwind.dbo.customer表中addresses欄位中包含單詞road或他的縮寫rd的記錄數,選擇語句類似這樣:
selectcount(*)fromnorthwind.dbo.customerswherecharindex(rd,address)>0orcharindex(road,address)>1
怎樣使用patindex函數
patindex函數返回字元或字元串在另一個字元串或表達式中的起始位置,patindex函數支持搜索字元串中使用通配符,這使patindex函數對於變化的搜索字元串很有價值。patindex函數的命令如下:
patindex ( %pattern% , expression )
pattern是要搜索的字元串,expression是被搜索的字元串。一般情況下expression是個表中的一個欄位,pattern的前後需要用「%」標記,除非搜索的字元串在被收縮的字元串的最前面或最後面。
和charindex函數相同,patindex函數返回搜索字元串在被搜索字元串中的起始位置。假如有這樣一個patindex函數:
patindex(%bc%,abcd)
這個patindex函數返回的結果是2,這和charindex函數相同。這里的%標記告訴patindex函數去找字元串「bc」,不管被搜索的字元串中在「bc」的前後有多少字元!
假如想知道被搜索字元串是否由特定的字元串開始,能夠省去前面的%標記。patinded函數就要這樣寫:
patindex(ab%,abcd)
這個命令執行的結果返回1,表示搜索的字元串「ab」在被搜索的字元串中「abcd」被找到。
使用通配符能夠編輯比以上舉得簡單例子復雜得多的搜索字元串。假如說要確定一個字元串是否包含字母a和z,更有任何數字,這個parindex函數命令可能像這樣:
patindex(%[a,z,0-9]%[a,z,0-9]%[a,z,0-9]%,xyzabc123)
注意在上面這個例子中的搜索字元部分使用了很多的通陪符。察看sql server聯機叢書能夠獲得更多關於通佩符的信息。接下來,用兩個例子來看patindex和select怎麼聯合起來使用。
假設想要找出northwind.dbo.categories表中description欄位中是包含單詞「bread」或「bread」的任何記錄,那麼選擇語句就可能是這樣:
.dbo.categorieswherepatindex(%[b,b]read%,description)>0
這里用通配符來確定大寫和小寫的「b」。在notthwind資料庫中執行這個腳本後,得到下面的結果:
description
--------------------------------------------------------
desserts, candies, and sweet breads
breads, crackers, pasta, and cereal
這是再用另外一個額外的通配符來查找一些記錄的例子。這個例子是怎樣選出上面的查詢結果中,description欄位的第二子字母不是「e」的紀錄。
.dbo.categorieswherepatindex(%[b,b]read%,description)>0andpatindex(_[^e]%,description)=1
通過在條件語句中增加一個使用^通配符的patindex函數,能夠過濾掉「dessert, candies, and sweet breads」這條記錄。上面的查詢結果只有一條記錄。
description
--------------------------------------------------------
breads, crackers, pasta, and cereal
總結
現在能夠發現charindex和patindex搜索字元串時的區分了吧。patindex函數支持使用通配符,能夠用在很多有變化的查找中。而charindex不能夠。根據自己不同的情況,這兩個函數對在sql server中的字元串的搜索、控制、分析很有幫助。
❻ sql 怎樣定位一個字元所在的位置
可以通過INSTR方法來進行查詢:
sql:select INSTR('abcdefg ','c') from al;
輸出結果:3。
解釋:以上sql就是查詢c字元在「abcdefg」中的位置。
❼ MS SQL Server有沒有查找字元串位置的函數
sql 查找字元串位置使用CHARINDEX函數。
CHARINDEX函數,在一段字元中搜索字元或者字元串。
語法
CHARINDEX ( expression1 , expression2 , [ start_location ] )
參數
expression1
一個表達式,其中包含要尋找的字元的次序。expression1是一個短字元數據類型分類的表達式。
expression2
一個表達式,通常是一個用於搜索指定序列的列。expression2屬於字元串數據類型分類。
start_location
在expression2中搜索expression1時的起始字元位置。如果沒有給定start_location,而是一個負數或零,則將從expression2的起始位置開始搜索。
返回類型
int
例:
❽ sql如何獲取字元串中的指定字元
1、創建測試表,
create table test_int(value varchar2(50));