八月 10, 2024
摘要:在本教程中,我们将介绍如何在 Django 应用程序中集成 PostgreSQL。
目录
Django 简介
Django 是一个用 Python 编写的高级全栈开源 Web 框架,它鼓励快速开发和干净、实用的设计。
Django 处于“开箱即用”状态时,默认设置为与 SQLite 交互 - SQLite 是 Python 发行版中包含的轻量级关系数据库。因此,默认情况下,Django 会自动为您的项目创建一个 SQLite 数据库。
除了 SQLite,Django 还支持其他流行的数据库,包括 PostgreSQL、MySQL 和 Oracle。
但是,PostgreSQL 具有许多 Django 支持的其他数据库不具备的功能,这使得它成为生产中 Django 应用程序的理想选择。
在虚拟环境中安装 Django
首先,请确保已安装了 Python 3。
现在,我们必须设置一个虚拟环境。这非常重要,因为您正在构建一个巨大的应用程序,并且您不希望各种组件的各种版本相互冲突。
在命令提示符中输入以下内容,以安装 virtualenv:
pip install virtualenv
使用 pip,可以通过简单的一行指令,从命令行轻松安装 Django。
进入该目录后,通过执行以下命令,创建虚拟环境:
python3 -m venv myenv
您可以为该环境指定任何您想要的名称。现在执行以下命令,来激活环境:
source myenv/bin/activate
这必须在我们在虚拟环境中安装任何应用程序之前完成。
如果虚拟环境已激活,您将在命令提示符中看到 (myenv)。要退出虚拟环境,只需键入 “deactivate”。
在虚拟环境处于活动状态的情况下,安装 Django。
pip install Django
我们还需要安装 psycopg2。psycopg2 是一个软件包,它允许 Django 使用 PostgreSQL 数据库。同样,要安装,请执行命令:
pip install psycopg2
创建新的 Django 项目
安装 Python 组件后,您现在可以创建实际的 Django 项目文件。
只要你已经有了一个项目目录,你就可以让 Django 在这里安装文件。它将使用实际代码创建一个二级目录,这是正常的,并在此目录中放置一个管理脚本。关键是你要明确指定目录,而不是让 Django 以相对于我们当前的目录创建项目:
django-admin startproject myproj ~/myprojdir
此时,您的项目目录(在此示例中为~/myprojdir
)应包含以下内容:
~/myprojdir/manage.py
:一个 Django 项目管理脚本。~/myprojdir/myproj/
:Django 项目包。这里应该会包含__init__.py
、settings.py
、urls.py
、asgi.py
和wsgi.py
文件。~/myprojdir/myenv/
:您在前面创建的虚拟环境目录。
配置 Django 数据库设置
打开项目中的settings.py
文件,并直接滚动到数据库部分,该部分应如下所示。
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}}
我们需要更改这些设置,以将我们的 PostgreSQL 集成到项目。
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.postgresql_psycopg2',
'NAME': 'mydb',
'USER': 'myuser',
'PASSWORD': 'mypass',
'HOST': 'localhost',
'PORT': '5432',
}}
让我们快速了解下这些设置:
DATABASES
- 这个常量是一个数据库连接信息的字典,它是 Django 必需的。您可以有多个连接到不同数据库的设置,但大多数时候,您只需要一个名为 default 的条目。
default
- 这是默认的数据库连接配置。您应该始终拥有一组默认的连接设置。
'ENGINE': 'django.db.backends.postgresql_psycopg2'
- 这用于告诉 Django 使用 Postgres 后端。它会使用psycopg2
驱动,这是我们前面安装的 Python 的 Postgres 库。
'NAME': 'mydb'
- 要连接到的数据库的名称。
'USER': 'myuser'
- 有权访问数据库的用户。
'PASSWORD': 'mypass'
- 数据库用户的密码。
'HOST': 'localhost'
- 要连接到的数据库服务器的地址。
'PORT': '5432'
- 您要连接的端口,默认为 “5432”。
测试您的项目
此外,您现在可以创建一个超级用户,以登录到管理员操作面板。
python3 manage.py createsuperuser
系统将提示您提供登录凭据。
现在一切都已设置好了,通过运行 Django 开发服务器,来测试您的数据库是否正在运行。
python3 manage.py runserver 0.0.0.0:8000
在您的 Web 浏览器中,访问您服务器的域名或 IP 地址,后面跟上:8000
:
http://server_domain_or_IP:8000
你应该会进入到默认的 Django 主页:
如果在地址栏将/admin
附加到 URL 的末尾,系统将提示您输入使用createsuperuser
命令创建的管理用户名和密码:
身份验证后,您可以访问默认的 Django 管理界面:
完成探索后,可在终端窗口中按 CTRL-C 以关闭开发服务器。