Django 连接数据库 MySQL

一、Django 连接 MySQL


修改 settings.py 文件

# 默认用的是sqlite3
# Database
# https://docs.djangoproject.com/en/4.1/ref/settings/#databases

# DATABASES = {
#     'default': {
#         'ENGINE': 'django.db.backends.sqlite3',
#         'NAME': BASE_DIR / 'db.sqlite3',
#     }
# }

# 配置文件中配置
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'xyz',
        'USER':'root',
        'PASSWORD':'root',
        'HOST':'114.116.30.138',
        'PORT':3306,
        'CHARSET':'utf8'
    }
}

 

二、导入 pymysql


django默认用的是 mysqldb 模块链接 MySQL,但是该模块的兼容性不好 需要手动改为用pymysql 连接。

在项目名下的init 或者任意的应用名下的init 文件中书写以下代码都可以

import pymysql
pymysql.install_as_MySQLdb()

安装 pymysql

pip3 install pymysql

 

三、Django ORM


ORM 是对象关系映射(英语:Object Relational Mapping,简称 ORM),是一种程序技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换。

ORM 的由来:面向对象是从软件工程基本原则(如耦合、聚合、封装)的基础上发展起来的,而关系数据库则是从数学理论发展而来的,两套理论存在显著的区别。为了解决这个不匹配的现象,对象关系映射技术应运而生。

1 app 应用下面的 models.py 文件中书写一个类

from django.db import models

# Create your models here.

# CharField    必须要指定 max_length 参数不指定会直接报错
# verbose_name 该参数是所有字段都有,用来对字段的解释

class User(models.Model):
    # id int primary_key auto_increment
    id = models.AutoField(primary_key=True,verbose_name='主键')
    # username varchar(32)
    username = models.CharField(max_length=32,verbose_name='用户名')
    password = models.CharField(max_length=64,verbose_name='密码')
    age = models.IntegerField(verbose_name='年龄')

2 数据库迁移命令 将操作记录到(migrations文件夹)中

python manage.py makemigrations

3 将操作真正的同步到数据库中

python manage.py migrate

只要修改了 models.py 中跟数据库相关的代码 就必须重新执行上述的两条命令

 

 

 4 生成许多表,而 app_user 是自己定义的

 

四、 id 字段


由于一张表中必须要有一个主键字段 并且一般情况下都叫 id字段

所以ORM 当你不定义主键字段的时候 ORM 会自动帮你创建一个名为 id主键字段

也就意味着 后续我们在创建模型表的时候,如果主键字段名没有额外的叫法,那么主键字段可以省略不写。

 

五、字段的增删改查


字段的增加
 
1 可以在终端内直接给出默认值

2 该字段可以为空(null=True)
info = models.CharField(max_length=32, verbose_name='个人简介', null=True)
3 直接给字段设置默认值(default='py')
hobby = models.CharField(max_length=32, verbose_name='兴趣爱好', default='py')

字段的修改
  • 直接修改代码,然后执行数据库迁移的两条命令即可。
字段的删除
  • 直接注释对应的字段然后执行数据库迁移的两条命令即可!执行完毕之后字段对应的数据也都没有了。
  • 注意:在操作 models.py 的时候一定要细心,千万不要注释一些字段,执行迁移命令之前最好先检查一下自己写的代码。
增加email字段(终端内直接给出默认值
 

 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


注:所有源代码均实测运行过。所有源代码均已上传CSDN,请有需要的朋友自行下载。
继承APIView和ViewSetMixin;作用也与APIView基本类似,提供了身份认证、权限校验、流量管理等。ViewSet在开发接口中不经常用。
一、Django介绍Python下有许多款不同的 Web 框架。Django是重量级选手中最有代表性的一位。许多成功的网站和APP都基于Django。Django 是一个开放源代码的 Web 应用框架,由 Python 写成。Django 遵守 BSD 版权,初次发布于 2005 年 7 月, 并于 2008 年 9 月发布了第一个正式版本 1.0 。Django学习线路Django 采用了 MVT 的软件设计模式,即模型(Model),视图(View)和模板(Template)。这个MVT模式并
本文从nginx快速掌握到使用,gunicorn快速掌握到使用,实现小白快速搭建django项目,并对可能出现的报错进行了分析
uniapp微信小程序订阅消息发送服务通知
Django终端打印SQL语句 1 Setting配置: 2 默认python 使用的MysqlDB连接,Python3 支持支持pymysql 所有需要在app里面的__init__加上下面配置:
url: re_path('authors/$', views.AuthorView.as_view()), re_path('book/(?P\d+)/$', vie
前提 关于html寻找路线: template 如果在各个APP中存在, Django 会优先找全局template 文件下的html文件,如果全局下的template文件没有相关的html Djan
// GET请求request.GET // POST请求request.POST // 处理文件上传请求request.FILES // 处理如checkbox等多选 接受列表request.get
from bs4 import BeautifulSoup#kindeditordef kindeditor(request): s = ''' <li><s
view.py 配置 html 配置
from django.http import JsonResponse JsonResponse 里面代码会加这一个响应头 kwargs.setdefault('content_type&#
#下面两种是基于QuerySet查询 也就是说SQL中用的jion连表的方式查询books = models.UserInfo.objects.all() print(type(books)) &gt
return HttpResponse("OK") 返回一个字符串 return redirect("/index/") 返回URL return render
from django.http import JsonResponse JsonResponse 里面代码会加这一个响应头 kwargs.setdefault('content_type&#
浏览器有一个很重要的概念——同源策略(Same-Origin Policy)。所谓同源是指,域名,协议,端口相同。不同源的客户端脚本(javascript、ActionScript)在没明确授权的情况
自动发送 > 依赖jQuery文件 实例-->GET请求: 手动发送 > 依赖浏览器XML对象(也叫原生ajax) Ajax主要就是使用 【XmlHttpRequest】对象来完成请
#下面两种是基于QuerySet查询 也就是说SQL中用的jion连表的方式查询books = models.UserInfo.objects.all() print(type(books)) &gt
// GET请求request.GET // POST请求request.POST // 处理文件上传请求request.FILES // 处理如checkbox等多选 接受列表request.get
return HttpResponse("OK") 返回一个字符串 return redirect("/index/") 返回URL return render