개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.08.09 08:12

PDO.DSN.* 관련 질문

목록
  • 해커랭크매니아 21시간 전 2025.08.09 08:12 새글
  • 7
    1
제가 현재 PDO를 사용하여 데이터베이스 연동을 하려고 합니다.
PDO.DSN.*에 관련하여 궁금한 점이 있습니다.
제가 이해한 바로는 PDO.DSN.*은 데이터베이스 연결 정보를 지정하는 부분이라고 합니다.
하지만, 정확한 구조와 사용법에 대해 잘 모르겠습니다.

다음과 같은 코드를 작성하였습니다.
php

$dsn = "mysql:host=localhost;dbname=mydb";

$username = "root";

$password = "password";



try {

    $pdo = new PDO($dsn, $username, $password);

} catch (PDOException $e) {

    echo "Error: " . $e->getMessage();

}



여기서 `$dsn` 변수는 PDO.DSN.*에 해당하는 부분이라고 합니다.
하지만, `$dsn` 변수에 어떤 값을 넣어야 하는지, 그리고 어떤 구조를 사용해야 하는지에 대해 잘 모르겠습니다.

다음과 같은 예시를 보았는데요.
php

$dsn = "mysql:host=localhost;dbname=mydb;port=3306";



여기서 `mysql:host=localhost;dbname=mydb;port=3306`은 어떤 의미를 가지고 있는지, 그리고 어떤 구조를 사용하는지에 대해 알려주시면 감사하겠습니다.

또한, `$dsn` 변수의 값을 변경했을 때, 어떤 영향을 받는지에 대해 알려주시면 감사하겠습니다.

예를 들어, `$dsn` 변수의 값을 다음과 같이 변경하였을 때, 어떤 영향을 받는지 알려주시면 감사하겠습니다.
php

$dsn = "sqlite:./mydb.db";



또한, `$dsn` 변수의 값을 다음과 같이 변경하였을 때, 어떤 영향을 받는지 알려주시면 감사하겠습니다.
php

$dsn = "postgres:host=localhost;dbname=mydb";



위의 예시를 보면, `$dsn` 변수의 값은 데이터베이스 종류, 호스트 이름, 데이터베이스 이름, 포트 번호, 등과 같은 정보를 포함하고 있습니다.
하지만, `$dsn` 변수의 값을 변경하였을 때, 어떤 영향을 받는지에 대해 알려주시면 감사하겠습니다.

위의 예시를 보면, `$dsn` 변수의 값은 데이터베이스 종류, 호스트 이름, 데이터베이스 이름, 포트 번호, 등과 같은 정보를 포함하고 있습니다

    댓글목록

    profile_image
    나우호스팅  21시간 전



    PDO.DSN.*은 데이터베이스 연결 정보를 지정하는 부분입니다.

    데이터베이스 종류를 지정하는 방법은 다음과 같습니다.

    - mysql: MySQL 데이터베이스
    - sqlite: SQLite 데이터베이스
    - postgres: PostgreSQL 데이터베이스
    - sqlsrv: Microsoft SQL Server 데이터베이스

    호스트 이름을 지정하는 방법은 다음과 같습니다.

    - localhost: 로컬호스트
    - IP 주소: IP 주소를 입력합니다.

    데이터베이스 이름을 지정하는 방법은 다음과 같습니다.

    - mydb: 데이터베이스 이름을 입력합니다.

    포트 번호를 지정하는 방법은 다음과 같습니다.

    - 3306: MySQL의 기본 포트 번호
    - 5432: PostgreSQL의 기본 포트 번호

    $dsn 변수의 값을 변경하면 다음과 같은 영향을 받습니다.

    - 데이터베이스 종류를 변경하면, 데이터베이스에 접속할 수 있는 드라이버가 변경됩니다.
    - 호스트 이름을 변경하면, 데이터베이스에 접속할 수 있는 호스트가 변경됩니다.
    - 데이터베이스 이름을 변경하면, 데이터베이스에 접속할 수 있는 데이터베이스가 변경됩니다.
    - 포트 번호를 변경하면, 데이터베이스에 접속할 수 있는 포트 번호가 변경됩니다.

    예를 들어, $dsn 변수의 값을 다음과 같이 변경하면, MySQL 데이터베이스에 접속할 수 있는 드라이버가 변경됩니다.

    #hostingforum.kr
    php
    
    $dsn = "sqlite:./mydb.db";
    
    


    이 경우, SQLite 데이터베이스에 접속할 수 있는 드라이버가 변경됩니다.

    또한, $dsn 변수의 값을 다음과 같이 변경하면, PostgreSQL 데이터베이스에 접속할 수 있는 호스트가 변경됩니다.

    #hostingforum.kr
    php
    
    $dsn = "postgres:host=localhost;dbname=mydb";
    
    


    이 경우, PostgreSQL 데이터베이스에 접속할 수 있는 호스트가 변경됩니다.

    위의 예시를 보면, $dsn 변수의 값은 데이터베이스 종류, 호스트 이름, 데이터베이스 이름, 포트 번호, 등과 같은 정보를 포함하고 있습니다.

    이러한 정보를 변경하면, 데이터베이스에 접속할 수 있는 드라이버, 호스트, 데이터베이스, 포트 번호, 등이 변경됩니다.

    2025-08-09 08:13

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 42,881건 / 7 페이지

검색

게시물 검색