简单总结一下迟老师今天下午上课时讲的ORM操作

目录:

一、首先配置django连接mysql数据库

                                            二、在自己创建的app中添加一个model

                                            三、利用django生成表

                                            四、利用model进行增删改查的操作

                                            五、作业

一、首先配置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入门的更多相关文章

  1. Django ORM模型

    Object Relational Mapping(ORM) 一,ORM介绍 1, ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象 ...

  2. day 67 django orm的基础

    django项目 安装: 创建项目 配置(setting,static,csrf) 创建app,python manage.py startapp app1 三部分 urls.py路由配置 1,普通正 ...

  3. Django ORM介绍 和字段及字段参数

    Object Relational Mapping(ORM) ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据 ...

  4. Django ORM字段和字段参数

    Object Relational Mapping(ORM) ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据 ...

  5. Django orm常用字段和字段参数

    1.Object Relational Mapping(ORM) 1.1ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象 ...

  6. django orm介绍以及字段和参数

    Object Relational Mapping (ORM) orm介绍 orm概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数 ...

  7. django ORM教程(转载)

    Django中ORM介绍和字段及字段参数   Object Relational Mapping(ORM) ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简 ...

  8. django orm总结[转载]

    django orm总结[转载] 转载地址: http://www.cnblogs.com/linjiqin/archive/2014/07/01/3817954.html 目录1.1.1 生成查询1 ...

  9. Django ORM - 001 - 外键表查询主表信息

    开始用Django做web开发,我想大家都会遇到同样的问题,那就是如何高效快速的查询需要的数据,MVC都很简单,但是ORM折腾起来就有些费时间,我准备好好研究下Django ORM,所以会有一个系列的 ...

随机推荐

  1. zabbix v3.0安装部署

    这篇文章没有写明init的部分要注意 zabbix v3.0安装部署 摘要: 本文的安装过程摘自http://www.ttlsa.com/以及http://b.lifec-inc.com ,和站长凉白 ...

  2. “医疗信息化行业之中的联发科”- 我们在医疗行业中的定位及目标 想做一个面对中小企业的专业上游软件供应商 台湾联发科技颠覆掉的是一个封闭的手机产业系统 解决方案,即AgileHIS.NET数字化医院基础方案

    “医疗信息化行业之中的联发科”- 我们在医疗行业中的定位及目标   我们做中国医疗信息化行业之中的联发科 ---我们在医疗行业中的定位及目标 从我个人来讲,我从2001年到现在这10年之间基本上一直在 ...

  3. linux达人养成计划学习笔记(五)—— 关机和重启命令

    一.shutdown 1.格式: shutdown [选项] 时间(now) 选项: -c: 取消前一个关机命令 -h: 关机 -r: 重启 2.程序放入后台执行: shutdown -r 时间 &a ...

  4. Ubuntu菜鸟入门(十四)—— 设置root密码

    sudo su - 输入你的账户的密码 passwd 输入新的root密码 再次输入新的root密码

  5. 基于matplotlib的数据可视化 - 柱状图bar

    柱状图bar 柱状图常用表现形式为: plt.bar(水平坐标数组,高度数组,宽度比例,ec=勾边色,c=填充色,label=图例标签) 注:当高度值为负数时,柱形向下 1 语法 bar(*args, ...

  6. [aaronyang原创] Mssql 一张表3列的sql面试题,看你sql学的怎么样

    文章已经迁移到:http://www.ayjs.net/post/99.html 文章已经迁移到:http://www.ayjs.net/post/99.html 文章已经迁移到:http://www ...

  7. 简单获取cpu使用率,以及后台运行的问题

    做了一个运维平台,有一个功能定时执行一个脚本,获取cpu使用率和内存使用情况到监控平台. 获取cpu使用率使用的是top中的信息.直接运行没有问题.通过nohup xxx.sh & 之后获取不 ...

  8. cent os 6.5 配置vsftpd

    1. 下载vsftpd: #yum –y install vsftpd 2. 关闭iptables 查看防火墙状态:/etc/init.d/iptables status 关闭:service ipt ...

  9. Keepalived介绍以及在Linux系统下的安装与配置

    一.简介 Keepalived是一个免费开源的,用C编写的类似于layer3, 4 & 7交换机制软件,具备我们平时说的第3层.第4层和第7层交换机的功能.主要提供loadbalancing( ...

  10. Window 7 + Ubuntu 双系统安装

    硬件: ThinkPad X260 i5-6200U/8G/480G 当前系统: Window 7 旗舰版 64位 下载 Ubuntu 官网 下载桌面版,当前 Ubuntu 版本为:16.04 镜像安 ...