Django 链接MySQL及数据操作
Django 链接MySQL
Django创建的项目自带的数据库是SQLite3,我们想要链接MySQL的话,需要更改settings.py中的配置
1.在MySQL中创建好数据库,Django项目不会创建数据库,只会根据models.py中的模型类创建对应的表
2.在项目文件下的settings.py文件中,找到 DATABASES
属性,配置MySQL相关参数
DATABASES = {
'default': {
# 将数据库引擎修改成 mysql
'ENGINE': 'django.db.backends.mysql',
# 数据库名称
'NAME': 'django_test',
# 数据库所在的主机地址
'HOST': '127.0.0.1',
# MySQL服务的端口号
'PORT': 3306,
'USER': 'root',
'PASSWORD': 'Ad123',
'CHARSET': 'utf8'
}
}
3.找到项目文件下或app(应用程序)下的__init__.py
配置成MySQL
注意:重点!重点!重点!
import pymysql
# 将数据库引擎调整为MySQL
pymysql.install_as_MySQLdb()
4.在对应的app(应用程序)下的 models.py
文件中编写数据库表对应的类
from django.db import models
# 模型类都需要继承 models.Model 类
class Book(models.Model):
# AutoField 表示是int数据类型,auto_increment自增长列,primary_key 表示主键
b_id = models.AutoField(primary_key=True)
# CharField 表示varchar数据类型,必须给 max_length 赋值,表示字符长度
book_name = models.CharField(max_length=64)
# IntegerField 表示int数据类型, default 表示默认值
book_price = models.IntegerField(default=0)
这里运用的就是ORM对象关系映射
ORM(Object Relational Mapping) 对象关系映射:通过使用描述对象和数据库之间映射的方式,将面向对象语言程序中的对象自动持久化到关系数据库中。
本质上就是将数据从一种形式转换到另外一种形式,通俗来讲,能够让一个不会数据库操作的小白也能通过Python面向对象语法,句点符(对象.属性)来简单快捷的操作数据
Python | MySQL |
---|---|
类(class) | 数据表(table) |
对象(object) | 记录(数据表中的一行记录) |
属性(attribute) | 表字段(column) |
5.在cmd或pycharm中的Terminal窗口执行数据库迁移(同步)命令
注意:重点!重点!重点!
# python3 是python解释器名称
# 将对数据库的操作记录到项目中的migrations文件夹下的文件中,此时并没有同步到到数据库
python3 manage.py makemigrations
# 将对数据库的操作同步到MySQL中
python3 manage.py migrate
- 一定要在对应的项目文件下执行这两条命令
- 这两条命令一般情况下,是成对出现的,缺一不可
- 在开发过程中,只要修改了models.py 中跟数据库相关的代码,就必须重新执行这两命令,以保证数据库中的记录跟models.py中一致
Django 表操作-增删改
在models.py文件中操作
1.增加表,增加对应的类即可
2.给表增加字段或修改字段,找到对应的类,调整类属性的参数即可,例
# 默认所有列都是非空,允许为空,null=True
book_price = models.IntegerField(null=True)
# 默认所有列没有默认值,增加默认值,default=默认值
press_addr = models.CharFiels(default='aaa')
3.删除表,将对应的类注释即可
以上操作,都要执行!!!处理完毕后,执行数据库迁移(同步)命令
Django 数据操作-查增删改
1.数据操作-查询
- models.类名.objects.filter() 条件查询
# 当前类是Book类
# filter() 有返回值,是一个列表;没有参数(查询所有)或多个参数,参数之间关系对应SQL语句为:where 参数1=参数值1 and 参数2=参数值2 and …… and 参数n=参数值n
# res = models.Book.objects.filter(book_name='钢铁是怎样炼成的')
# select * from book where book_name='青年文摘' and book_price=1234;
res = models.Book.objects.filter(book_name='青年文摘', book_price=1234)
# 可通过索引取值但是索引不能为负数,不推荐使用索引取值,可使用first()
book_obj = res.first() # 取第一条记录
注意:filter方法如果没有获取到结果,不会报错,返回的是一个空列表
- models.类名.objects.all() 查询所有
# 等同于 select * from book
# 返回值是一个列表,支持索引,但不支持负索引
res = models.Book.objects.all()
2.数据操作-增加
- 类.objects.create()
# create() 有返回值,是当前被创建的对象本身
book_obj = Book.objects.create(book_name='Django入门', book_price=1234)
# 打印创建的对象, 对象的book_name 属性
print(book_obj, book_obj.book_name)
- 创建对象,通过对象.save()
# 创建Book 对象
book_obj = Book(book_name='redis入门', book_price=4321)
# 通过对象.save()方法增加记录
book_obj.save()
3.数据操作-删除
'''
1.先查询出结果,
2.通过delete() 删除
'''
# sql语句:delete from book where b_id=2;
models.Book.objects.filter(b_id=2).delete()
# 由于filter() 的返回值是一个列表,这个方式相当于是批量删除,不建议删除记录
4.数据操作-修改
- 批量更新(推荐使用该方法)
'''
1.先查询出结果
2.通过update() 更新
'''
# sql语句:update book set book_name='aa', book_price=2314 where b_id=3;
models.Book.objects.filter(b_id=3).update(book_name='aa',book_price=2314)
# 由于filter() 的返回值是一个列表,这个方式相当于是批量修改
- 先获取数据对象,再修改对象属性,调用对象的绑定方法save()保存(了解即可,不推荐使用)
# 1.获取数据对象
book_obj = models.Book.objects.filter(b_id=3).first()
# 2.修改对象属性
book_obj.book_name = 'bb'
book_obj.book_price = 3124
# 3.调用对象的绑定方法 save
book_obj.save()
Django 链接MySQL及数据操作的更多相关文章
- Django链接MySQL,数据库迁移
form表单默认是以get请求提交数据的 http://127.0.0.1:8000/login/?username=admin&password=123 action 1 不写,默认向当前地 ...
- 数据库 MySQL 之 数据操作
数据库 MySQL 之 数据操作 一.MySQL数据类型介绍 MySQL支持多种类型,大致可以分为四类:数值.字符串类型.日期/时间和其他类型. ①二进制类型 bit[(M)] 二进制位(101001 ...
- ORACLE链接SQLSERVER数据库数据操作函数范例
ORACLE链接SQLSERVER数据库数据操作函数范例 create or replace function FUN_NAME(LS_DJBH IN varchar2 ,LS_ITM varchar ...
- 搭建Django链接MySQL流程(python2版)
之前生成选型python3,除了用的python3的pymysql模块之外其他的都是一样的. 1.首先搭建mysql(Mariadb)数据库(单点) 安装方式分为yum安装,rpm包安 ...
- Django—链接MySQL
Djalgo基础配置方法 静态文件配置方法 1 所有的静态文件都放在 static 文件夹下,例如Bootstrap值类的第三方库,通常 static 文件下会创建 css image js 文件,用 ...
- MySQL 数据库 -- 数据操作
数据的增删改 一 介绍 MySQL数据操作: DML ======================================================== 在MySQL管理软件中,可以通过 ...
- Django之mysql表单操作
在Django之ORM模型中总结过django下mysql表的创建操作,接下来总结mysql表记录操作,包括表记录的增.删.改.查. 1. 添加表记录 class UserInfo(models.Mo ...
- mysql 写数据操作几次硬盘?
mysql 写数据步骤: 1:写入操作事物日志,持久化操作日志到磁盘,并且只是写在磁盘上一小块区域内的顺序io,不需要像随机io一样 在磁盘多个地方移动磁头 2:内存中事物日志持久化以后 ,写入的数 ...
- mysql之数据操作
一 介绍 MySQL数据操作: DML 在MySQL管理软件中,可以通过SQL语句中的DML语言来实现数据的操作,包括 使用INSERT实现数据的插入 UPDATE实现数据的更新 使用DELETE实现 ...
随机推荐
- Python深入:Distutils发布Python模块
Distutils可以用来在Python环境中构建和安装额外的模块.新的模块可以是纯Python的,也可以是用C/C++写的扩展模块,或者可以是Python包,包中包含了由C和Python编写的模块. ...
- @总结 - 7@ 生成树计数 —— matrix - tree 定理(矩阵树定理)与 prüfer 序列
目录 @0 - 参考资料@ @0.5 - 你所需要了解的线性代数知识@ @1 - 矩阵树定理主体@ @证明 part - 1@ @证明 part - 2@ @证明 part - 3@ @证明 part ...
- [***]HZOJ 哪一天她能重回我身边
%%%神仙题. 居然是图论,我还一直以为是二分图或者啥数据结构. 直接说正解了,将数看作节点,牌看做边,从牌的正面的数想反面连边权为1的边,反面向正面连边权为0的边(注意用到成对存储的技巧,之后会非常 ...
- hdu 3329 The Flood (Flood Fill + MFSet)
Problem - 3329 用pfs,将淹没时间调整回来,然后用并查集,时间倒序插入点. 代码如下: #include <iostream> #include <algorithm ...
- wamp环境搭建(Apache2.4.34+PHP7.2.7+MySQL5.5.60)
1 添加环境变量 1.1 添加Apache bin目录 1.2 添加PHP目录 2 配置Apache 2.1 修改conf/httpd.conf 将第38行SRVROOT值修改为当前Apache文件夹 ...
- Android 自定义界面的弹出框(可输入数据)
上午写了一篇博文,介绍了如何定义从屏幕底部弹出PopupWindow,写完之后,突然想起之前写过自定义内容显示的弹出框,就随手写了两个实例,分享出来: 第一种实现方式:继承Dialog 1.1 线定义 ...
- Mac MAMP 使用终端shell操作mysql数据库
在MAMP中已经集成了phpMyAdmin,可以很方便的管理mysql数据库,但是有的情况是phpMyAdmin不能做到的.比如,导入sql文件,当sql文件非常大(大于20MB)的时候,apache ...
- 2019-10-30-C#-dotnet-core-局域网组播方法
title author date CreateTime categories C# dotnet core 局域网组播方法 lindexi 2019-10-30 9:0:48 +0800 2019- ...
- css的一些小问题
这是今天整理的笔记一.属性书写顺序: Formatting Model(布局方式.位置) > Box Model(尺寸) > Typographic(文本相关) > Visual(视 ...
- Flex AIR应用的启动闪屏(必须)
说明: 一款移动应用,它必须具有启动屏幕,这点可以从我们常见的手机应用观察知道(如,你启动一个QQ,开始大约10秒钟会停留在一个界面上,之后才跳转到登陆或者是主界面). 在air移动应用中,如果不添加 ...