欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

sql?server如何去除數(shù)據(jù)中的一些無用的空格

 更新時間:2023年05月29日 11:43:49   作者:wxl@  
這篇文章主要介紹了sql?server去除數(shù)據(jù)中的一些無用的空格,本文給大家提到了一些常用的函數(shù),結(jié)合示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

先有個一名為student的關(guān)系,其字段以及元組如圖所示:

為了保持?jǐn)?shù)據(jù)的一致性,現(xiàn)在需要將sname的多余空格去除,以及將所有的snative字段的“族”去掉以保持?jǐn)?shù)據(jù)的一致性。
在這之前,首先介紹幾個常用的函數(shù):

left&right&substring

使用格式:
left(str, n)
right(str, n)
substring(str, start, n)
str指的是字符串對象,n指的是字符個數(shù),所以left和right的作用就明了了:從傳入的字符串的左邊(右邊)第一個字符開始,選中n個字符,例如:

這里選出的結(jié)果有的為空是因?yàn)樵P(guān)系中sname有些開頭有空格。
而substring()的用法更為靈活,它指定了從str的第幾個元素開始,即start的作用,如從sname的第二個字符開始選擇三個字符:

有三個地方需要注意:

  • 在sql中,字符串的第一個字符不是0,而是1,拿python來說,它的字符串的第一個字符的索引為0,拿C語言的數(shù)組來說,第一個元素的索引為0,所以這個區(qū)別需要清楚。
  • 我們知道中文占用兩個字節(jié),可能在這里容易陷入一個誤區(qū):是不是sql選擇字符串中的中文需要兩個距離大小呢?比如選擇第一個中文就是:substring(str, 1, 2)?看了上面的實(shí)例就知道了,這里儲存字符串類似于數(shù)組,一個字符占用一個位置,所以這樣才是正確的:substring(str, 1, 1)
  • 如果要訪問字符串的最后一個字符如何操作呢?根據(jù)這三個函數(shù)有兩種方法:right(str, 1)或者substring(str, len(str), 1)

lower&upper

使用方式:

select upper(sname) from student;
select lower(sname) from student;

這兩個函數(shù)對于中文無影響

ltrim&rtrim

使用方式:

select ltrim(sname) from student;
select rtrim(sname) from student;

作用:去除屬性值最左邊(右邊)的空格;

模糊查詢(like的用法)

具體請參照我的這一篇博文:http://www.dbjr.com.cn/database/285790x8b.htm

首先解決簡單的,將民族的多余的“族”去掉:

update student set 
snative=substring(snative, 1, len(snative) - 1) 
where right(snative, 1)='族';

現(xiàn)在去除多余的空格:
大體上有兩種方式,使用like和不適用like:

使用like :

首先去除左右兩邊的空格:
這里的% 可以代表任意字符,甚至可以為空。

-- 首先去除左右兩邊的空格
update  student set  
sname=ltrim(rtrim(sname)) where sname like ‘% %';

然后去除中間的空格:

update student set 
sname=left(sname,1)+right(sname,1) where sname like ‘% %';

使用like '% %'其實(shí)實(shí)現(xiàn)了掃描每一個sname字符串是否包含空格。

不使用like:

首先去除兩邊的空格:

update student set sname=ltrim(rtrim(sname));

去除中間的空格:

update student set 
sname = left(sname, 1) + 
rtrim(ltrim(substring(sname, 2, len(sname) - 2))) + 
right(sname, 1);

這種方法其實(shí)不通用,僅僅適合處理名字長度小于4的情況,其他情況的中間空格沒法完全去除。它的思路就是先除去sname的左右空格,然后取中間部分,再次除去這部分的左右空格,然后和左右部分相接。

