django 卸载mysql_Django实现简单的用户添加、删除、修改等功能

本文介绍了Django中处理用户添加、删除、修改功能的实现,包括静态文件配置、form表单提交、后端接收POST数据的方法。同时,讲解了Django连接MySQL数据库的步骤,数据库迁移命令以及ORM的初步知识,最后展示了用户注册功能的简单实现。
摘要由CSDN通过智能技术生成

一. Django必要的知识点补充

1. templates和static文件夹及其配置

1.1 templates文件夹

所有的HTML文件默认都放在templates文件夹下。

1.2 static文件夹

所有的静态文件(css,js,前端第三方类库)默认都放在static文件夹下。我们需要手动创建static文件夹(跟app处于同级目录,每个app文件夹里面也可以有自己的static文件夹),然后里面再建两个文件夹:css和js)。

首先HTML页面访问外部资源有两个方式,一是cdn,二是本地。当我们服务端用的本地的时候,客户端是访问不到的(如果说本地静态文件夹路径是D:\mydjango/static,客户端访问时可能就会变成127.0.0.1/8080/mydjango/static,自然是访问不到。)

为了让客户端能访问到静态文件(比如我们用本地导入的Bootstrap),我们需要修改Django的settings.py:

1. 拉到settings.py最下面

406737e14e07660d42a812693823a52d.png

2. 在其下面添加STATICFILES_DIRS = [ ],里面存放静态文件夹的路径。

STATIC_URL = '/static/'

#接口前缀,规定了你HTML界面导入静态文件的路径前缀,/变量名/:变量名随意取#但默认情况下接口前缀跟文件夹名字一样

#静态文件设置

STATICFILES_DIRS =[#静态文件夹路径,可以有多个,因为每个app也可以有自己的static文件夹

os.path.join(BASE_DIR, 'static')

]#暴露给外界,能够访问服务器静态文件下所有的资源#STATICFILES_DIRS里面可以写多个静态文件夹的路径#浏览器访问时会依次从静态文件夹路径查找资源,找到就停止,如果都没找到就报错,

3. 将HTML文件中导入静态文件的地方路径也稍作修改,路径开始都换成接口前缀,后面跟static文件下你要导入的文件的相对路径即可。

1f0c1e6244723306673c8c712b76769a.png

2. 关于form表单提交数据

2.1 提交数据的两种方式

第一种:submit

第二种:button按钮

button

2.2 form表单提交数据的地址指定方式

首先地址是由action属性来控制的。

第一种方式:全路径

第二种方式:只写路径后缀(浏览器会自动拿当前页面的host、ip帮你补全路径)

第三种方式:不写,默认是提交至当前页面。

注意:form表单默认是GET请求,需要向后端提交form表单数据时,我们需要通过method属性改为POST。

单单这样还不够,为了POST请求不报错,我们需要先将Django的settings.py中注释掉一个中间件。

c68c9255cf7af7b0cd6c8da267359c89.png

如果不注释的话可能会出现以下问题:

361f1f2e0a27b7f1a806c3276ecc8da5.png

3. 后端获取前端数据的方法

首先我们需要能够判断浏览器是单纯想获取页面信息还是有数据提交给我们。这就需要用到request.method方法,它能获取当前客户端的请求方式(GET、POST)。

deflogin(request):print(request.method)if request.method == 'POST':print(request.POST) #可以看做是存放客户端POST请求提交的所有数据的字典{key:value}

#request.POST:< QueryDict: {'username': ['jason'], 'password': ['123']} >

print(request.POST.get('username')) #虽然value是列表,但是默认取其中的最后一个数据

print(request.POST['username']) #拿到的也同.get一样,不推荐使用该方法获取数据

print(request.POST.getlist('username')) #一次性获取value列表所有数据

return HttpResponse('OK')print(request.GET) #跟request.POST获取数据方式一样

return render(request, 'login.html')

注意:获取value列表里面所有元素需要使用getlist,应用场景:用户的爱好--多选框

get只能拿到value列表的最后一个元素。前端GET请求最多携带数据为4KB。

还有一点要提的是,不论你的请求方式是GET或者是POST,只要你的路径携带了信息,后端都可以通过request.GET来得到(比如:127..0.1:8080/index/?id=1,我们可以通过request.GET.get('id')拿到id)。这就意味着前端请求方式是POST得时候,后端也是可以通过request.GET来得到消息,举个实例。

当我们一些数据想要给后端,但是又不想让其显示在前端界面的时候,有两种方式可以实现。

方式一:将id放在form表单action的URL后面

方式二:利用input隐藏

二. Django连接数据库

Django的settings.py里面提供了连接数据库的入口,要实现连接不同的数据库,只要修改其中的参数等信息即可。

1. sqlite3数据库

是Django自带的一个小型数据库,可以用来做本地测试,如果数据量不大的话。

6ab1b36d4cb17d04fbb3a67a7a8f8eb9.png

2. 连接MySQL数据库

1. 修改配置文件

修改上述DATABASES中的参数(键必须都是大写)

8a3fa44d1678c6922dd9a37794470dcc.png

2. 告诉django用pymysql替换它默认的mysql_db模块连接数据库

因为mysql_db现在已经没用了,所以需要替换模块。

