>데이터 베이스 >MySQL 튜토리얼 >MySQL을 사용하도록 Django를 구성하는 방법은 무엇입니까?

MySQL을 사용하도록 Django를 구성하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-30 11:43:101022검색

How to Configure Django to Use MySQL?

Django와 함께 MySQL 사용

Python 기반 웹 개발에서 Django는 웹 애플리케이션의 다양한 측면을 관리하기 위한 포괄적인 프레임워크를 제공합니다. 데이터베이스 관리와 관련하여 Django는 MySQL을 지원합니다. MySQL과 함께 작동하도록 Django를 설정하는 방법은 다음과 같습니다.

MySQL 구성

Django와 MySQL 간의 연결을 설정하려면 Django 내에 있는 settings.py 파일을 수정해야 합니다. 프로젝트 디렉토리. DATABASES 사전 내에서 다음과 같이 항목을 정의합니다.

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql', 
        'NAME': 'DB_NAME',
        'USER': 'DB_USER',
        'PASSWORD': 'DB_PASSWORD',
        'HOST': 'localhost',   # Or an IP Address that your DB is hosted on
        'PORT': '3306',
    }
}

여기서 'DB_NAME'을 MySQL 데이터베이스 이름으로 바꾸고, 'DB_USER'를 적절한 사용자 이름으로, 'DB_PASSWORD'를 해당 비밀번호로 바꿉니다. 'localhost'를 MySQL 서버의 IP 주소로 바꿉니다(동일한 시스템에서 실행 중인 경우 'localhost'로 변경).

테스트하기 runserver

연결을 확인하려면 다음 명령을 실행할 수 있습니다.

python manage.py runserver

이 명령은 기본적으로 localhost에서 애플리케이션에 액세스할 수 있는 개발 서버를 시작합니다.

로컬 호스트 문제

'python Manage.py runserver myip:port'를 실행할 때만 애플리케이션이 작동하는 경우 다음을 나타낼 수 있습니다. Django가 지정된 IP 및 포트에서 실행되도록 올바르게 구성되지 않았습니다. 필요한 IP 및 포트에서 액세스할 수 있도록 settings.py에서 ALLOWED_HOSTS 설정을 올바르게 수정했는지 확인하세요.

프로덕션에 배포

애플리케이션을 배포할 준비가 되면 다음을 권장합니다. 'python Manage.py runserver'에 의존하는 대신 프로덕션 환경에 적합한 서버 구성을 사용합니다. djangobook에서 Django 배포에 대한 자세한 지침을 확인할 수 있습니다.

UTF-8 문자 집합

MySQL의 기본 문자 집합은 UTF-8이 아닐 수 있습니다. 로컬 컴퓨터에서 테스트하는 동안 다음을 사용하여 데이터베이스를 생성하는 것을 고려하세요.

CREATE DATABASE mydatabase CHARACTER SET utf8 COLLATE utf8_bin

MySql 커넥터

Oracle의 MySQL 커넥터를 사용하는 경우 settings.py의 'ENGINE' 줄이 다음을 반영하는지 확인하세요. 다음:

'ENGINE': 'mysql.connector.django',

추가 참고사항

  • 활용하려면 Django 1.7에서는 MySQL 옵션 파일을 지원하므로 위의 DATABASES 항목을 'OPTIONS' 사전이 포함된 항목으로 바꿉니다.
  • 운영 체제에 MySQL을 설치하는 것을 잊지 마세요. 예를 들어 macOS에서는 'brew install mysql'을 사용할 수 있습니다.
  • Python 3의 경우 'pip3 install mysqlclient'를 사용하여 필수 MySQL 클라이언트 패키지를 설치합니다.

위 내용은 MySQL을 사용하도록 Django를 구성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.