http://www.sqler.com/269782

안녕하세요?

MSSQL Oracle 함수를 비교하신 분들이 많은데요. 의외로 예제를 실어 놓은 곳이 거의 없더군요하여 준비해 보았습니다.

 

하지만, 한 번에 너무 많은 것을 올려놓으면 보기 힘들기에

오늘은 그 첫번째 시간으로 문자열 중 10가지만 적어봅니다.

 

1.     문자 식에서 가장 왼쪽 문자의 ASCII 코드 값 반환 (숫자로 표시됨)

구분

MSSQL

Oracle

함수

ASCII

ASCII

용례

SELECT ASCII('A')

SELECT ASCII('A') FROM DUAL

결과

65

65

è  MSSQL이든 ORacle이든 ‘’ 안에 여러 개의 문자가 있어도 가장 좌측 값만 반환합니다.

, SELECT ASCII(‘A’) SELECT ASCII(‘ABCDEFG’) 나 결과는 같습니다.

 

 

2.     문자 합치기

구분

MSSQL

Oracle

함수

+

CONCAT 또는 ||

용례

SELECT '동해물과' + '백두산이'

1. SELECT '동해물과 ' || '백두산이' FROM DUAL

2. SELECT CONCAT('동해물과 ','백두산이') FROM DUAL

결과

동해물과 백두산이

동해물과 백두산이

 

 

3.     ASCII 코드를 문자로 변환하기

구분

MSSQL

Oracle

함수

CHAR

CHR

용례

SELECT CHAR(67)

SELECT CHR(67) FROM DUAL

결과

C

C

è  참고로 9번은 TAB, 10LF(Line Feed), 13번은 CR(Carriage Return) 입니다.

 

 

4.     좌측에서 몇 번째에 해당 문자가 있는지 알려주기

구분

MSSQL

Oracle

함수

CHARINDEX

INSTR

용례

SELECT CHARINDEX('마이', '고마해라. 마이 무우따 아이가?')

SELECT INSTR('고마해라. 마이 무우따 아이가?','마이' ) FROM DUAL

결과

7

7

è  MSSQLOracle의 함수사용 순서가 다릅니다.

è  MSSQL에는 패턴찾기에 PATINDEX를 많이 사용합니다. 위와 같은 결과를 얻으려면

SELECT PATINDEX('%마이%', '고마해라. 마이 무우따 아이가?')

처럼 사용하면 됩니다.(와일드 카드 사용 가능)

 

 

5.     대문자 변환, 소문자 변환

구분

MSSQL

Oracle

함수

UPPER / LOWER

UPPER / LOWER

용례

SELECT UPPER('aBcDeF'), LOWER('aBcDeF')

SELECT UPPER('aBcDeF'), LOWER('aBcDeF') FROM DUAL

결과

ABCDEF abcdef

ABCDEF abcdef

 

 

6.     좌측공간을 특정 문자로 채워주기

구분

MSSQL

Oracle

함수

지원하지 않음(없음)

LPAD

용례

-

SELECT LPAD('13579',10, '0') FROM DUAL

결과

-

0000013579

è  MSSQL에선 없는 함수이기 때문에 아래와 같이 사용자함수를 만들어서 사용하기도 합니다.

-- 1. FUNCTION 만들기

CREATE FUNCTION dbo.UFN_LPAD

(

       @INPUT VARCHAR(8000),

       @COUNT AS INT,

       @FILLCHAR AS CHAR(1)=' '

)

RETURNS varchar(200)

AS

BEGIN

RETURN

       CASE

             WHEN LEN(@INPUT) >= @COUNT THEN LEFT(@INPUT, @COUNT)

       ELSE

             LEFT(REPLICATE(@FILLCHAR, @COUNT), @COUNT-LEN(@INPUT)) + @INPUT

       END

END

 

 

-- 2. SAMPLE

SELECT dbo.UFN_LPAD('12',10,'0') AS PR_KEY

 --> 결과

 0000000012

 

 

 

7.     우측공간을 특정 문자로 채워주기

구분

MSSQL

Oracle

함수

지원하지않음(없음)

RPAD

용례

-

SELECT RPAD('13579',10, '0') FROM DUAL

결과

-

1357900000

è  MSSQL에선 없는 함수이기 때문에 UFN_LPAD처럼 함수를 만들어서 씁니다.

다만, REPLICATE라는 함수가 있는데, 이것은 특정문자를 연속적으로 채워 줄 뿐, RPAD와는 조금 다릅니다.

-- 사용례

SELECT REPLICATE('0',10)

 --> 결과

 0000000000

   또한, SPACE라는 함수는 공백만 채워줍니다.

-- 사용례

SELECT '나의' + SPACE(10) + ''

 --> 결과

 나의        

 

 

8.     /우 공백 없애주기

구분

MSSQL

