当前位置: 首页 > news >正文

Python Django 连接 PostgreSQL 操作实例

159bea4cac9b19705f6955b1ddde44dd.jpeg

更多Python学习内容:ipengtao.com

大家好,我是彭涛,今天为大家分享 Python Django 连接 PostgreSQL 操作实例,全文3500字,阅读大约10分钟

在Web开发中,使用Django连接到PostgreSQL数据库是一种常见的选择。本文将详细介绍如何在Django项目中连接到PostgreSQL数据库,并提供丰富的示例代码。

安装必要的库

首先,确保已经安装了Django和psycopg2库,它是Django连接PostgreSQL所需的驱动。

pip install Django psycopg2

配置数据库连接

在Django项目的settings.py文件中,配置数据库连接信息,将ENGINE设置为django.db.backends.postgresql, 并填写NAME, USER, PASSWORD, HOSTPORT等信息。

# settings.pyDATABASES = {'default': {'ENGINE': 'django.db.backends.postgresql','NAME': 'your_database_name','USER': 'your_database_user','PASSWORD': 'your_database_password','HOST': 'localhost','PORT': '5432',}
}

创建并应用迁移

运行以下命令,创建数据库迁移并应用。

python manage.py makemigrations
python manage.py migrate

定义模型

创建一个简单的模型,以演示数据库操作。

# models.pyfrom django.db import modelsclass Book(models.Model):title = models.CharField(max_length=100)author = models.CharField(max_length=50)def __str__(self):return self.title

进行数据库操作

在Django shell中,演示如何进行数据库操作。

python manage.py shell
# 在Django shell中# 导入模型
from your_app.models import Book# 创建新书
new_book = Book(title='Django Essentials', author='John Doe')
new_book.save()# 查询所有书籍
all_books = Book.objects.all()
print(all_books)

Django视图和模板

在Django项目中创建视图和模板,以展示从数据库中检索数据的方式。

# views.pyfrom django.shortcuts import render
from .models import Bookdef book_list(request):books = Book.objects.all()return render(request, 'book_list.html', {'books': books})
<!-- book_list.html -->{% extends 'base.html' %}{% block content %}<h2>Book List</h2><ul>{% for book in books %}<li>{{ book.title }} by {{ book.author }}</li>{% endfor %}</ul>
{% endblock %}

运行Django服务器

最后,运行Django开发服务器并查看连接到PostgreSQL的Web页面。

python manage.py runserver

访问http://127.0.0.1:8000/,查看包含数据库中书籍信息的页面。

数据库迁移和更改模型

在实际开发中,可能需要对模型进行更改。演示如何通过数据库迁移来处理模型变更。

# models.pyfrom django.db import modelsclass Book(models.Model):title = models.CharField(max_length=100)author = models.CharField(max_length=50)published_date = models.DateField()def __str__(self):return self.title

运行以下命令进行迁移:

python manage.py makemigrations
python manage.py migrate

Django管理后台

使用Django自带的管理后台,轻松管理数据库记录。

# admin.pyfrom django.contrib import admin
from .models import Bookadmin.site.register(Book)

运行服务器,访问http://127.0.0.1:8000/admin/,使用创建的超级用户账号登录,即可管理数据库中的书籍记录。

Django表单和视图

展示如何使用Django表单和视图来实现用户添加书籍的功能。

# forms.pyfrom django import forms
from .models import Bookclass BookForm(forms.ModelForm):class Meta:model = Bookfields = ['title', 'author', 'published_date']
# views.pyfrom django.shortcuts import render, redirect
from .models import Book
from .forms import BookFormdef add_book(request):if request.method == 'POST':form = BookForm(request.POST)if form.is_valid():form.save()return redirect('book_list')else:form = BookForm()return render(request, 'add_book.html', {'form': form})
<!-- add_book.html -->{% extends 'base.html' %}{% block content %}<h2>Add Book</h2><form method="post">{% csrf_token %}{{ form.as_p }}<button type="submit">Add Book</button></form>
{% endblock %}

urls.py中添加新的URL模式,使用户能够访问添加书籍的页面。

# urls.pyfrom django.urls import path
from .views import book_list, add_bookurlpatterns = [path('books/', book_list, name='book_list'),path('add_book/', add_book, name='add_book'),
]

总结

在本文中,深入研究了如何在Django项目中连接到PostgreSQL数据库,并提供了详尽的示例代码,覆盖了从配置数据库连接到实现基本的Web应用功能的全过程。首先,介绍了安装必要的库,包括Django和psycopg2,并详细说明了在settings.py中配置数据库连接的步骤。