在项目文件夹下的__init__.py或者是应用文件夹下的__init__.py中加入以下语句。

#加下列语句,固定写法

importpymysql

pymysql.install_as_MySQLdb()

3. 点击pycharm右侧的database,选择要连接的数据库

ccb41b51810f70adb7a6c68b8a90a1bb.png

4. 最后一步准备

ead7e2086463033350cad10bd35b0658.png

这样数据库就成功连接上了,如果中途没出现什么意外的话。

89779f372af49b080eb709f9e9aa685f.png

3. 数据库迁移(同步)命令

Django的ORM虽然不会自动帮我们创建库,但是会帮我们自动创建表,然而创建的过程还是需要我们配合的,并非全自动。

还需要在命令行窗口(比如pycharm里的terminal)输入以下命令:

python3 manage.py makemigrations #数据库变动的记录(并不会帮你创建表)

python3 manage.py migrate #将你的数据库变动同步到数据库中(这下才是真正创建表了)

数据库迁移命令执行完毕后,表创建完成了,不过你可能会发现它帮我们创建了其他的表,不要慌,正常现象。

edebcee2acd9a7942590007b9bfdc713.png

注意:

数据库迁移记录都存放在migrations文件夹下。

tools选项中的Run manage.py Task敲命令更方便,因为有提示,而且不需要输入前面的python3 manage.py。(当然前期不推荐这么干,要不然完整命令都忘了,面试被问到了咋整)

只要修改了模型层(models.py)的与表相关的任何数据,都必须重新执行数据库迁移命令。

一个Django项目用一个库,不要多个Django项目共用一个库!!!

三. Django中的ORM(初级知识)

1. ORM概念

对象关系映射(英语:(Object Relational Mapping,简称ORM,或O/RM,或O/R mapping),是一种程序技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换。从效果上说,它其实是创建了一个可在编程语言里使用的--“虚拟对象数据库”。

在ORM中,每一个类都映射数据库中的一张表。ORM的类都写在models.py中。

类 》》》 表

对象 》》》 表记录

对象的属性 》》》一条记录某个字段对应的值

2. ORM对数据库的增删改查

操作数据库,无非就是增删改查,为了更好的演示,这里定义一个ORM类,然后假设前后端数据交互已完成,username和password均是从前端拿到的数据。

这里先提一个QuerySet对象,Django操作数据库时,查询的all()和filter()方法返回的是QuerySet对象,有点像列表里面存放一个个对象,它可以用.query的方法获取其内部的mysql语句。如果要获取数据对象的话,可以用索引取,但是不推荐这么做,因为可能会报错,通常我们用QuerySet.first()等方法取其中的数据对象。

classUser(models.Model):#user表的主键字段名就是id,其实可以不写,因为你不写时Django默认会帮你创建一个字段名为id的主键

id = models.AutoField(primary_key=True)#varchar(32) name字段是varchar(32) CharField在定义的时候必须要加max_length参数

name = models.CharField(max_length=32)#varchar(16) name字段是varchar(32) CharField在定义的时候必须要加max_length参数

password = models.CharField(max_length=16)

2.1 增

方式一:

user_obj = models.User.objects.create(name=username,

password=password) #返回当前的数据对象本身

方式二:

user_obj = models.User(name=username, password=password)

user_obj.save()#对象调用save方法保存至数据库

2.2 查

查全部数据:

user_list =models.User.objects.all()print(user_list)print(user_list.query) #只要是QuerySet对象,就能用.query获取它内部的MySQL语句

根据条件查询:

res = models.User.objects.filter(id=delete_id)

#这样回来的是QuerySet对象,如果条件不存在返回空的QuerySet对象

res = models.User.objects.filter(id=delete_id).first()

#取出里面的第一个对象,虽然可以索引取,但是不推荐使用,而起不支持负索引取值

根据条件查询直接拿一个数据对象(该方法不推荐使用,因为存在报错的情况)

res = models.User.objects.get(id=edit_id) #如果id不存在会直接报错

注意:get和filter相比,get能直接拿回一个数据对象,但是查询条件不满足时会报错。而filter查询条件满足或者不满足时返回的都是QuerySet对象,可以通过.first()、.last()取其中的数据对象,不存在报错的情况。所以一般选择用filter方法。

2.3 删

models.User.objects.filter(id=delete_id).delete()

#会将该QuerySet里面的数据对象都删除掉(会同步到数据库)

2.4 改

#方式一(推荐使用该方式):

models.User.objects.filter(id=edit_id).update(name=username, password=password)#方式二:

user_obj = models.User.objects.filter(id=edit_id).first()

user_obj.name=username

user_obj.save()

注意:QuerySet点语法,点删除和修改都会作用于对象内部所有的数据对象,类似于批量操作。

所以想要操作单个数据对象时,最好查时用能唯一标识一条数据的条件。

四. 简单实现用户的添加、删除、修改操作

现在我们数据库连接也会了,ORM也稍微知道了一点用法,就可以写一点东西来让知识点印象更深刻。

1. 用户的注册

首先思路是用户在浏览器输入用户名、密码,点注册按钮后,将输入的数据提交给后端,后端从数据库找相应的用户信息是否存在。存在则返回用户已存在,不存在则完成用户的创建并返回注册成功。

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

register

}

注册

username:

password:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值