Oracle

함수

LTRIM / RTRIM

LTRIM / RTRIM

용례

SELECT LTRIM('  아버지'), RTRIM('어머니 ')

SELECT LTRIM('  아버지'), RTRIM('어머니  ') FROM DUAL

결과

아버지   어머니  à (공백제거됨)

아버지   어머니  à (공백제거됨)

 

 

9.     문자의 음성표현을 가지는 문자열을 반환. 국내에서는 흔히 사용하지 않음(한글 동작 안함)

b, f, p, v = 1

c, g, j, k, q, s, x, z = 2

l = 4

m, n = 5

r = 6

구분

MSSQL

Oracle

함수

SOUNDEX

SOUNDEX

용례

SELECT SOUNDEX ('Smith'), SOUNDEX ('Smythe');

SELECT SOUNDEX ('Smith'), SOUNDEX ('Smythe') FROM DUAL

결과

S252     S200

S530     S530

è  어라? 예제에는 같은 것으로 되어 있는데, 실제 결과는 다르네요. -_- 이것 참

 

 

10.   전체 문자열에서 지정한 길이만큼의 문자열 반환

구분

MSSQL

Oracle

함수

SUBSTRING

SUBSTR

용례

SELECT SUBSTRING('1234567890',4,5)

SELECT SUBSTR('1234567890',4,5) FROM DUAL

결과

45678

45678

è  4번째 자리에서 시작해서 다섯 글자를 가져옵니다.

 

오늘은 여기까지이고요, 조만간 2탄 올리겠습니다.

 

이상 [쓸만한게없네]였습니다.

 

SELECT Schema_name(tbl.schema_id)                                 AS [Schema],

       tbl.name,

       Coalesce((SELECT pr.name

                 FROM   sys.database_principals pr WITH (nolock)

                 WHERE  pr.principal_id = tbl.principal_id),

       Schema_name(tbl.schema_id))                                AS [Owner],

       tbl.max_column_id_used                                     AS [Columns],

       CAST(CASE idx.index_id

              WHEN 1 THEN 1

              ELSE 0

            END AS BIT)                                           AS

       [HasClusIdx],

       Coalesce((SELECT SUM (spart.ROWS)

                 FROM   sys.partitions spart WITH (nolock)

                 WHERE  spart.object_id = tbl.object_id

                        AND spart.index_id < 2), 0)               AS [RowCount],

       Coalesce((SELECT CAST(v.low / 1024.0 AS FLOAT) * SUM(a.used_pages - CASE

                                         WHEN a.TYPE <> 1 THEN a.used_pages

                                         WHEN p.index_id < 2 THEN a.data_pages

                                         ELSE 0

                                                                           END)

                 FROM   sys.indexes AS i WITH (nolock)

                        JOIN sys.partitions AS p WITH (nolock)

                          ON p.object_id = i.object_id

                             AND p.index_id = i.index_id

                        JOIN sys.allocation_units AS a WITH (nolock)

                          ON a.container_id = p.partition_id

                 WHERE  i.object_id = tbl.object_id), 0.0) / 1024 AS [IndexMB],

       Coalesce((SELECT CAST(v.low / 1024.0 AS FLOAT) * SUM(CASE

                        WHEN a.TYPE <> 1 THEN a.used_pages

                                 WHEN p.index_id < 2 THEN a.data_pages

                                 ELSE 0

                                                            END)

                 FROM   sys.indexes AS i WITH (nolock)

                        JOIN sys.partitions AS p WITH (nolock)

                          ON p.object_id = i.object_id

                             AND p.index_id = i.index_id

                        JOIN sys.allocation_units AS a WITH (nolock)

                          ON a.container_id = p.partition_id

                 WHERE  i.object_id = tbl.object_id), 0.0) / 1024 AS [DataMB],

       tbl.create_date,

       tbl.modify_date

FROM   sys.tables AS tbl WITH (nolock)

       INNER JOIN sys.indexes AS idx WITH (nolock)

         ON ( idx.object_id = tbl.object_id

              AND idx.index_id < 2 )

       INNER JOIN MASTER.dbo.spt_values v WITH (nolock)

         ON ( v.NUMBER = 1

              AND v.TYPE = 'E' )

--WHERE tbl.Name like '%tablename%' 

ORDER  BY 8 DESC



declare @dbname

sysname

set @dbname = null

if @dbname

is not null and @dbname

not in (select name from

master.dbo.sysdatabases)

 

begin

 

