django ORM入门
简单总结一下迟老师今天下午上课时讲的ORM操作
目录:
一、首先配置django连接mysql数据库
在项目(projet)的setting中进行设置。比如我的项目叫做myApp,打开
myApp/myApp/setting.py
找到下面这段代码,进行配置:
代码在这:
# Database
# https://docs.djangoproject.com/en/2.0/ref/settings/#databases DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',#数据库引擎
'NAME': 'aisystem',#已经建好的数据库名
'USER':'root',#连接mysql的用户名
'PASSWORD':'',#连接密码
'HOST':'127.0.0.1',#设置localhost,如果不是远程的数据库都是这个
'PORT':#在安装mysql的时候设置的端口,没有修改的默认都是3306
}
}
mysql配置
二、在自己创建的app中添加一个model
比如我添加的app叫做 userManage,所以在这里添加一个model:
打开 myApp/myApp/userManage/models.py,添加一个model:
代码在这里:
class TUser(models.Model):
#主键
userId = models.AutoField(primary_key=True,unique=True)#自增 唯一
#用户名
username=models.CharField(max_length=)
#密码
password=models.CharField(max_length=)
TUser
三、利用django生成表
首先执行:
python manage.py makemigrations
可以看到创建TUser成功:
这时候项目目录中应该生成一个叫做migrations的文件夹
然后写入数据库,执行命令:
python manage.py migrate
出现很多ok,我的由于不是第一次写入数据库,所有只有几个
在数据库中可以看到一个叫做tuser的表
四、利用model进行增删改查的操作
首先在数据库中增加两条数据备用:
4.1 实现登陆验证
我们修改login中的代码,实现登陆验证,如果用户名、密码匹配则跳转到首页。否则重新登陆
然后我们开启服务器:
python manage.py runserver
打开登陆页:127.0.0.1:8080/user/login。登陆一下
当输入正确的用户名、密码是,跳转到127.0.0.1/user/index,显示欢迎
当输入错误的用户名或密码,提示错误
4.2操作数据库
为了说明model的用法,我们不考虑逻辑。直接在userManage中增加一个/test,说明一下model的其他常用函数。
首先在userManage/urls中增加一个映射:
path('test/',views.test)
然后再userMange/views中增加一个test方法,直接返回一个渲染的模板。
再在userManage/templates中新建一个名为test.html的文件。
接下来我们慢慢修改这些内容
4.2.1查询数据库中全部内容
修改 userManage/videws.py的test方法:
通过 objects.all方法读取一个表中的全部内容,通过render把参数传递给test.html
然后修改test.html,显示users的内容。
打开test查看一下效果
4.2.2增加一条记录
修改test方法
自己打开test查看结果吧。然后到数据库中可以看到确实增加了一条记录。
4.2.3删除一条记录
访问test将会删除admin用户
4.2.4修改一条记录
可以到数据库或者登陆页面验证小明的密码被修改为2了
这样增删改查的内容就全部介绍完了。当然这只是一种实现方式。还有其它的实现方法,包括但不限于执行sql语句。留给大家自己探索了。
五、作业
给大家重复一下作业:
时间:4月15日-5月5日。
作业内容:实现一个web端文章的管理系统,可以对文章进行增、删、改、查、保存。
检查方式:5月5日课上检查完成情况。
完不成会怎样:我也不知道。但是相信大家经过两天的学习,应该没问题的。实在写不完又被检查到了的话,表演个小节目吧。所以要么抽空写一下作业,要么抽空练练技能。
django ORM入门的更多相关文章
- Django ORM模型
Object Relational Mapping(ORM) 一,ORM介绍 1, ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象 ...
- day 67 django orm的基础
django项目 安装: 创建项目 配置(setting,static,csrf) 创建app,python manage.py startapp app1 三部分 urls.py路由配置 1,普通正 ...
- Django ORM介绍 和字段及字段参数
Object Relational Mapping(ORM) ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据 ...
- Django ORM字段和字段参数
Object Relational Mapping(ORM) ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据 ...
- Django orm常用字段和字段参数
1.Object Relational Mapping(ORM) 1.1ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象 ...
- django orm介绍以及字段和参数
Object Relational Mapping (ORM) orm介绍 orm概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数 ...
- django ORM教程(转载)
Django中ORM介绍和字段及字段参数 Object Relational Mapping(ORM) ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简 ...
- django orm总结[转载]
django orm总结[转载] 转载地址: http://www.cnblogs.com/linjiqin/archive/2014/07/01/3817954.html 目录1.1.1 生成查询1 ...
- Django ORM - 001 - 外键表查询主表信息
开始用Django做web开发,我想大家都会遇到同样的问题,那就是如何高效快速的查询需要的数据,MVC都很简单,但是ORM折腾起来就有些费时间,我准备好好研究下Django ORM,所以会有一个系列的 ...
随机推荐
- 用ElasticSearch存储日志
介绍 如果你使用elasticsearch来存储你的日志,本文给你提供一些做法和建议. 如果你想从多台主机向elasticsearch汇集日志,你有以下多种选择: Graylog2 安装在一台中心机上 ...
- 对于“Newtonsoft.Json”已拥有为“NETStander.Library”定义的依赖项,解决办法
问题描述: 在使用visual studio中的NuGet包管理下载程序时,有时会出现-对于“Newtonsoft.Json”已拥有为“NETStander.Library”定义的依赖项,这样的错误. ...
- 【Java】解析Java对XML的操作
目录结构: contents structure [+] 什么是XML 解析XML 使用DOM解析 使用SAX解析 使用PULL解析 使用dom4j解析xml dom4j的部分API 打印一个XML文 ...
- 【MySQL】MySQL的常规操作
MySQL的常规知识 标准的SQL语句通常可分为如下的几种类型: 1,DCL(Database Control Language) :数据控制语言,主要由grant和revoke关键字组成. 2.DD ...
- Mac Vim 编辑器
1.常用命令 /xxx 查找xxx n 执行上一次查找 0 到行首 w 光标往后移动一个词 b 光标往前移动一个词 x 删除当前一个字符 dw 删除一个单词 D 删除到行尾 dd 删除整行 V 选中整 ...
- mysql开发常用小结
1.时间转换 时间戳转时间 FROM_UNIXTIME 比如 FROM_UNIXTIME(1449480551/1000,'%Y-%m-%d %H:%i:%s') 如果是精确到毫秒的时间戳,则必 ...
- mysqldump: Couldn't execute 'SET OPTION SQL_QUOTE_SHOW_CREATE=1'
源码安装的mysql数据库,在执行mysqldump的时候报错: # mysqldump -u root -p --all-databases > dbdump.db Enter passwor ...
- appium简明教程(8)——那些工具
那片笑声让我想起我的那些tool 在我生命每个角落静静为我开着 我曾以为我会永远守在她身旁 今天我们已经离去在人海茫茫 她们都老了吧 都更新换代了吧 幸运的是我曾陪她们开发 啦…… 想她 啦…… 她还 ...
- Fix SharePoint 2013 Site in Read only mode after an interrupted backup
Problem When I was backing up SharePoint Site Collection Automatically with PowerShell and Windows T ...
- python标准库介绍——34 commands 模块详解
==commands 模块== (只用于 Unix) ``commands`` 模块包含一些用于执行外部命令的函数. [Example 3-7 #eg-3-7] 展示了这个模块. ====Exampl ...