ASP.NET에서 SQL SERVER에 대한 연결 문자열 설정


답변:


149

이것을 사용할 수도 있습니다. 더 간단합니다. 설정해야하는 유일한 것은 "YourDataBaseName"입니다.

  <connectionStrings>
    <add name="ConnStringDb1" connectionString="Data Source=localhost;Initial Catalog=YourDataBaseName;Integrated Security=True;" providerName="System.Data.SqlClient" />
  </connectionStrings>

연결 문자열 을 배치 할 위치

<?xml version='1.0' encoding='utf-8'?>  
  <configuration>  
    <connectionStrings>  
      <clear />  
      <add name="Name"   
       providerName="System.Data.ProviderName"   
       connectionString="Valid Connection String;" />  
    </connectionStrings>  
  </configuration>  

일부 쿼리를 실행하고 싶을 때 내 C # 코드에서 사용하는 방법.
Nikhil Tamhankar 2011 년

1
닷넷에서 연결 문자열에 대한 자세한 정보를 볼 수 있습니다. connectionstrings.com/sql-server-2008
Vimal bhatt

4
얼마나 많은 사람들이 그 줄을 복사해서 붙여 넣었는지 궁금하네요 ... :-)이 질문에 30 번째가 된 것 같아요 .... 그냥 마음으로 배워야 할 것 같아요.
Ayo Adesina 2015 년

이 버전에는 사용자 이름 / 암호 속성이 없습니다.
Burgi

@Burgi 아니 그것의 누락되지 않았습니다 ( Integrated Security=True? 참조 ), 데이터베이스가 권한으로 파일을 읽기 때문에 필요하지 않습니다-시도하십시오. 이것이 추가 할 필요가 없기 때문에 더 간단하다고 제가 말하는 이유입니다. 사용하지 못하면 데이터베이스를 열고 데이터베이스와 파일에 대한 올바른 권한을 설정하십시오
Aristos

107

어떤 이유로 나는 여기서 간단한 답을 보지 못합니다.

이것을 코드 맨 위에 넣으십시오.

using System.Web.Configuration;
using System.Data.SqlClient; 

이것을 Web.Config에 넣으십시오.

<connectionStrings >
    <add
         name="myConnectionString" 
         connectionString="Server=myServerAddress;Database=myDataBase;User ID=myUsername;Password=myPassword;Trusted_Connection=False;"
         providerName="System.Data.SqlClient"/>
</connectionStrings>

연결 변수를 설정하려는 위치 :

SqlConnection con = new SqlConnection(
    WebConfigurationManager.ConnectionStrings["myConnectionString"].ConnectionString);

5
WebConfigurationManager.ConnectionStrings["myConnectionString"].ConnectionString기술적으로 더 정확할 수 있습니다.
crush

2
나는 또한 필요 :using System.Data.SqlClient;
nu everest

21

나는 이것이 답을 얻기가 매우 어려웠다는 것을 알았지 만 결국 그것을 알아 냈습니다. 그래서 아래 단계를 작성하겠습니다.

  1. 코드에서 연결 문자열을 설정하기 전에 실제로 데이터베이스에 액세스 할 수 있는지 확인하십시오. SSMS (Sql Server Management Studio 또는 다른 데이터베이스와 동일)를 사용하여 데이터베이스 서버에 로컬로 로그인하여 사용하려는 세부 정보를 사용하여 액세스 할 수 있는지 확인하십시오.

  2. 다음으로 (필요한 경우) 별도의 서버에서 데이터베이스에 액세스하려는 경우 SSMS에서도 마찬가지로 수행 할 수 있는지 확인합니다. 따라서 컴퓨터에 SSMS를 설정하고 해당 데이터베이스 서버에 대한 사용자 이름과 암호를 사용하여 서버에 액세스 할 수 있는지 확인하십시오.

위의 2 가지 사항을 제대로 이해하지 못하면 데이터베이스에 액세스 할 수 없기 때문에 시간을 낭비하는 것입니다. 이는 설정 한 사용자가 잘못되었거나 원격 액세스가 활성화되지 않았거나 (필요한 경우) 포트가 열리지 않았기 (필요한 경우), 여러 다른 이유 중에서도 가장 일반적인 이유 일 수 있습니다.

SSMS를 사용하여 데이터베이스에 액세스 할 수 있는지 확인한 후. 프로세스를 자동화하고 실수를 방지하기위한 다음 단계는 시스템이 작업을 수행하도록하는 것입니다.

  1. 빈 프로젝트를 시작하고 Linq를 SQL 또는 Dataset에 추가하고 (EF는 좋지만 연결 문자열은 EF con 문자열 내부에 포함되어 있으므로 깨끗한 문자열을 원합니다) 위에서 확인한 세부 정보를 사용하여 데이터베이스에 연결합니다. 사기 문자열 위자드. 테이블을 추가하고 파일을 저장하십시오.

