django操作mysql
连接mysql
1、安装pymysql
操作指令 : pymsql: pip install pymysql
2、导入库
在项目目录下的__init__.py文件中导入pymysql模块
加入以下两行代码:
import pymysql
pymysql.install_as_MySQLdb()
3、在setting中的databases中配置mysql的连接
'ENGINE': 'django.db.backends.mysql', # 设置驱动
'NAME':库名, # 设置数据库名
'USER':'root', # 设置用户名
‘PASSWORD':密码, # 设置密码
'HOST':主机地址, # 设置主机地址
'PORT':3306, # 设置端口号
4、执行迁移
python manage.py makemigrations
python manage.py migrate
5、连接mysql数据库
点击database --- + -----data source ----数据库类型(如:mysql) ----- 设置 账号,密码,主机,(注意: 如果对mysql设置远程连接,
要使用远程连接的账号密码) ----test connect ---- ok 即可
操作mysql
1、创建一个表
需要在model模块中创建一个类,该类继承models.Model
例:
- class Person(models.Model):
- p_name = models.CharField(max_length=20, null=False, unique=True)
- p_age = models.IntegerField(default=10)
- p_sex = models.BooleanField(default=True)
表名默认为 应用名_类名
注:在右侧detabase处可以看到自己创建的表
注:在创建的类中添加
class Meta:
db_table = "表名" 修改表名
可以修改创建的表的名字
例:
- class Person(models.Model):
- p_name = models.CharField(max_length=20, null=False, unique=True)
- p_age = models.IntegerField(default=10)
- p_sex = models.BooleanField(default=True)
- class Meta:
- db_table = "Person"
修改完成后,执行迁移
若要修改表的字段名,则更改定义的类中的属性之后迁移即可
2、增加一个数据
步骤:
①.创建一个对象
②.设置属性
③.保存数据
④.对象名.save()
例:
- from django.shortcuts import render
- from day02.models import Person
- import random
- # Create your views here.
- def insertPerson(request):
- # 创建一个对象
- person = Person()
- # 设置属性
- person.p_name = "王" + str(random.randint(1, 100))
- person.p_age = random.randint(1, 100)
- person.p_sex = random.randint(0, 1)
- # 保存数据
- person.save()
设置url
在项目的urls中添加 url("应用名",include("应用名.urls"))
注:需import 应用名
- from django.conf.urls import url, include
- from django.contrib import admin
- import day02
- urlpatterns = [
- url(r'^admin/', admin.site.urls),
- url(r'^day02/', include(day02.urls)),
- ]
注:须在应用的目录中创建一个urls.py文件,可以将项目中的urls中的内容复制过去
- from django.conf.urls import url
- from django.contrib import admin
- urlpatterns = [
- url(r'^admin/', admin.site.urls),
- ]
在应用中的urls中添加路径
- from django.conf.urls import url
- from django.contrib import admin
- from day02 import views
- urlpatterns = [
- url(r'^admin/', admin.site.urls),
- url(r'insertPerson', views.insertPerson),
- ]
激活服务器,在浏览器中输入地址即可成功添加数据
查看插入的表
3、删除一个数据
用变量获取匹配到的数据
格式:变量.delete() # 删除数据
- def delPerson(request):
- person = Person.objects.filter(p_name="王66").first() # 用变量person接收获取到的对象
- person.delete()
- return HttpResponse("删除成功")
在应用的urls中添加路径
url(r'delPerson',views.delPerson)
激活服务器,并操作,
成功删除
4、修改数据
格式:对象名.属性名 = 值
对象名.save()
例:首先插入一条数据
修改数据的属性值
- def updatePerson(request):
- person = Person.objects.filter(p_name="王30").first()
- person.p_name = "王小明"
- person.p_age = 18
- person.p_sex = 0
- person.save()
- return HttpResponse("修改成功")
在urls中添加路径
url(r'updatePerson', views.updatePerson),
运行服务器
修改成功
5、查询数据
格式: 类名.objects.方法
例:多插入几条数据
在应用的views中添加代码
- def queryPerson(request):
- persons = Person.objects.all()
- return render(request, "Persons.html", context={"persons":persons})
在templates中创建Persons.html文件
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Title</title>
- </head>
- <body>
- <ul>
- {% for person in persons %}
- <li>name:{{ person.p_name }} age:{{ person.p_age }}</li>
- {% endfor %}
- </ul>
- </body>
- </html>
在urls中添加路径
启动服务器
成功查询表格中的数据
注:这里只介绍了查询所有数据的方法
django操作mysql的更多相关文章
- Django静态文件配置 request对象 Django操作MySQL
Django中的文件介绍 render.HttpResponse和redirect 当我们想起手写一个项目,创建好应用并且注册之后,在urls.py文件先导入app文件夹下migrations下的vi ...
- Django 操作Mysql数据库
pip安装mysqlclient sudo ln -s /usr/local/mysql/bin/mysql_config /usr/local/bin/mysql_config sudo pip i ...
- django MVC模式 数据库的操作mysql
介绍:本节课我们继续学习djangoWEB框架的开发,这节课主要是学习如何访问数据库,django如何自动为我们创建好表结构等相关内容. 1.首先我们打开settings.py找到DATABASES关 ...
- django连接mysql数据库以及建表操作
django连接mysql数据库需要在project同名的目录下面的__init__.py里面加入下面的东西 import pymysql pymysql.install_as_MySQLdb() 找 ...
- Django之mysql表单操作
在Django之ORM模型中总结过django下mysql表的创建操作,接下来总结mysql表记录操作,包括表记录的增.删.改.查. 1. 添加表记录 class UserInfo(models.Mo ...
- Django 链接MySQL及数据操作
Django 链接MySQL Django创建的项目自带的数据库是SQLite3,我们想要链接MySQL的话,需要更改settings.py中的配置 1.在MySQL中创建好数据库,Django项目不 ...
- python——django使用mysql数据库(二)
上一篇中,我们已经讲述了如何初始化一个django数据库,这一章就来讲讲在实际的项目中如何使用我们初始化的数据库呢? 如还未进行初始化数据库操作,请参考python——django使用mysql数据库 ...
- python——django使用mysql数据库(一)
之前已经写过如何创建一个django项目,现在我们已经有了一个小骷髅,要想这个web工程变成一个有血有肉的人,我们还需要做很多操作.现在就先来介绍如何在django中使用mysql数据库. 前提:已经 ...
- Django ajax MYSQL Highcharts<1>
Another small project with django/Ajax/Mysql/Highcharts. 看下效果图 - delivery dashboard .嘿嘿 是不是还蛮好看的. 废 ...
随机推荐
- Linux系统swappiness参数在内存与交换分区之间优化作用
http://blog.sina.com.cn/s/blog_13cc013b50102wskd.html swappiness的值的大小对如何使用swap分区是有着很大的联系的.swappiness ...
- js 延迟函数
1.对于 setTimeout函数 普通函数: 100ms后执行时,this指向window对象. function foo(){ setTimeout(function(){ console.log ...
- Head First Design Patterns HeadFirst 设计模式
OO原则是我们的目标,而设计模式是我们的做法. 策略模式 (Strategy) 在软件开发上,一直不变的真理是"change".不管软件设计的多好,一段时间之后,总是要成长与改变, ...
- 19-js策略模式
var PriceStrategy = function() { var stragtegy = { return30: function(price) { return +price + parse ...
- samtools获取uniq reads
参考地址: https://www.biostars.org/p/56246/ -q INT only include reads with mapping quality >= INT [0] ...
- 《ucore lab1 exercise6》实验报告
资源 ucore在线实验指导书 我的ucore实验代码 题目:完善中断初始化和处理 请完成编码工作和回答如下问题: 中断描述符表(也可简称为保护模式下的中断向量表)中一个表项占多少字节?其中哪几位代表 ...
- 使用speedtest-cli测量服务器带宽
使用speedtest-cli测量服务器带宽,这个是python写的工具,很方便,只需要在服务器端安装即可. 1.安装python-pip # yum install python-pip –y 2. ...
- MongoDB 空间定位(点) 与 距离检索
转自: http://blog.csdn.net/flamingsky007/article/details/39208837 基于 MongoDB 2.6 GeoJSON 格式 { "ty ...
- LeetCode 141. 环形链表(Linked List Cycle) 19
141. 环形链表 141. Linked List Cycle 题目描述 给定一个链表,判断链表中是否有环. 为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 ...
- PAT(B) 1043 输出PATest(Java)统计
题目链接:1043 输出PATest (20 point(s)) 题目描述 给定一个长度不超过 104 的.仅由英文字母构成的字符串.请将字符重新调整顺序,按 PATestPATest- 这样的 ...