Microsoft MVP성태의 닷넷 이야기
SqlConnection Open()에서 에러가나면 Close()하는 시점 [링크 복사], [링크+제목 복사],
조회: 6363
글쓴 사람
SunNee Dong (clickway at naver.com)
홈페이지
첨부 파일
 

선생님, 질문 있습니다

string sQuery = "SELECT *FROM Table";

       public bool ExecuteNonQuery(string sQuery)
        {
            try
            {
                using (SqlConnection conn = new SqlConnection("server=20.10.12.71;Database=DB;User ID=user;Password=pw"))
                {
                    conn.Open();

                    SqlCommand cmd = new SqlCommand();

                    cmd.Connection = conn; <====== 1) 에러발생

                    cmd.CommandText = sQuery;

                    cmd.ExecuteNonQuery();

                    conn.Close();<======= 위에 1)에서 에러가 발생하면 conn.Close() 안될거 같음
                }
            }
            catch
            {
               conn.Close(); <======catch문에서 SqlConnection 에서 Close() 해줘야 하는거에요?
                return false;
            }
            finally
            {

            }

            return true;

        }








[최초 등록일: ]
[최종 수정일: 8/16/2024]


비밀번호

댓글 작성자
 



2024-08-16 02시54분
질문을 할 줄 아는 것은 개발 시 매우 필요한 자세이긴 합니다. 하지만, 책 한 권 정도의 공부를 통해 기본적인 것들은 먼저 알고 나서 질문하시는 것이 더 좋습니다.

가령, 위의 질문은 "using" 예약어를 알고 있었다면 필요가 없는 질문입니다.

using (C# reference)
; https://learn.microsoft.com/en-us/dotnet/csharp/language-reference/keywords/using

꼭 제 책이 아니더라도 좋으니, 기본적인 책 한 권 정도는 읽어보시고 나서 서서히 질문을 하시는 것을 권장합니다. 현재 상태로는 코딩을 하는 모든 순간이 질문이 될 수밖에 없습니다.
정성태
2024-08-16 03시50분
SqlConnection 에서 Open() 에서 에러가 나면
Try catch문에서 SqlConnection 에서 Close() 안해도 된다는 말씀이신지요?
conn.Close(); <======catch문에서 SqlConnection 에서 Close() 해줘야 하는거에요?

답변 부탁드립니다.
제가 잘몰라서..ㅠㅠ
SunNee Dong
2024-08-16 06시44분
맞습니다. using을 했으니 Close/Dispose는 자동으로 호출됩니다.
정성태

... 46  47  [48]  49  50  51  52  53  54  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
3669다비드12/18/201518045인터넷 임시파일 삭제 관련 질문. [1]
3668김치사발면12/16/201517415템플릿이 자꾸 초기화? 되버리네요 [1]
3667김치사발면12/15/201517033템플릿 설정 추가 질문 [1]파일 다운로드1
3666노태현12/15/201516414사용자별로 권한을 주고 볼 수 있는 데이터를 제한하려면 어떤 방법으로 접근하는게 좋을까요? [2]
3665김치사발면12/14/201519682C# 템플릿 설정이 이상해요ㅜㅜ [3]파일 다운로드1
3664KuLu12/10/201516658멀정하던 사이트 중 일부메뉴가 응답없음이 되어버립니다. [3]
3663Sung...12/10/201518283UWP 서버 프로그래밍 작업 중 [5]
3662Sung...12/9/201518206uwp앱에서 접속한 클라이언트 주소값을 받아서 표시하고 싶은데 어떤 메소드를 써야 할까요? [7]
3661김무진12/9/201517683Oracle 환경에서 데이터를 조회할때 한글이 ? 이렇게 표시가됩니다. [1]
3660질문자12/7/201519749OpenFileDialog 호출시 hang걸리는 문제 [4]
3659Sung...12/4/201519551UWP 앱에서 textBox로 클라에서 받은 값을 나타내고 싶은데 안되고 있습니다. [5]
3658강준12/3/201518494Visual Studio (Xamarin) vs Eclipse [2]
3656DEVY...12/1/201517808MasterPageFile 사용시 다국어 처리 질문입니다. [1]
3653DEVY...11/26/201519502ds:Signature 질문입니다. [7]
3654윤용한11/27/201519540    답변글 [답변]: ds:Signature 질문입니다. [3]
3657윤용한12/1/201521112    답변글 [답변]: ds:Signature 질문입니다. [1]
3651노태현11/20/201551903MariaDB - ASP.NET오류의 원인조차 못 찾고 있습니다.. [2]파일 다운로드2
3652노태현11/20/201519700    답변글 [답변]: MariaDB - ASP.NET오류의 원인조차 못 찾고 있습니다.. [3]
3649kokon11/17/201519052예제 파일 실행이 안 되네요 [5]
3647Sang...11/15/201517493Part 3 목차? [5]
3646힘찬도약11/13/201522862c# mscorlib System.IO IOException [8]파일 다운로드2
3644힘찬도약11/11/201521694c# user.config파일 [2]
3645spow...11/13/201518305    답변글 [답변]: c# user.config파일 - Json.NET을 이용한 설정파일 처리 [1]파일 다운로드1
3643힘찬도약11/11/201520128C# 함수의 processing time과 재호출 [14]
3642.net11/10/201519296c# 으로 작성된 com+ 에 대한 문제입니다. [2]
3641힘참도약11/9/201519094c# log file 관련해서 질문드립니다. [5]
... 46  47  [48]  49  50  51  52  53  54  55  56  57  58  59  60  ...