Django框架数据库(mysql)存储时间DateTimeField的用法

本文介绍了在Django中如何使用DateTimeField高效存储和处理时间数据,包括自动设置时间和时区调整,以及字段获取和常见操作方法。

前言

        在数据库中存储时间虽然用字符串或者分下来用数字存储就可以解决问题,但是这样要么就是存储空间浪费,要么就是对于时间的运算操作效率很低。而数据库本身就自带了专门存储时间的类型,那在Django框架下如何用数据库存储时间数据呢?

        在mysql里面有个datetime类型,在Django的ORM语言里面对应的类是DateTimieField

        下面就来介绍它的使用方法。

一、存储一个时间数据

首先,声明方式:

    createDate = models.DateTimeField(auto_now_add = True)

 那这个createDate字段的类型就是datetime类型。

这里创建的时候有两个参数auto_now_addauto_now,它们默认都是False,他们的区别如下:

  • 设置为true时,能够在保存该字段时,将其值设置为当前时间,并且每次修改model,都会自动更新。因此这个参数在需要存储“最后修改时间”的场景下,十分方便。需要注意的是,设置该参数为true时,并不简单地意味着字段的默认值为当前时间,而是指字段会被“强制”更新到当前时间,你无法程序中手动为字段赋值;如果使用django自带的admin管理器,那么该字段在admin中是只读的。
  • 设置为true时,auto_now_add会在model对象第一次被创建时,将字段的值设置为创建时的时间,以后修改对象时,字段的值不会再更新。该属性通常被用在存储“创建时间”的场景下。与auto_now类似,auto_now_add也具有强制性,一旦被设置为True,就无法在程序中手动为字段赋值,在admin中字段也会成为只读的。

有一点要注意的是,auto_now_add默认是UTC(可以查看settings.py内TIME_ZONE的设置)时间,即国际标准时间我们是东8区,所以看到的是比当前时间要晚8个小时。这个问题的解决办法是:

settings.py中修改:

TIME_ZONE = 'Asia/Shanghai'
这样存入的时间就是东8区的时间了。

然后就是存储一个数据的时候,因为之前设置了auto_now_add =True,所以我们设置的时候设置属性为None即可:

 然后看看后台:

 没有问题。

二、DateTimeField类型字段数据的获取和常用使用方法

它的用法就和python的datetime类似。

我们可以获取一个记录看看:        

 运行的结果是:

那用法就和datetime.datetime一样了

print("年:"+str(obj.createTime.year)+"月:"+str(obj.createTime.month)+"日:"+str(obj.createTime.day)+"时:"+str(obj.createTime.hour)+"分:"+str(obj.createTime.minute)+"秒:"+str(obj.createTime.second))

结果:

 

总结:

Python和Django真好用。

 

 

        

 

