반응형
MS SQL에서 MD5를 사용 할 수 있는 방법 이 생겼다.아래 자료를 보자

나도 요건 펌했음

브리핑

MS SQL 서버에서 제공하지 못하는 기능을 추가하여 쿼리문만으로 처리를 하고 싶을때 외장 스토어드 프로시저를 VC++로 개발하여 추가하는 방법..
사용자가 스토어드 프로시저를 만들어 넣을 수도 있는데 왜 이런 난리브루스가 필요할까?
간혹 살다보면 MS SQL 서버에서 제공되는 기본 쿼리만으로는 해결이 안되는 문제가 있기 때문이다.. 얼마전 다음과 같은 상황이 있었다..

DB 상에서의 사용자 주민등록번호를 암호화 할 필요가 있었다.. 즉, 사용자 정보중 주민등록번호를 DB를 열어봐도 알 수 없도록 해야한다는 것이다.. 사용자가 주민등록번호를 입력하면 비교는 할 수 있돼, 푸는 방법은 없도록 암호화를 해야했으므로 해쉬가 가장 적합해보였다.. 그리고 특정 소스코드의 개입 없이 쿼리문만으로 이러한 작업들이 가능해야 했다.. 해서 웹 어플리케이션 소스를 수정해 처리하는 방식은 배제하였다.. (웹어플리케이션에 의존하지 않고 주민등록번호의 비교작업이나 등록, 점검 등의 작업을 쿼리문 만으로 할 수 있도록..)

어플리케이션의 소스코드에서 처리하는 것은 배제가 되었으므로, MS SQL이 기본으로 제공하는 CHECKSUM 함수 사용하는 것을 검토해 봤다.. 이걸로 충분히 해결이 될 것으로 기대가 되었기 때문이다.. 음.. 그런데, 약 4만개 정도의 주민등록번호로 테스트를 해본 결과 중복이 4개 정도 발생하는 것이다.. 이런, 이런.. 중복이 발생하면 안되는데..

결국, MS SQL에서 MD5를 사용할 수 있는 방법을 검색하게 되었고, 코드프로젝트 사이트에서 딱 맞는 소스코드를 찾을 수 있었다..

그런데 말이지 왜 checksum 함수는 4만개만으로도 중복이 생겼을까? 그리고 MD5는 사용자 수가 많아진다고 하더라도 중복이 생기지 않는걸 보장해줄 수 있을까?
일단은 MD5는 중복이 생기지 않을 것으로 기대를 하고 적용시키기로 했다.. 100만명쯤 되었을때도 중복이 안되야 할텐데.. 아마 안될 것이라고 생각이 든다.. P2P 프로그램 같은데서 동영상 파일의 해쉬값을 얻기 위해 사용하는거 보면 주민등록번호 길이 정도로는 중복이 안될 것 같다는 생각이 든다.. (중복이 생기면 안돼~ 다른 방법을 다시 찾아야 한단 말이지..)


정보수집 및 장비챙기기

