简单总结一下迟老师今天下午上课时讲的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. Linux下网卡混杂模式设置和取消

    工作中发现一个网卡工作状态不对了,查看了一下,发现这个网卡和正常工作的网卡  信息不一样,它显示的居然是混杂模式,而正常工作的是  running 模式 ,所以来了解下混杂模式怎么取消... 下文来自 ...

  2. mysql insert if not exists防止插入重复记录的方法(转)

    MySQL 当记录不存在时插入(insert if not exists) 在 MySQL 中,插入(insert)一条记录很简单,但是一些特殊应用,在插入记录前,需要检查这条记录是否已经存在,只有当 ...

  3. jquery获取radio值

    单选组radio: $("input[@type=radio][@checked]").val(); 单选组 radio: $("input[@type=radio]&q ...

  4. PHP发送HEAD方法请求

    HEAD方法在99%的web服务中支持(不完全统计,默认都是HEAD.POST.GET,除了某些极其特殊的应用会限制HEAD方法),HEAD方法有很多用途,比如探测网页的状态(HTTP头部信息,404 ...

  5. Spring-MVC配置Gson做为Message Converter解析Json

    Spring-MVC配置Gson做为Message Converter解析Json 在学习Spring的时候看到可以使用@RequestBody 和@ResponseBody注解来是的Spring自动 ...

  6. python标准库介绍——30 code 模块详解

    ==code 模块== ``code`` 模块提供了一些用于模拟标准交互解释器行为的函数. ``compile_command`` 与内建 ``compile`` 函数行为相似, 但它会通过测试来保证 ...

  7. mac 安装配置java环境变量

    1.下载java 地址:http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html 2.选择 ...

  8. hbase ERROR: wrong number of arguments (3 for 4)

    hbase(main):036:0> get 'ddl', 'example', 'info:age'COLUMN                                         ...

  9. supervisor 完整安装步骤

    Supervisorhttp://www.jianshu.com/p/bf2b3f4dec73http://www.jianshu.com/p/9abffc905645http://blog.csdn ...

  10. Vue(七):computed计算属性

    简介 计算属性关键词: computed. 计算属性在处理一些复杂逻辑时是很有用的. 实例1 可以看下以下反转字符串的例子: <div id="app"> {{ mes ...