硬杠后端(后端坑系列)——Django前

2023-01-31 00:01:26 django 系列 后端

Django是一个开放源代码的WEB应用框架,由python写成,采用了mvc的框架模式.

MVC

MVC是一种软件设计典范,用一种业务逻辑、数据、界面显示分离的方法组织代码,将业务逻辑聚集到一个部件里面,在改造和个性化定制界面及用户交互的同时,不需要重新编写业务逻辑。MVC被独特的发展起来用于映射传统的输入,处理和输出功能在一个逻辑的图形化用户界面的结构中.

M->Model(模型):是应用程序中用于处理应用程序数据逻辑的部分,通常模型对象负责在数据库中存取数据

V->View(视图):是应用程序中处理数据显示的部分,是应用程序中处理数据显示的部分

C->Controller(控制器):是应用于程序中处理用户交互的部分,通常控制器负责从视图读取数据,控制用户输入,并向模型发送数据

核心思想:解耦

优点:降低各功能模块之间的耦合性,方便变更,更容易重构代码,最大程度上实现代码的重用

MTV

有些WEB框架觉得MVC的字面意思很别扭,就给它改了一下,改成了MTV,本质其实也是MVC

M->Model(模型):负责业务对象与数据库的对象(ORM

T->Template(模板):负责如何把页面展示给用户

V->View(视图):负责业务逻辑,并在适当的时候调用Model和Template

安装

终端输入pip install DjanGo==1.11.4(不写版本默认为最新版本)

验证

进入Python环境——>>>import django   导入成功即验证成功

创建项目

创建目录——终端进入到创建的目录下,输入django-admin startproject project——目录里生成以下文件即成功

设计表结构

 在数据库中设计用来测试或使用的表就行

配置数据库(Django默认使用的是SQLite数据库)

1.在settings.py文件中,通过DATABASES选项进行数据库配置

2.配置sql

python3.x安装的是pyMysql

在__init__.py文件中写入两行代码:import pymysql

                pymysql.install_as_MySQLdb()

格式:

DATABASES = {

'default': {

'ENGINE': 'django.db.backends.mysql', # 使用的数据库类型

'NAME': '数据库名',

'USER': '用户名',

'PASSWord': '数据库密码',

'HOST': '数据库服务器ip',

'PORT': '端口'

    }

}

创建应用(在一个项目中可以创建多个应用,每个应用进行一种业务处理)

终端进入Python-Django目录下的project目录

执行python manage.py startapp myApp,然后会生成一个myApp文件夹:

激活应用

在settings.py文件中,将myApp应用加入到INSTALLED_APPS选项中

INSTALLED_APPS = [

'django.contrib.admin',

'django.contrib.auth',

'django.contrib.contenttypes',

'django.contrib.sessions',

'django.contrib.messages',

'django.contrib.staticfiles',

'myApp'

]

定义模型(在model.py文件中定义模型)

例如:

from django.db import models

 

# Create your models here.

# 一个模型就是一个表

class Grades(models.Model):

# 表中的属性

# 字符串

gname = models.CharField(max_length=20)

# 时间类型

gdate = models.DateField()

# 数字类型

ggirlnum = models.IntegerField()

gboynum = models.IntegerField()

# 布尔类型

isDelete = models.BooleanField(default=False)

 

class Students(models.Model):

sname = models.CharField(max_length=20)

sgender = models.BooleanField(default=True)

sage = models.IntegerField()

scontent = models.CharField(max_length=20)

isDelete = models.BooleanField(default=False)

# 关联外键

sgrage = models.ForeignKey("Grades", on_delete=models.CASCADE) 

说明:不需要定义主键,在生成时自动添加,并且值为自动添加

生成迁移文件

因为本来技术和经验不足,这一步对于新手来说,运气不好真的是有可能把你心态搞崩,反正我尝试了好多百度上的解决办法,都以失败而告终,最终看到一个帖子(之前看过的,忘记是哪一篇了),让我把我即将喷出的一口老血强行咽了下去?,如果出现了类似的问题,可以先百度一下,百度上有常用的办法,如果不行的话,再来尝试我看到的这个方法:

执行python manage.py makemigrations :在migrations目录下生成一个迁移文件,此时数据库中还没有生成数据库

执行python manage.py migrate:相当于执行sql语句创建数据表,如果出现:

(1)pymysql.err.OperationalError:(1045,u"Access denied for user 'root '@'localhost'(using password:No)")

原因:新版mysql使用的caching_sha2_password, 换成mysql_native-password就可以了

解决办法:更换root密码验证,在终端连接mysql,输入:mysql -u root -p XXXX,然后输入ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'XXXX';

(2)pymysql.err.ProgrammingError:(1064)(字符串转译问题)

原因:数据库版本不合适,我的是5.5,会报错

解决办法:换成5.7版本

测试数据操作

增删改查测试一下即可

启动服务器

格式:python manage.py runserver ip:port(ip可以不写,不写的话代表本机ip,端口号默认为8000)

说明:这是一个纯python写的轻量级web服务器,仅仅在开发测试中使用

 

 

 

欢迎大佬前来指正分享,本文部分内容参考他人博客,如有侵权,请联系小子!

相关文章