标签:mys object 终端 post请求 更新 init var info 对象
ORM即Object Relational Mapping,全称对象关系映射。
如果连接的是pycharm默认的Sqlite,不用改动,使用默认配置即可
如果连接mysql,需要在配置文件中的setting中进行配置:
将DATABASES={} 更新为
DATABASES = { ‘default‘: { ‘ENGINE‘: ‘django.db.backends.mysql‘, ‘HOST‘: ‘127.0.0.1‘, ‘PORT‘: 3306, ‘USER‘: ‘root‘, ‘PASSWORD‘: ‘pie123‘, ‘NAME‘: ‘test_database‘, } }
同时还要在__init__.py文件中进行初始化设置:
import pymysql pymysql.install_as_MySQLdb()
配置完以后,要进行数据迁移(在pycharm的终端Terminal中运行指令),否则数据更新不能同步到mysql数据库中
python manage.py makemigrations ----记录数据库的变化,在migrations文件中可以看到记录
python manage.py migrate ----将变化同步到数据库中
或者
菜单 tools--->Run manage.py Task,即可进入manage.py,直接输入以下指令即可
makemigrations ----记录数据库的变化,在migrations文件中可以看到记录
migrate ----将变化同步到数据库中
? 只能创建数据表和字段,不能创建数据库(必须手动创建数据库)
? 创建一个类就表示创建了一个数据表,类中的属性表示数据表中的字段
创建表和字段在modules.py中
类 ---> 数据表
属性 ---> 字段
# 类必须继承models.Model类,否则只表示一个普通的类 # AutoField 自动增长的int类型 # primary_key=True 该字段是主键 # CharField(max_length=32) 表示 varchar(32) class User(models.Model): id = models.AutoField(primary_key=True) name = models.CharField(max_length=32) password = models.CharField(max_length=32) address = models.CharField(max_length=32)
在增删改以后都要进行数据迁移
直接在创建表的类中添加一个属性,即增加一个字段,然后执行数据迁移
添加的字段必须有默认值,两种方式
phone=models.CharField(max_length=64,default=‘120‘)
将类中的属性注释,即表示删除字段,执行数据迁移
直接修改类中的属性,执行数据库迁移命令
得到的是queryset对象(类似于列表),列表中一个个对象[user1, user2, user3]
res = models.User.objects.all()
返回页面,将queryset对象(类似于列表)res返回到userlist.html页面的user_list
render(request, ‘userlist.html‘, {‘user_list‘: res})
{% for user in user_list %} # 要循环的内容,下面的插值表达式表示获取每一个user的name的数据 {{user.name}} {% endfor%}
通过get发送请求,会将数据暴露出来,例如id就会显示http://127.0.0.1:8000/deleteuser/?id=1
前台get方式提交的数据,后台从request.GET字典里取值:
id = request.GET.get(‘id‘) # 推荐使用,即使没有接收到数据也会有默认值,不会抛出异常 或者 id = request.GET[‘id‘] # 该方式要是没有接收到数据会出现异常
前台post方式提交的数据,后台从request.POST字典里取值:
name = request.POST.get(‘name‘)
先过滤找到指定数据,然后调用方法delete()删除该数据
# 返回值是影响的行数 res = models.User.objects.filter(id = id).delete()
两种方式:
user=models.User.objects.create(name=name,password=pwd,address=addr)
user = models.User(name=name, password=password, address=addr)
user.save()
先过滤找到要修改的数据记录,然后调用update()方法修改数据
models.User.objects.filter(id = id).update(name=name,password=password,age=age)
由于过滤到的所有数据可能是多条数据,所以要用first()来取出第一条
浏览器 ---> web服务器 ---> 路由匹配 ----> 视图函数 ---> 操作模板和数据
Django框架(三)-- orm增删改查、Django生命周期
标签:mys object 终端 post请求 更新 init var info 对象
原文地址:https://www.cnblogs.com/zhangbingsheng/p/10612079.html