Microsoft MVP성태의 닷넷 이야기
Parameters.AddWithValue 와 Parameters.Add 의 차이점이 궁금합니다. [링크 복사], [링크+제목 복사],
조회: 15797
글쓴 사람
한예지 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]

... 91  92  93  94  95  96  [97] 
NoWriterDateCnt.TitleFile(s)
30정성태12/17/200312294    답변글 [답변]: atl com에서 Window Handle 구하고 싶은데(바쁘시더라도 꼭 답변 해주세요!!)
26임영택9/15/200311413IE에서 submit 버튼을 누를때 발생하는 이벤트를 받을수 있나요?
29정성태12/17/200311432    답변글 [답변]: IE에서 submit 버튼을 누를때 발생하는 이벤트를 받을수 있나요?
24임영택9/14/200311510실행중인 DLL과 통신하는 방법?
25임영택9/15/200311650    답변글 [답변]: 자답(해결했습니다)
21박용운7/29/200311217잠긴파일에서...
22박용운7/30/200312653    답변글 왜 MoveFileEx가 먹히지를 않을까요?
23박용운7/30/200312545        답변글 [자답]
19김진호7/28/200311641atl 디버깅
20정성태7/29/200311533    답변글 [답변]: atl 디버깅
17박용운7/23/200311882[질문] 보안모듈? [1]
13박용운7/23/200312410"IE BHO 개체를 개발할 때, 인터넷 익스플로러가 아닌 탐색기에서 활성화 되는 문제 해결" 문서를 읽고...
14정성태7/23/200311262    답변글 [답변]: "IE BHO 개체를 개발할 때, 인터넷 익스플로러가 아닌 탐색기에서 활성화 되는 문제 해결" 문서를 읽고...
16박용운7/23/200311839        답변글 [답변]: [답변]: "IE BHO 개체를 개발할 때, 인터넷 익스플로러가 아닌 탐색기에서 활성화 되는 문제 해결" 문서를 읽고...
7박용운7/21/200313503HTTP 프로토콜로 통신하는법? [5]
6박용운7/21/200313881POST값을 못읽는 사이트는? [1]
1박용운7/18/200315928[질문] IWebBrowser2로 POST값 구하기 [4]파일 다운로드1
... 91  92  93  94  95  96  [97]