一、数据库连接配置

  • 如果连接的是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文件中进行初始化设置:

# 因为django默认链接mysql数据库,用的是MySQLdb模块,python3.0以后,不支持MySQLdb,需要用pymysql替换MySQLdb
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 ----将变化同步到数据库中

显示没有提交到数据库的数据

python3 manage.py showmigrations  ---->查看那个没有提交到数据库

二、orm创建表和字段

1、orm的使用限制

只能创建数据表和字段不能创建数据库(必须手动创建数据库)

​ 创建一个类就表示创建了一个数据表,类中的属性表示数据表中的字段

创建表和字段在modules.py中

类 --->  数据表
属性 ---> 字段

2、orm创建表和字段

在app的 models.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)

三、单表增删改查

1、增加数据

(1)方式一

# 直接创建数据,返回值是一个对象
book = models.Book.objects.create(name='西游记',price=50.5)
print(book.name)

(2)方式二

book = models.Book.objects.filter(name='西游记').first()
book.delete()

3、修改数据

(1)方式一

models.Book.objects.filter(name='西游记').update(name='红楼梦')

(2)方式二

对象没有update方法,可以利用对象获取它的属性,来修改数据,改完后要保存

book = models.Book.objects.filter(name='西游记').first()
book.name = '红楼梦'
book.save()

4、查询数据

# 调用queryset对象的query可以查看对应的sql语句
res = models.Book.objects.all()
print(res.query)

(1)查询数据API

# 1. all():                  查询所有结果
res = models.Book.objects.all() # 2. filter(**kwargs): 它包含了与所给筛选条件相匹配的对象,用逗号分隔,他们之间是and的关系
res = models.Book.objects.filter(name='西游记',price='') # 3. get(**kwargs): 返回与所给筛选条件相匹配的对象,返回结果有且只有一个,如果符合筛选条件的对象超过一个或者没有都会抛出错误。
res = models.Book.objects.filter(id=1) # 4. exclude(**kwargs): 它包含了与所给筛选条件不匹配的对象,用逗号分隔,他们之间是and的关系
res = models.Book.objects.exclude(name='西游记',price='23.8') # 5. order_by(*field): 对查询结果排序('-id'),字段名钱前加 “-” 表示从大到小排序
res = models.Book.objects.all().order_by('price')
res = models.Book.objects.all().order_by('-price') # 6. reverse(): 对查询结果反向排序,一定要先排序才能反向排序
res = models.Book.objects.all().order_by('-price').reverse() # 7. count(): 返回数据库中匹配查询(QuerySet)的对象数量。
res = models.Book.objects.all().filter(name='西游记').count() # 8. first(): 返回第一条记录
res = models.Book.objects.all().first() # 9. last(): 返回最后一条记录
res = models.Book.objects.all().last() # 10. exists(): 如果QuerySet包含数据,就返回True,否则返回False
res = models.Book.objects.filter(name='三国演义').exists() # 11. values(*field): 返回一个ValueQuerySet——一个特殊的QuerySet,运行后得到的并不是一系列,model的实例化对象,而是一个可迭代的字典序列
res = models.Book.objects.all().values('name','price')
# 返回值为QuerySet对象<{name='红楼梦',price=18},{name='西游记',price=58}> # 12. values_list(*field): 它与values()非常相似,它返回的是一个元组序列,values返回的是一个字典序列
res = models.Book.objects.all().values_lists('name','price')
# 返回值为QuerySet对象<(name='红楼梦',price=18),(name='西游记',price=58)> # 13. distinct(): 从返回结果中剔除重复纪录,只要带了id,去重就没有意义了
res = models.Book.objects.all().values('name').distinct()

(2)基于上下划线的模糊查询

# 1. __in 字段的值在其中
Book.objects.filter(price__in=[100,200,300]) # 2. __gt 字段的值大于指定值
Book.objects.filter(price__gt=100) # 3. __lt 字段的值小于指定值
Book.objects.filter(price__lt=100) # 4. __gte 字段的值大于等于指定值
Book.objects.filter(price__gte=100) # 5. __lte 字段的值小于等于指定值
Book.objects.filter(price__lte=100) # 6. __range 字段的值在指定区间内,包含头和尾
Book.objects.filter(price__range=[100,200]) # 7. __contains 字段的值包含指定值,区分大小写
Book.objects.filter(title__contains="python") # 8. __icontains 字段的值包含指定值,不区分大小写
Book.objects.filter(title__icontains="python") # 9. __startswith 字段的值以指定值开头
Book.objects.filter(title__startswith="py") # 10. __endswith 字段的值以指定值开头
Book.objects.filter(title__startswith="on") # 11. __year 日期格式的年为指定值
Book.objects.filter(pub_date__year=2012)

四、在Python脚本中调用Django环境

import os
if __name__ == '__main__':
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "untitled15.settings")
import django
# 启动Django环境
django.setup() from app01 import models books = models.Book.objects.all()
print(books)

