한줄 메모장 응용 프로그램

시삽: 레드플러스 님 
게시판 이동:
 제목 : 테이블 및 저장 프로시저: DotNetNote.Models.Memo.sql
글번호: 5
작성자: Administrator ( 레드플러스 / redplus@live.com )
작성일: 2014/07/22 오전 7:04:06
조회수: 2625
-- Memos 테이블 설계
Create Table dbo.Memos
(
    Num Int Identity(1, 1) Primary Key,
    Name VarChar(25) Not Null,
    Email VarChar(50) Null,
    Title VarChar(150) Not Null,
    PostDate DateTime Default(GetDate()),
    PostIP VarChar(15) Null
)
Go

-- 입력 저장 프로시저 : AddMemo
Create Proc dbo.AddMemo
    @Name VarChar(25), @Email VarChar(50),
    @Title VarChar(150), @PostIP VarChar(15)
As
    Insert Into Memos
    Values(@Name, @Email, @Title, GetDate(), @PostIP)
Go

-- 출력 저장 프로시저(기본 페이징) : GetMemos
Create Proc dbo.GetMemos
As
    Select * From Memos Order By Num Desc
Go

-- 출력 저장 프로시저(고급 페이징) : GetMemos
Alter Proc dbo.GetMemos -- SQL Server 2005 전용
    @Page Int -- 몇번째 페이지 보여줄지? 0 : 1페이지, 99면 : 100페이지
As
    Select Top 10 * From Memos
    Where
        Num Not In
        (
            Select Top (10 * @Page) Num From Memos
            Order By Num Desc
        )
    Order By Num Desc
Go

-- 출력 저장 프로시저(고급 페이징) : GetMemos : 동적 쿼리문
Alter Proc dbo.GetMemos -- SQL Server 2000에서 사용한다면...
    @Page Int
As
    Declare @strSql VarChar(500)
    Set @strSql = '
        Select Top 10 * From Memos
        Where
            Num Not In
            (
                Select Top ' + Cast((10 *  + @Page) As VarChar)
                    + ' Num From Memos Order By Num Desc
            )
        Order By Num Desc
    '
    Exec(@strSql)
Go

-- 현재 Memos 테이블의 레코드 수 반환 : GetTotalMemo
Create Proc dbo.GetTotalMemo
As
    Select Count(*) As Total From Memos
Go

-- 메모를 검색하는 저장 프로시저
Create Proc dbo.FindMemos
    @SearchField VarChar(10),
    @SearchQuery VarChar(25)
As
    Set @SearchQuery = '%' + @SearchQuery + '%'
    Select Top 100 * From Memos
    Where
        (
            Case @SearchField
            When 'Name' Then Name
            When 'Title' Then Title
            Else @SearchQuery
            End
        )    
        Like
        @SearchQuery
    Order By Num Desc
Go

FindMemos 'Name', '홍길'
Go

-- 예시문 : 100건 데이터 입력
Declare @i Int
Set @i = 1
While @i <= 100
Begin
    Exec AddMemo '홍길동', 'h@h.com', '안녕하세요.', '127.0.0.1'

    Set @i = @i + 1
End

-- 기존 기본 페이징 : 전체 읽어다 10개만 보여준다.
Select * From Memos
Go
-- 앞으로 성능 향상 페이징 : 10개만
GetMemos 4
Go

-- 검색 결과 리스트에 따른 페이징 처리 수정

-- 검색 결과에 대한 레코드 수 반환
Create Proc dbo.GetTotalFindMemo
    @SearchField VarChar(10),
    @SearchQuery VarChar(25)    
As
    Set @SearchQuery = '%' + @SearchQuery + '%'
    Select Count(*) From Memos
    Where
        (
            Case @SearchField
            When 'Name' Then Name
            When 'Title' Then Title
            Else @SearchQuery
            End
        )    
        Like
        @SearchQuery
Go

-- 출력 저장 프로시저(고급 페이징) : GetMemos : 동적 쿼리문
Create Proc dbo.GetFindMemos -- SQL Server 2000에서 사용한다면...
    @Page Int,
    @SearchField VarChar(10),
    @SearchQuery VarChar(25)
As
    Declare @strSql VarChar(500)
    Set @strSql = '
        Select Top 10 * From Memos
        Where
            ' + @SearchField + ' Like ''%' + @SearchQuery + '%''
            And  
            Num Not In
            (
                Select Top ' + Cast((10 *  + @Page) As VarChar)
                    + ' Num From Memos Where ' + @SearchField + ' Like ''%' + @SearchQuery + '%'' Order By Num Desc
            )
        Order By Num Desc
    '
    Exec(@strSql)
Go

-- SQL 인젝션 공격 관련 읽어볼 문서
-- http://technet.microsoft.com/ko-kr/library/ms161953.aspx
 
이전 글   다음 글 삭제 수정 답변 글쓰기 리스트


관련 아티클 리스트
  제       목 파일 작성자 작성일 조회
이전글 한줄 메모장 ASP.NET MVC 버전 - Administrator 2014-07-22 2679
  데이터베이스(테이블) 및 클래스(모델) 설계 - Administrator 2014-07-22 2428
현재글 테이블 및 저장 프로시저: DotNetNote.Models.Memo.sql - Administrator 2014-07-22 2625
  DotNetNote.Models.Memo.Oracle.sql - Administrator 2014-07-22 2361
  DotNetNote.Models.Memo 클래스 - Administrator 2014-07-22 2416
다음글 한줄 메모장 소개 - Administrator 2014-07-22 2518
관련 페이지 리스트
titlenamedateview
한줄 메모장 소개 Administrator 2014-07-22 2518
데이터베이스(테이블) 및 클래스(모델) 설계 Administrator 2014-07-22 2428
테이블 및 저장 프로시저: DotNetNote.Models.Memo.sql Administrator 2014-07-22 2625
DotNetNote.Models.Memo.Oracle.sql Administrator 2014-07-22 2361
DotNetNote.Models.Memo 클래스 Administrator 2014-07-22 2416
한줄 메모장 ASP.NET MVC 버전 Administrator 2014-07-22 2679
한줄 메모장 ASP.NET Web Forms 버전 Administrator 2014-07-22 2494
 
 
 
손님 사용자 Anonymous (손님)
로그인 Home