到此這篇關(guān)于sql server去除數(shù)據(jù)中的一些無用的空格的文章就介紹到這了,更多相關(guān)sql server去除數(shù)據(jù)空格內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • SQLServer地址搜索性能優(yōu)化

    SQLServer地址搜索性能優(yōu)化

    網(wǎng)上關(guān)于SQL優(yōu)化的教程很多,但是比較雜亂。今天我們來從一個簡單的例子來探討下SQLServer地址搜索性能優(yōu)化
    2017-01-01
  • sql server排查死鎖優(yōu)化性能

    sql server排查死鎖優(yōu)化性能

    這篇文章介紹了sql server排查死鎖優(yōu)化性能的方法,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04
  • GreatSQL 在SQL中如何使用 HINT 語法修改會話變量

    GreatSQL 在SQL中如何使用 HINT 語法修改會話變量

    GreatSQL推出新的優(yōu)化Hint功能,名為SET_VAR,允許用戶在查詢語句中修改數(shù)據(jù)庫的會話變量,但只對當(dāng)前查詢會話生效,不影響其他會話,本文給大家介紹GreatSQL 在SQL中如何使用 HINT 語法修改會話變量,感興趣的朋友一起看看吧
    2024-10-10
  • SQL?Server查看當(dāng)前連接數(shù)和最大連接數(shù)具體方法代碼

    SQL?Server查看當(dāng)前連接數(shù)和最大連接數(shù)具體方法代碼

    這篇文章主要介紹了SQL?Server查看當(dāng)前連接數(shù)和最大連接數(shù)的具體方法,講解了使用系統(tǒng)視圖、配置選項(xiàng)、實(shí)時監(jiān)控和SQL?Server?Management?Studio等方法,每種方法都給出了代碼示例,需要的朋友可以參考下
    2025-04-04
  • sql?server如何去除數(shù)據(jù)中的一些無用的空格

    sql?server如何去除數(shù)據(jù)中的一些無用的空格

    這篇文章主要介紹了sql?server去除數(shù)據(jù)中的一些無用的空格,本文給大家提到了一些常用的函數(shù),結(jié)合示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-05-05
  • sqlserver 數(shù)據(jù)庫學(xué)習(xí)筆記

    sqlserver 數(shù)據(jù)庫學(xué)習(xí)筆記

    sqlserver 數(shù)據(jù)庫學(xué)習(xí)筆記,學(xué)習(xí)sqlserver的朋友可以參考下。
    2011-11-11
  • SQLSERVER的非聚集索引結(jié)構(gòu)深度理解

    SQLSERVER的非聚集索引結(jié)構(gòu)深度理解

    非聚集索引也是堆結(jié)構(gòu)?其實(shí)SQLSERVER有幾種頁面類型(數(shù)據(jù)都使用一頁一頁來存儲,就像Windows的內(nèi)存也是使用頁面來組織的)感興趣的朋友可以了解下,希望本文可以增加你們對非聚集索引結(jié)構(gòu)的理解
    2013-01-01
  • SQL Server數(shù)據(jù)復(fù)制到的Access兩步走

    SQL Server數(shù)據(jù)復(fù)制到的Access兩步走

    以下的文章主要描述的是把SQL Server數(shù)據(jù)復(fù)制到的Access數(shù)據(jù)庫中的實(shí)際操作步驟,以及對其在實(shí)際操作中要用到的代碼描述。
    2015-09-09
  • SQLServer2019安裝教程圖文詳解

    SQLServer2019安裝教程圖文詳解

    這篇文章主要介紹了SQLServer2019安裝教程圖文詳解,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-02-02
  • 談?wù)凾empdb對SQL Server性能優(yōu)化有何影響

    談?wù)凾empdb對SQL Server性能優(yōu)化有何影響

    由于tempdb是SQLServer的系統(tǒng)數(shù)據(jù)庫一直都是SQLServer的重要組成部分,用來存儲臨時對象,在數(shù)據(jù)庫中起到舉足輕重的作用,此篇文章給大家?guī)韙empdb對sql server性能優(yōu)化的影響,感興趣的朋友參考下
    2015-11-11

最新評論