Django框架(八)--单表增删改查,在Python脚本中调用Django环境的更多相关文章

  1. Django框架(九)—— 单表增删改查,在Python脚本中调用Django环境

    目录 单表增删改查,在Python脚本中调用Django环境 一.数据库连接配置 二.orm创建表和字段 三.单表增删改查 1.增加数据 2.删除数据 3.修改数据 4.查询数据 四.在Python脚 ...

  2. $Django 多表操作(增删改查,基于双下划线,对象的查询) 在Python脚本中调用Django环境

    在Python脚本中调用Django环境. import osif __name__ == '__main__': os.environ.setdefault("DJANGO_SETTING ...

  3. django系列5.4--ORM中执行原生SQL语句, Python脚本中调用django环境

    ORM执行原生sql语句 在模型查询API不够用的情况下,我们还可以使用原始的SQL语句进行查询. Django 提供两种方法使用原始SQL进行查询:一种是使用raw()方法,进行原始SQL查询并返回 ...

  4. Python--day69--pythonDjango终端打印SQL语句、在Python脚本中调用Django环境

    Django终端打印SQL语句 在Django项目的settings.py文件中,在最后复制粘贴如下代码: LOGGING = { 'version': 1, 'disable_existing_lo ...

  5. $Django orm增删改字段、建表 ,单表增删改查,Django请求生命周期

    1 orm介绍  ORM是什么   ORM 是 python编程语言后端web框架 Django的核心思想,“Object Relational Mapping”,即对象-关系映射,简称ORM.  一 ...

  6. Django ORM基本的单表增删改查

    创建表 步骤: 1.app下models.py里创建类(继承models.Model) from django.db import models class UserInfo(models.Model ...

  7. mysql数据库单表增删改查命令

    数据库DB-database-mysql 课程安排 第一天: 1.数据库定义以及设计 2.mysql服务端的安装 3.mysql-dos操作 库的操作 表的操作 4.mysql客户端navicate工 ...

  8. ORM之单表增删改查

    ORM之单表增删改查 在函数前,先导入要操作的数据库表模块,model from model所在的路径文件夹 import model   在views文件中,加的路径: #就一个app01功能的文件 ...

  9. MySQL初步理解,简易单表增删改查

    什么是数据库? 存储数据的仓库,本质是一个文件系统,封装了算法和文件之前数据的存储模式 阶段1:集合 数组 变量 缺点:数据存储在内存中,不能实现数据的持久化存储 阶段2:IO流 结合文件 .txt ...

随机推荐

  1. LeetCode3-Longest_Substring_Without_Repeating_Characters

    参考思路 https://github.com/azl397985856/leetcode/blob/master/problems/3.longestSubstringWithoutRepeatin ...

  2. Visualforce 页面的生命周期

    了解 Visualforce 页面的生命周期可以让我们明白其各个元素的执行顺序.改变逻辑,从而提高开发效率,避免不必要的错误. 在官方文档中有详细的讲解.本文摘取其中的要点,作为一个总结. Visua ...

  3. itsdangerous模块

    使用场景: 在取消订阅时,可以在URL里序列化并且签名一个用户的ID或在任何的激活账户的链接或类似的情形下使用.这种情况下不需要生成一个一次性的token并把它们存到数据库中. 被签名的对象可以被存入 ...

  4. asp.net core 3.0 身份认证 替换为自已的提供程序 AuthenticationStateProvider replace to SelfAuthenticationStateProvider

    public void ConfigureServices(IServiceCollection services) { // 添加身份验证服务 services.AddAuthorizationCo ...

  5. Beta冲刺(6/7)——2019.5.28

    作业描述 课程 软件工程1916|W(福州大学) 团队名称 修!咻咻! 作业要求 项目Beta冲刺(团队) 团队目标 切实可行的计算机协会维修预约平台 开发工具 Eclipse 团队信息 队员学号 队 ...

  6. SIFT提取特征

    SIFT特征提取: 角点检测: Morvavec角点检测算子:基于灰度方差的角点检测方法,该算子计算图像中某个像素点沿水平.垂直方向上的灰度差异,以确定角点位置 Harris角点检测算子:不止考察水平 ...

  7. SpringBoot之Swagger2文档生成

    SpringBoot之Swagger2文档生成 1.Swagger2介绍 编写和维护接口文档是每个程序员的职责,前面我们已经写好的接口现在需要提供一份文档,这样才能方便调用者使用.考虑到编写接口文档是 ...

  8. scala基础题--面向对象1

    练习1 编写computer类,包含CPU.内存.硬盘等属性,getDetails方法用于返回computer的详细信息. 编写PC子类,继承computer类,添加特有属性[品牌brand] 编写n ...

  9. Web应急:搜索引擎劫持

    当你直接打开网址访问网站,是正常的,可是当你在搜索引擎结果页中打开网站时,会跳转到一些其他网站,比如博彩,虚假广告,淘宝搜索页面等.是的,你可能了遇到搜索引擎劫持. 现象描述 从搜索引擎来的流量自动跳 ...

  10. 使用Ueditor上传图片到图片服务器(一)

    网站的文章,通过运营平台来发布文章(图文消息),上传图片等.百度Ueditor比较成熟就采用了该技术,另外上传的图片是网站系统以及运营平台系统共享的,所以考虑搭建独立的图片服务器,以后也可以提供给公司 ...