<think>好的,我现在需要帮助用户了解如何将微信小程序的表单数据通过Django存储MySQL数据库。首先,我得理清楚整个流程,确保步骤正确且易于理解。 用户可能已经具备一些基础知识,但可能需要从零开始的指导。我应该分步骤讲解,从环境准备到代码实现,每个环节都要详细说明。 首先,Django项目的创建和配置是关键。用户需要安装DjangoMySQL的驱动,比如mysqlclient。然后,创建模型(Model)来定义数据库结构。这部分需要解释模型类如何对应数据库表,字段类型的选择,以及迁移命令的使用。 接下来是API接口的开发。用户需要在Django中创建视图(View)来处理POST请求,这里可能需要使用Django REST框架来简化操作,尤其是序列化器的部分。同时,要提到跨域问题,因为微信小程序的请求可能会被Django的安全设置拦截,需要配置CORS中间件。 然后是微信小程序端的代码,如何发送网络请求到Django后端。需要给出示例代码,说明使用wx.request方法,并处理成功和失败的情况。同时,要提醒用户注意小程序的域名白名单设置,确保后端地址被允许。 数据库连接配置部分,用户需要在Django的settings.py中设置MySQL的连接参数,包括数据库名称、用户、密码、主机和端口。这里要强调正确填写信息,以及安装必要的库。 测试环节也很重要,用户需要学会使用工具如Postman测试API,再在小程序端进行集成测试。同时,要提到查看数据库确认数据是否存储成功。 可能遇到的问题包括跨域错误、数据库连接失败、字段不匹配等,需要给出排查建议,比如检查CORS配置、数据库权限、模型与请求数据的一致性。 最后,总结整个流程,确保用户有一个清晰的步骤概览。同时,提供扩展学习的建议,如Django REST框架、安全措施和性能优化,帮助用户进一步深入。 整个过程中,要使用清晰的中文,避免专业术语堆砌,适当拆分段落,保持可读性。代码示例要正确,并符合之前提到的LaTeX格式要求,行内公式用$...$,独立公式用$$...$$,但在这个问题中可能代码示例较多,需要注意格式正确。</think>将微信小程序的表单数据通过Django存储MySQL数据库的实现流程如下: 一、环境准备 1. 安装依赖库 $$ pip install django mysqlclient django-cors-headers $$ 2. 创建Django项目和应用 $$ django-admin startproject myproject $$ $$ cd myproject && python manage.py startapp myapp $$ 二、数据库配置(settings.py) ```python DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'mydatabase', 'USER': 'root', 'PASSWORD': 'yourpassword', 'HOST': 'localhost', 'PORT': '3306', } } ``` 三、创建数据模型(models.py) ```python class FormData(models.Model): name = models.CharField(max_length=100) email = models.EmailField() content = models.TextField() created_at = models.DateTimeField(auto_now_add=True) ``` 执行迁移命令: $$ python manage.py makemigrations $$ $$ python manage.py migrate $$ 四、创建API接口 1. 序列化器(serializers.py) ```python from rest_framework import serializers from .models import FormData class FormDataSerializer(serializers.ModelSerializer): class Meta: model = FormData fields = '__all__' ``` 2. 视图(views.py) ```python from rest_framework.decorators import api_view from rest_framework.response import Response from .serializers import FormDataSerializer @api_view(['POST']) def submit_form(request): serializer = FormDataSerializer(data=request.data) if serializer.is_valid(): serializer.save() return Response({"status": "success", "data": serializer.data}) return Response({"status": "error", "errors": serializer.errors}) ``` 3. 路由配置(urls.py) ```python from django.urls import path from . import views urlpatterns = [ path('submit/', views.submit_form, name='submit-form'), ] ``` 五、小程序端请求示例 ```javascript wx.request({ url: 'https://yourdomain.com/submit/', method: 'POST', data: { name: '张三', email: 'zhangsan@example.com', content: '测试内容' }, success(res) { console.log('提交成功', res.data) }, fail(err) { console.error('提交失败', err) } }) ``` 六、安全配置 1. 关闭CSRF验证(临时方案) ```python # views.py from django.views.decorators.csrf import csrf_exempt @csrf_exempt @api_view(['POST']) def submit_form(request): # ...原有代码... ``` 2. 配置CORS(推荐) ```python # settings.py INSTALLED_APPS = [ ..., 'corsheaders' ] MIDDLEWARE = [ ..., 'corsheaders.middleware.CorsMiddleware' ] CORS_ORIGIN_WHITELIST = [ 'https://your-weapp-domain.com' ] ``` 七、验证数据存储 1. 使用MySQL客户端查询 ```sql SELECT * FROM myapp_formdata; ``` 2. Django管理后台查看 $$ python manage.py createsuperuser $$ 注册模型到admin.py: ```python from .models import FormData admin.site.register(FormData) ``` 常见问题排查: 1. 连接数据库失败:检查MySQL服务状态和用户权限 2. 413错误:调整Nginx配置`client_max_body_size` 3. 跨域问题:确保CORS配置正确 4. 字段类型不匹配:检查模型定义与请求数据格式 扩展建议: 1. 添加数据验证逻辑 2. 实现JWT身份验证 3. 添加速率限制 4. 使用Django信号处理后续操作 完整技术栈关系图: 微信小程序(前端) → HTTPS → Nginx(反向代理) → Django(后端) → MySQL数据库
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

咖啡咖_CoffCa

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值