소스코드는 코드 프로젝트 사이트에서 MD5 Hash SQL Server Extended Stored Procedure 라는 제목의 글을 참조했다.. (
http://www.codeproject.com/database/xp_md5.asp)

소스코드를 직접 수정하거나 할 경우가 아니라면 만들어 적용시키기 부분에서 처럼 사용하면 된다.. 소스코드를 직접 빌드해서 사용하려면 VC++ 6.0 with SP6, 그리고 MS SQL 서버 개발도구가 필요하다.. MS SQL 서버 설치시 옵션에서 개발도구를 체크해서 설치하면 MS SQL 서버에 관련된 개발시 필요한 헤더파일과 라이브러리 파일, 그리고 각종 샘플 소스코드 등이 아래의 위치에 설치가 된다.. (설치시 디폴트로 둔 경우 아래와 같았다..)

C:Program FilesMicrosoft SQL Server80ToolsDevTools

이 폴더 하위의 include 및 lib 폴더를 include, lib 경로에 추가한다.. (메뉴에서 Tools > Options 를 선택하면 나타나는 다이얼로그 화면에서 Directories 탭을 선택하여 include와 lib 경로를 추가하고 이 경로를 맨위로 올려둔다.. 그렇지 않으면 컴파일시 에러가 난다.. MS SQL 2000 서버와 함께 제공되는 최신의 헤더파일을 사용하여 컴파일이 될 수 있도록 이 경로를 추가하고 리스트 상에서 맨 위로 올려두어야 하는 것이다..)


만들어 적용시키기

MD5 해쉬 알고리즘 스토어드 프로시저 적용방법은 간단하다.. 위의 사이트에서 DLL 파일을 다운로드 받았거나, 소스코드를 다운로드 받아 빌드를 하여 만들어낸 DLL 파일만 있으면 된다.. 아래와 같이 3단계만 거치면 내가 만든 스토어드 프로시저를 마치 MS SQL 서버가 원래 제공했던 함수들 같이 사용할 수 있다..

1. DLL 파일을 아래 경로에 복사해 넣는다..
C:Program FilesMicrosoft SQL ServerMSSQLBinn

2. 제공되는 외장 스토어드 프로시저를 등록한다..
USE master;
EXEC sp_addextendedproc 'xp_md5', 'xp_md5.dll'

3. 좀 더 편하게 사용하기 위해 사용할 모든 데이터베이스에 아래와 같이 사용자정의 함수를 추가한다.. 즉, 새로운 데이터베이스가 생겼다면 새로 생긴 DB에 아래의 함수를 추가해 넣어야 한다.. 물론, 이 함수를 만들지 않고 등록된 스토어드 프로시져를 직접 호출해도 된다..
use 데이터베이스명
go

CREATE FUNCTION [dbo].[fn_md5] (@data TEXT)
RETURNS CHAR(32) AS
BEGIN
   DECLARE @hash CHAR(32)
   EXEC master.dbo.xp_md5 @data, -1, @hash OUTPUT
   RETURN @hash
END
go

CREATE FUNCTION [dbo].[fn_md5x] (@data IMAGE, @len INT = -1)
RETURNS CHAR(32) AS
BEGIN
   DECLARE @hash CHAR(32)
   EXEC master.dbo.xp_md5 @data, @len, @hash OUTPUT
   RETURN @hash
END
go

4. 사용방법은 다음과 같이 간단하다.. 드디어 원하는대로 쿼리문 안에서 MD5 해쉬를 사용할 수 있게 되었다.. insert, update 등 어떤 쿼리문에서도 쉽게 사용가능하다.. 대만족~
SELECT dbo.fn_md5('주민번호')
소스 대충 보니 MS SQL 서버에서 동작하는 확장 스토어드 프로시저를 DLL로 작성하는건 뭐 별거 없어 보인다.. 앞으로 필요한 함수가 있다면 만들어 넣으면 될 것 같다..

그동안 MS SQL 서버를 10년 가까이 사용해 오면서 이런 방법이 있다는 것을 이제야 알다니.. (물론, 10년전에 사용하던 MS SQL Server 6.5에도 이런게 가능했는지는 모르겠지만..)


출처 :
http://madchick.egloos.com/1254999
반응형

'DB > MS-SQL' 카테고리의 다른 글

MSSQL 혼합인증방식 설정  (0) 2010.05.06
MSSQL - 원하는 날짜를 수순대로 구하기  (0) 2010.04.12
MSSQL PAGING PROCEDURE  (0) 2010.03.12
MS-SQL IDENTIFY QUERY 정보  (0) 2010.03.05
MS-SQL 실행계획 확인방법  (0) 2010.02.26
반응형


SQL 프로시저를 생성하는 도중에 페이징이 너무 와닿지가 않았다.
공부를 많이 안했다는 증거... -_-;

자료를 찾아뒤지던 중.
아주 좋은 페이징기법인 CTE (Common Table Expression) 라는 아주 좋은 녀석을 발견했다.
마침 회사디비는 SQL 2005를 사용하고 있는터라, 매우 유용하게 사용될 듯 싶다.

 

 


1. top 키워드 이용 페이징

create procedure [dbo].[PaymentList1]

    @page int,

    @pageSize int

as

BEGIN

 

    select top (@pageSize)

            execDate, paymentID

    from tblPayment

 

    where paymentID not in (

                            select top ((@page - 1) * @pageSize) paymentID

                            from tblPayment

                                ORDER BY paymentID desc

                            )

    ORDER BY paymentID desc

end

 

2. RowCount 키워드 이용 페이징

 

create procedure [dbo].[PaymentList2]

    @page int,

    @pageSize int

as

BEGIN

    DECLARE @N1 INT, @N2 INT

    declare @lastIndex int

 

    set @N1 = ((@page - 1) * @pageSize)

    set @N2 = @pageSize

 

    SET ROWCOUNT @N1

 

    select

        @lastIndex = paymentID            -- 마지막 로우에서 반환된 값을 임시 저장합니다

    from tblPayment

    ORDER BY paymentID desc

 

    SETROWCOUNT @N2

 

    select

        execDate, paymentID

    from tblPayment

    where paymentID < @lastIndex               

 

    ORDER BY paymentID desc

end

 

 

여기까지는 MS-SQL 2000에서 보편적으로 사용하던 방식입니다.

MS-SQL 2005에는 Row_Number와 CTE(Common Table Expression)을 이용하여 간편하게 페이지을 할 수 있습니다.

 

 

3. Row_Number, CTE 이용 페이징

alter procedure [dbo].[PaymentList3]

    @page int,

    @pageSize int

as

BEGIN

    with paymentListTBL as

    (

        select Row_Number() OVER (ORDER BY paymentID desc) AS rowNum,

            execDate, paymentID

        from

            tblPayment

 

    )

 

    select * from paymentListTBL

    where rowNum between ((@page - 1) * @pageSize) + 1 and @page * @pageSize

 

end

반응형

'DB > MS-SQL' 카테고리의 다른 글

MSSQL 혼합인증방식 설정  (0) 2010.05.06
MSSQL - 원하는 날짜를 수순대로 구하기  (0) 2010.04.12
[펌] MSSQL 에서 MD5 사용하기  (0) 2010.03.17
MS-SQL IDENTIFY QUERY 정보  (0) 2010.03.05
MS-SQL 실행계획 확인방법  (0) 2010.02.26
반응형
업무중 MS-SQL 로 하다가 막힌곳에 대해 정보를 끄적거려본다.

-- > 방금한 INSERT의 IDENTIFY 정보를 확인하는 방법
SELECT @@IDENTITY

근데 저거 JAVA 코드로 적게되면은
이렇게 해야한다.

INSERT INTO TEST_TAB (VALUE) VALUES('AAA')
SELECT @@IDENTITY

근데 이방법은 좀 구린게 최초 접속한 SESSION정보가 있어야한다.

따라서 다른 SESSION에서 사용할려면 아래와 같은 방법으로 하는게 짱좋다.

SELECT    IDENT_CURRENT('test_tab') 


이렇게 채변 테이블을 구성하면 max값이 되었을때는 골때려진다.

따라서 max값이 찼을때는

1) 초기화 방법
DBCC CHECKINDENT('A',RESEED,0)
-> A Table를 identify를 0으로 초기화 한다.

2) DBCC CHECKIDENT('A',RESEED)
-> 현재 A Table의 Identify를 현재 Row수로 초기화 한다.
 현재 row가 10개 있음 10으로 초기화 한다.
반응형

'DB > MS-SQL' 카테고리의 다른 글

MSSQL 혼합인증방식 설정  (0) 2010.05.06
MSSQL - 원하는 날짜를 수순대로 구하기  (0) 2010.04.12
[펌] MSSQL 에서 MD5 사용하기  (0) 2010.03.17
MSSQL PAGING PROCEDURE  (0) 2010.03.12
MS-SQL 실행계획 확인방법  (0) 2010.02.26
반응형
쿼리문에

Set Statistics Profile ON

이렇게 해서 실행계획 ON을 켜주면 실행된다.
반응형

'DB > MS-SQL' 카테고리의 다른 글

MSSQL 혼합인증방식 설정  (0) 2010.05.06
MSSQL - 원하는 날짜를 수순대로 구하기  (0) 2010.04.12
[펌] MSSQL 에서 MD5 사용하기  (0) 2010.03.17
MSSQL PAGING PROCEDURE  (0) 2010.03.12
MS-SQL IDENTIFY QUERY 정보  (0) 2010.03.05

+ Recent posts