Django与MySQL时区问题

环境

  • windows10
  • pycharm2017.3.3 professional edition
  • python3.6.4
  • django2.0.2

问题与方法

将Django项目默认的UTC时区修改为本地时区
  • 打开Django项目的settings.py文件,修改TIME_ZONE为

    TIME_ZONE = 'Asia/Shanghai'
Django存取数据时的时区问题
  • 在数据库和Django都为本地时区时,通过Django写入数据库的数据,从数据库中看相差8个小时,显示出来也相差8个小时,这是因为Django在写入数据库时将本地时区变成了UTC时区
  • 解决方法:将settings.py文件里的

    USE_TZ = Ture

    改为

    USE_TZ = False
改动结果如图

这里写图片描述

参考文档

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Django是一个流行的Python Web框架,而MySQL是一个流行的关系型数据库管理系统。Django可以与MySQL数据库联合使用,以实现Web应用程序的数据存储和管理。下面是一些步骤: 1. 确保已经安装了MySQL数据库和Django框架,并且已经创建了Django项目。 2. 安装Python的mysqlclient模块,这是一个MySQL数据库连接器,可以通过以下命令安装: ```shell pip install mysqlclient ``` 3. 在Django项目的settings.py文件中,配置MySQL数据库的连接信息,例如: ```python DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'mydatabase', 'USER': 'mydatabaseuser', 'PASSWORD': 'mypassword', 'HOST': 'localhost', 'PORT': '3306', } } ``` 其中,'NAME'是数据库名称,'USER'和'PASSWORD'是数据库的用户名和密码,'HOST'是数据库服务器的主机名或IP地址,'PORT'是数据库服务器的端口号。 4. 在Django项目中定义模型(Model),并在模型中定义数据表的结构和字段。例如: ```python from django.db import models class Book(models.Model): title = models.CharField(max_length=100) author = models.CharField(max_length=50) pub_date = models.DateField() price = models.DecimalField(max_digits=5, decimal_places=2) ``` 这个模型定义了一个名为Book的数据表,包含title、author、pub_date和price四个字段。 5. 在Django项目中创建数据表。可以使用以下命令: ```shell python manage.py makemigrations python manage.py migrate ``` 第一条命令会生成数据表的迁移文件,第二条命令会将迁移文件应用到数据库中,从而创建数据表。 6. 在Django项目中编写视图(View),并在视图中实现数据的增删改查操作。例如: ```python from django.shortcuts import render from .models import Book def book_list(request): books = Book.objects.all() return render(request, 'book_list.html', {'books': books}) def book_detail(request, pk): book = Book.objects.get(pk=pk) return render(request, 'book_detail.html', {'book': book}) def book_new(request): if request.method == "POST": form = BookForm(request.POST) if form.is_valid(): book = form.save(commit=False) book.save() return redirect('book_detail', pk=book.pk) else: form = BookForm() return render(request, 'book_edit.html', {'form': form}) def book_edit(request, pk): book = get_object_or_404(Book, pk=pk) if request.method == "POST": form = BookForm(request.POST, instance=book) if form.is_valid(): book = form.save(commit=False) book.save() return redirect('book_detail', pk=book.pk) else: form = BookForm(instance=book) return render(request, 'book_edit.html', {'form': form}) ``` 这些视图实现了书籍列表、书籍详情、新建书籍和编辑书籍等功能。 7. 在Django项目中编写模板(Template),并在模板中使用Django模板语言(DTL)来呈现数据。例如: ```html {% extends 'base.html' %} {% block content %} <h1>Book List</h1> <ul> {% for book in books %} <li><a href="{% url 'book_detail' pk=book.pk %}">{{ book.title }}</a></li> {% endfor %} </ul> {% endblock %} ``` 这个模板呈现了书籍列表,使用了DTL的for循环和url反向解析等功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值