接着,创建了一个简单的模型,展示了如何使用Django的迁移系统来初始化和更新数据库结构。通过在Django shell中演示数据库操作,大家可以清晰了解如何进行常见的增删改查操作。还深入探讨了Django的视图、模板和管理后台的使用,演示了如何以用户友好的方式展示和管理数据库中的数据。此外,引入了Django表单和视图的概念,展示了如何通过表单让用户添加新的数据库记录。

总体而言,本文提供了一个全面而详实的教程,适用于初学者和有一定经验的开发者。通过这些示例,大家将获得在Django中连接和操作PostgreSQL数据库的实际经验,为构建功能齐全的Web应用奠定了坚实的基础。

如果你觉得文章还不错,请大家 点赞、分享、留言 下,因为这将是我持续输出更多优质文章的最强动力!

更多Python学习内容:ipengtao.com

干货笔记整理

  100个爬虫常见问题.pdf ,太全了!

Python 自动化运维 100个常见问题.pdf

Python Web 开发常见的100个问题.pdf

124个Python案例,完整源代码!

PYTHON 3.10中文版官方文档

耗时三个月整理的《Python之路2.0.pdf》开放下载

最经典的编程教材《Think Python》开源中文版.PDF下载

58f11e9d26335cc9abf0dce7fcf82fc2.png

点击“阅读原文”,获取更多学习内容

相关文章:

  • 【Linux基础命令使用】
  • Elasticsearch的使用总结
  • React Hooks解决了什么问题?
  • 2020-XNUCA babyv8
  • 机器学习算法---聚类
  • Spring Boot中实现订单30分钟自动取消的策略
  • PDF如何转换制作成翻页电子书
  • 【数据结构—队列的实现】
  • LeedCode刷题---滑动窗口问题(二)
  • 华为OD机试 - 员工派遣(Java JS Python C)
  • pytorch——支持向量机
  • 自然语言处理阅读第二弹
  • 京微齐力:基于H7的平衡控制系统(一、姿态解析)
  • Kafka本地安装⭐️(Windows)并测试生产消息以及消费消息的可用性
  • Nginx location+Nginx rewrite(重写)(新版)
  • SegmentFault for Android 3.0 发布
  • 《用数据讲故事》作者Cole N. Knaflic:消除一切无效的图表
  • 【跃迁之路】【641天】程序员高效学习方法论探索系列(实验阶段398-2018.11.14)...
  • android图片蒙层
  • es的写入过程
  • JavaScript设计模式之工厂模式
  • Laravel深入学习6 - 应用体系结构:解耦事件处理器
  • mysql常用命令汇总
  • storm drpc实例
  • WordPress 获取当前文章下的所有附件/获取指定ID文章的附件(图片、文件、视频)...
  • 短视频宝贝=慢?阿里巴巴工程师这样秒开短视频
  • 工作手记之html2canvas使用概述
  • 译自由幺半群
  • 用jquery写贪吃蛇
  • 中文输入法与React文本输入框的问题与解决方案
  • k8s使用glusterfs实现动态持久化存储
  • Nginx惊现漏洞 百万网站面临“拖库”风险
  • 宾利慕尚创始人典藏版国内首秀,2025年前实现全系车型电动化 | 2019上海车展 ...
  • 大数据全解:定义、价值及挑战
  • ​比特币大跌的 2 个原因
  • (02)vite环境变量配置
  • (23)Linux的软硬连接
  • (zt)基于Facebook和Flash平台的应用架构解析
  • (八)Flask之app.route装饰器函数的参数
  • (二)什么是Vite——Vite 和 Webpack 区别(冷启动)
  • (非本人原创)我们工作到底是为了什么?​——HP大中华区总裁孙振耀退休感言(r4笔记第60天)...
  • (附源码)计算机毕业设计SSM在线影视购票系统
  • (强烈推荐)移动端音视频从零到上手(下)
  • (三)c52学习之旅-点亮LED灯
  • (收藏)Git和Repo扫盲——如何取得Android源代码
  • (转)Oracle存储过程编写经验和优化措施
  • .net wcf memory gates checking failed
  • .NET 使用 ILRepack 合并多个程序集(替代 ILMerge),避免引入额外的依赖
  • .php文件都打不开,打不开php文件怎么办
  • @Valid和@NotNull字段校验使用
  • [20161214]如何确定dbid.txt
  • [51nod1610]路径计数
  • [8] CUDA之向量点乘和矩阵乘法
  • [Angular] 笔记 7:模块
  • [Avalon] Avalon中的Conditional Formatting.