이제 웹 구성으로 이동하면 마술처럼 필요한 모든 세부 정보와 함께 깔끔하게 작동하는 연결 문자열이 표시됩니다.


{아래는 이전 게시물의 일부이므로 무시할 수 있습니다. 코드 뒤에있는 데이터베이스에 액세스하는 가장 기본적인 방법으로 참고 용으로 남겨 둡니다. 아래로 스크롤하여 아래 2 단계부터 계속하십시오. }

위의 단계에서 코드 뒤에있는 연결 문자열로 다음과 같이 시작한다고 가정 해 보겠습니다.

string conString = "Data Source=localhost;Initial Catalog=YourDataBaseName;Integrated Security=True;";

이 단계는 매우 중요합니다. 다음 단계를 수행하기 전에 위의 연결 문자열 형식이 작동하는지 확인하십시오. 연결 문자열을 수행하는 가장 간단한 방법이므로 테이블의 일부 데이터를 레이블이나 텍스트 boses 등으로 표시하는 일종의 SQL 명령 텍스트를 사용하여 실제로 데이터에 액세스 할 수 있는지 확인하십시오.

위의 스타일이 작동한다고 확신하면 이제 다음 단계를 수행 할 차례입니다.

1. 문자열 리터럴 (따옴표 포함 )을 web.config 파일의 다음 섹션으로 내 보냅니다 (여러 연결 문자열의 경우 여러 줄을 수행하면됩니다.

<configuration>
    <connectionStrings>
        <add name="conString" connectionString="Data Source=localhost;Initial Catalog=YourDataBaseName;Integrated Security=True;" providerName="System.Data.SqlClient" />
        <add name="conString2" connectionString="Data Source=localhost;Initial Catalog=YourDataBaseName;Integrated Security=True;" providerName="System.Data.SqlClient" />
        <add name="conString3" connectionString="Data Source=localhost;Initial Catalog=YourDataBaseName;Integrated Security=True;" providerName="System.Data.SqlClient" />
    </connectionStrings>
</configuration>

{위의 내용은 이전 게시물의 일부입니다. 상위 3 단계를 수행하면이 전체 프로세스가 완료되므로 무시해도됩니다. 내 참조를 위해 여기에 남겨 둡니다. }


2. 이제 클래스 정의 바로 아래 (즉, 메서드 내부가 아님) 뒤에있는 C # 코드에 다음 코드 줄을 추가합니다. 이것은 프로젝트의 루트 폴더를 가리 킵니다. 기본적으로 프로젝트 이름입니다. 이것은 일반적으로 web.config 파일의 위치입니다 (이 경우 내 프로젝트는 MyProject라고합니다.

static Configuration rootWebConfig = WebConfigurationManager.OpenWebConfiguration("/MyProject");

3. 이제 C # 코드 뒤에 다음 코드 줄을 추가합니다. 이렇게하면 다른 메서드에서 conString이 필요한 경우 코드 전체에서 여러 위치에서 참조 할 수있는 문자열 상수가 설정됩니다.

const string CONSTRINGNAME = "conString";

4. 다음으로 C # 코드 뒤에 다음 코드 줄을 추가합니다. 이것은 이름이 conString 인 web.config 파일에서 연결 문자열을 가져옵니다 (위의 상수에서).

ConnectionStringSettings conString = rootWebConfig.ConnectionStrings.ConnectionStrings[CONSTRINGNAME];

5. 마지막으로, 원래는 다음과 같은 코드 줄이 있었을 것입니다.

SqlConnection con = new SqlConnection(conString)

다음 코드 줄로 바꿉니다.

SqlConnection con = new SqlConnection(conString.ConnectionString)

이 5 단계를 수행하면 코드가 이전처럼 작동합니다. 연결 문자열에 문제가 있는지 또는 코드에 문제가 있는지 알 수 있도록 먼저 constring을 원래 형식으로 테스트하는 이유를 파악하십시오.

저는 C #, ASP.Net 및 SQL Server를 처음 사용합니다. 따라서이 코드를 수행하는 더 좋은 방법이있을 것이라고 확신합니다. 가능한 경우 이러한 단계를 개선하는 방법에 대한 피드백도 감사하겠습니다. 나는 이것과 같은 것을 찾아 보았지만 결국 몇 주 동안 열심히 일한 후에 그것을 알아 냈습니다. 직접 보면 더 쉬운 방법이있을 것 같습니다.

도움이 되었기를 바랍니다.


14

<configuration>노드 내에 있어야 합니다.

  <connectionStrings >
    <add name="myconnectionstring" connectionString="Server=myServerAddress;Database=myDataBase;User ID=myUsername;Password=myPassword;Trusted_Connection=False;" providerName="System.Data.SqlClient"/>
  </connectionStrings>

사이트 에는 더 많은 정보가 있습니다.


1
asp.net 4에서 일부 쿼리를 실행할 때 내 C # 코드에서 사용하는 방법
Nikhil Tamhankar 2011 년

7

WebConfig에서 연결

파일 의 <connectionStrings>요소에 연결 문자열을 추가 Web.config합니다.

<connectionStrings>
<add name="ConnectionString" connectionString="Data Source=192.168.1.25;Initial Catalog=Login;Persist Security Info=True;User ID=sa;Password=example.com"   providerName="System.Data.SqlClient" />
</connectionStrings>

Class.Cs에서

public static string ConnectionString{
get{
return ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;}
set{}

6

헤더에

using System.Configuration;

코드에서

SqlConnection conn = new SqlConnection(*ConfigurationManager.ConnectionStrings["connstrname"].ConnectionString*);

3

외부 구성 파일을 사용하여 연결 문자열 섹션을 지정하고 다음과 같이 응용 프로그램 구성 파일에서 해당 파일을 참조 할 수도 있습니다. web.config

in web.config파일 과 같이 :

<configuration>  
    <connectionStrings configSource="connections.config"/>  
</configuration>  

외부 구성 connections.config파일에는 연결 섹션이 포함됩니다.

<connectionStrings>  
  <add name="Name"   
   providerName="System.Data.ProviderName"   
   connectionString="Valid Connection String;" />  

</connectionStrings>  

외부 구성 파일의 내용을 수정해도 응용 프로그램이 다시 시작되지 않습니다 (ASP.net이 기본적으로 응용 프로그램 구성 파일을 변경하면 수행됨).


2

Web.config에 연결 문자열을 작성하려면 주어진 sting 아래에 작성하십시오.

<connectionStrings>
  <add name="Conn" connectionString="Data Source=192.168.1.25;Initial Catalog=Login;Persist Security Info=True;User ID=sa;Password=example.com"
   providerName="System.Data.SqlClient" />
 </connectionStrings>

또는

당신은 aspx.cs 파일에서 바로

SqlConnection conn = new SqlConnection("Data Source=12.16.1.25;Initial Catalog=Login;Persist Security Info=True;User ID=sa;Password=example.com");

2

이것을 web.config파일에 넣을 수 있습니다 connectionStrings.

<add name="myConnectionString" connectionString="Server=myServerAddress;Database=myDataBase;User ID=myUsername;Password=myPassword;Trusted_Connection=False;" providerName="System.Data.SqlClient"/>

2

다음 형식을 사용할 수 있습니다.

  <connectionStrings>
    <add name="ConStringBDName" connectionString="Data Source=serverpath;Initial Catalog=YourDataBaseName;Integrated Security=SSPI;" providerName="System.Data.SqlClient" />
  </connectionStrings>

아마도 당신은 web.config에서 connectionstring 태그를 <appSettings>

이것을 시도하십시오.


1

이것을 시도 할 수 있습니다. 매우 간단합니다

<connectionStrings>         
    <add name="conString" connectionString="Data Source=SQLServerAddress;Initial Catalog=YourDatabaseName; User Id=SQLServerLoginId; Password=SQLServerPassword"/>
</connectionStrings>

OP는 "web.config의 위치"를 물었습니다.
스티브 스미스

0

연결 문자열에 이것을 시도하십시오.

 Data Source=myServerAddress;Initial Catalog=myDataBase;Integrated Security=SSPI;
 User ID=myDomain\myUsername;Password=myPassword;

Stack Overflow에 오신 것을 환영합니다! 이전 질문에 대한 답변을 게시 할 때 왜 귀하의 답변이 이전 질문보다 나은지에 대한 맥락을 추가하는 것이 좋습니다. 그렇지 않으면 답변 목록 하단에서 간과 될 위험이 있습니다.
Monolo 2013

0

방금 찾았어요 !! 이 문자열 연결 을 넣고 데이터베이스를 직접 가리켜 야 합니다 . 서버에서도 마찬가지입니다.

"Provider=Microsoft.ACE.OLEDB.12.0; 
 Data Source=c:/inetpub/wwwroot/TEST/data/data.mdb;"

효과가있다!! :)



-1

내부 <connectionStrings></connectionStrings>에서 호출 된 섹션을 만든 다음 다른 연결 문자열을 추가합니다. 예를 들면web.config<configuration></configuration>

<configuration>

  <connectionStrings>
   <add name="ConnectionStringName" providerName="System.Data.SqlClient" connectionString="Data Source=.\SQLEXPRESS;Initial Catalog=DatabaseName;Integrated Security=True;MultipleActiveResultSets=True"/>
  </connectionStrings>

</configuration>

다음은 모든 다양한 연결 문자열 형식 목록입니다. https://msdn.microsoft.com/en-us/library/jj653752(v=vs.110).aspx


"web.config에 <connectionStrings> </ connectionStrings>라는 섹션을 만듭니다."-web.config의 위치는 어디입니까?
스티브 스미스

당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.