raiserror('You''re just one step away

from the results. please verify the database name is correct and try again. www.sqlServer-Training.com', 16,1)

end

set nocount on

if exists (select * from sysobjects where name = '#sizeinfo' and type = 'u')

 

drop table #sizeinfo

create table #sizeinfo

(

db_name varchar(100) not null primary key clustered,

total dec (7, 1),

data dec (7, 1),

data_used dec (7, 1),

[data (%)] dec (7, 1),

data_free dec (7, 1),

[data_free (%)]

dec (7, 1),

log dec (7, 1),

log_used dec (7, 1),

[log (%)] dec (7, 1),

log_free dec (7, 1),

[log_free (%)]

dec (7, 1),

status dec (7, 1)

)

set nocount on

insert

#sizeinfo ( db_name, log, [log (%)] , status

) exec ('dbcc sqlperf(logspace)

with no_infomsgs')

print '' print ''

if @dbname

is null

 

declare dbname cursor for select name from master.dbo.sysdatabases where

not status

& 32 = 32

and not status & 512

= 512 order

by name asc

else if @dbname is not null

begin

delete from

#sizeinfo where db_name <>

@dbname

 

declare dbname cursor for select name from master.dbo.sysdatabases where

not status

& 32 = 32

and not status & 512

= 512 and

name =

@dbname

end

open

dbname

fetch next from dbname

into @dbname

while @@fetch_status = 0

begin

----- adding .0 at the end of interger to avoid divide by zero error

 

exec ( ' use [' + @dbname

+ '] declare @total dec(7,1),

@data dec (7, 1),

@data_used dec (7, 1),

@data_percent dec (7, 1),

@data_free dec (7, 1),

@data_free_percent dec (7, 1),

@log dec (7, 1),

@log_used dec (7, 1),

@log_used_percent dec (7, 1),

@log_free dec (7, 1),

@log_free_percent dec (7, 1)

set @total = (select sum(convert(dec(15),size)) from sysfiles) * 8192.0 /1048576.0

set @data = (select sum(size) from sysfiles where (status & 64 = 0))* 8192.0 / 1048576.0

set @data_used = (select sum(convert(dec(15),reserved)) from sysindexes

where indid in (0, 1, 255)) * 8192.0 / 1048576.0

set

@data_percent = (@data_used * 100.0 / @data)

set @data_free = (@data - @data_used)

set @data_free_percent = (@data_free * 100.0 / @data

)

set @log = (select log from #sizeinfo where db_name = '''+@dbname+''')

set @log_used_percent = (select [log (%)] from #sizeinfo where db_name ='''+@dbname+''')

set @log_used = @log * @log_used_percent / 100.0

set @log_free = @log - @log_used

set @log_free_percent =@log_free * 100.0 / @log

update #sizeinfo set total = @total,

 

data = @data ,

data_used = @data_used,

[data (%)] = @data_percent,

data_free = @data_free,

[data_free (%)] = @data_free_percent,

log_used = @log_used,

log_free = @log_free,

[log_free (%)] = @log_free_percent

where db_name = '''+@dbname+'''' )

 

fetch next from dbname

into @dbname

end

close

dbname

deallocate

dbname

if ((select count(*) from #sizeinfo

) <> 1)

select @@servername as

'ServerName',db_name, total, data, data_used, [data (%)], data_free, [data_free (%)],

log,

log_used, [log (%)], log_free,

[log_free (%)]

 

from #sizeinfo order by db_name asc

else

select @@servername as

'ServerName',db_name, total, data, data_used, [data (%)], data_free, [data_free (%)],

log,

log_used, [log (%)], log_free,

[log_free (%)]

 

from #sizeinfo

drop table #sizeinfo

-- MERGE INTO TEST

C REATE TABLE MERGE_TEST

(INT1 INT,

INT2 INT,

VAL VARCHAR(100) )

 

MERGE INTO MERGE_TEST MG

USING (SELECT 1 AS INT1, 1 AS INT2, 'AAA' AS VAL) A

ON (MG.INT1 = A.INT1 AND MG.INT2 = A.INT2)

WHEN MATCHED THEN

       UPDATE SET

             VAL = A.VAL

WHEN NOT MATCHED THEN

       INSERT

       (INT1, INT2, VAL)

       VALUES

       (A.INT1, A.INT2, A.VAL)

;

 

SELECT * FROM MERGE_TEST;

 

INT1        INT2        VAL

----------- ----------- -------------------------------------------

1           1           AAA

 

(1 적용됨)

 

 

 

MERGE INTO MERGE_TEST MG

USING (SELECT 1 AS INT1, 1 AS INT2, 'BBB' AS VAL) A

ON (MG.INT1 = A.INT1 AND MG.INT2 = A.INT2)

WHEN MATCHED THEN

       UPDATE SET

             VAL = A.VAL

WHEN NOT MATCHED THEN

       INSERT

       (INT1, INT2, VAL)

       VALUES

       (A.INT1, A.INT2, A.VAL)

;

 

SELECT * FROM MERGE_TEST;

INT1        INT2        VAL

----------- ----------- -------------------------------------------

1           1           BBB

 

(1 적용됨)


+ Recent posts