Microsoft MVP성태의 닷넷 이야기
Parameters.AddWithValue 와 Parameters.Add 의 차이점이 궁금합니다. [링크 복사], [링크+제목 복사],
조회: 14684
글쓴 사람
한예지 donator
홈페이지
첨부 파일
 

선생님 안녕하세요!

Parameters.AddWithValue("@ID", 1)
Parameters.Add("@ID", SqlDbType.Int, 4).Value = 1

AddWithValue와 Add의 차이점을 아래와 같이 이해해도 괜찮을까요?...

① Add 함수는 varchar 열인 경우에 데이터의 길이와 타입을 명시함으로서 사용자 입력을
엄격히 제한할 수 있다.
② AddWithValue 함수는 데이터를 (암시적 형변환을 통해) nvarchar 형태로 DB로 보낸다.

혹시 선생님은 어떤 경우에는 AddWithValue를 사용하고 어떤 경우에는 Add를 사용한다는 기준이 있으신가요?








[최초 등록일: ]
[최종 수정일: 1/25/2021]


비밀번호

댓글 작성자
 



2021-01-25 06시56분
대략 그렇게 이해하시면 됩니다. 단지 2번의 경우 nvarchar로 고정된 것은 아니고, 대상 칼럼의 타입에 변환이 되는 모든 타입을 허용합니다. 따라서 런타임 시에 nvarchar도 가능하고 varchar도 가능하다는 식의 좀 더 세세한 차이점은 있습니다.

사용은 개인 취향일 수 있습니다. (제 경우에는 명확하게 지정하는 Add를 더 선호합니다.)

Difference between Parameters.Add(string, object) and Parameters.AddWithValue
; https://stackoverflow.com/questions/9999751/difference-between-parameters-addstring-object-and-parameters-addwithvalue
정성태
2021-01-25 12시26분
[예지] 답변 감사합니다!!
[guest]

NoWriterDateCnt.TitleFile(s)