django基础之数据库操作方法(详解)


Posted in Python onMay 24, 2017

Django 自称是“最适合开发有限期的完美WEB框架”。本文参考《Django web开发指南》,快速搭建一个blog 出来,在中间涉及诸多知识点,这里不会详细说明,如果你是第一次接触Django ,本文会让你在感性上对Django有个认识,完成本文操作后会让你有兴趣阅读的相关书籍和文档。

本文客操作的环境,如无特别说明,后续都以下面的环境为基础:

===================

Windows 7/10

python 3.5

Django 1.10

===================

1:创建工程

创建mysite工程项目:

E:/WWWROOT/python/> django-admin.py startproject mysite

当然,前提是你已经设置好了python的环境变量!

如果是IDE工具(本文使用的是PyCharm4.0),在File -> New Project -> Django中创建工程

创建完成后,工程目录结构如下:

django基础之数据库操作方法(详解)

manage.py ----- Django项目里面的工具,通过它可以调用django shell和数据库等。

settings.py ---- 包含了项目的默认设置,包括数据库信息,调试标志以及其他一些工作的变量。

urls.py ----- 负责把URL模式映射到应用程序。

2:创建blog应用

在python里叫做app

E:\WWWROOT\python\mysite>python manage.py startapp blog

完成后,会在项目中生成一个blog的文件夹

django基础之数据库操作方法(详解)

3:数据库操作

初始化数据库:

python 自带SQLite数据库,Django支持各种主流的数据库,这里我们首先使用SQLite,如果使用其它数据库请在settings.py文件中设置。数据库默认的配置为:

DATABASES = {
  'default': {
    'ENGINE': 'django.db.backends.sqlite3',
    'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
  }
}

使用默认的数据配置来初始化数据库:

E:\WWWROOT\python\mysite>python manage.py migrate

命令执行完成后,会生成一些数据表:

django基础之数据库操作方法(详解)

Django自带有一个WEB 后台,下面创建WEB后台的用户名与密码:

E:\WWWROOT\python\mysite>python manage.py createsuperuser
System check identified some issues:
 
WARNINGS:
?: (1_8.W001) The standalone TEMPLATE_* settings were deprecated in Django 1.8 and the TEMPLATES dictionary takes precedence. You must put the values of the following
settings into your default TEMPLATES dict: TEMPLATE_DIRS.
Username (leave blank to use 'administrator'): root
Email address: admin@admin.com
Password:
Password (again):
Superuser created successfully.

接下来我们使用上面创建的账号密码登录后台试试。要登录后台,必须在settings.py文件中将上面创建的APP也就是blog添加进来:

INSTALLED_APPS = [
  'django.contrib.admin',
  'django.contrib.auth',
  'django.contrib.contenttypes',
  'django.contrib.sessions',
  'django.contrib.messages',
  'django.contrib.staticfiles',
  'blog',
]

注意后面必须要有个逗号!

启动django容器:

E:\WWWROOT\python\mysite>python manage.py runserver

默认使用的WEB地址为http://127.0.0.1,端口为8000,使用该地址与端口访问首页:

django基础之数据库操作方法(详解)

下面访问django的后台:http://127.0.0.1/admin

django基础之数据库操作方法(详解)

使用上面创建的用户与密码即可登录到后台!

如果你想连接mysql数据库而不使用SQLite,那么首先你必须得安装pymysql模块,python3.5版本不再支持MySQLdb模块!安装完成后请看下面的操作:

首先在settings.py文件配置数据库:

DATABASES = {
  'default': {
    'ENGINE': 'django.db.backends.mysql',
    'HOST': '127.0.0.1',
    'PORT': 3306,
    'NAME': 'djangodb',
    'USER': 'root',
    'PASSWORD': 'root',
  }
}

在mysql数据中创建一个djangodb的数据库,然后在mysite/__init__.py文件中加入以下代码:

import pymysql
pymysql.install_as_MySQLdb()

命令行运行:

E:\WWWROOT\python\mysite>python manage.py makemigrations
E:\WWWROOT\python\mysite>python manage.py migrate

这样在mysql数据库他初始化数据表:

django基础之数据库操作方法(详解)

这里为了演示,我将数据库的链接改为SQLite

创建一张UseInfo表,并创建字段:

现在我们打开blog目录下的models.py文件,这是我们定义blog数据结构的地方。打开mysite/blog/models.py 文件进行修改:

from django.db import models
 
# Create your models here.
class UserInfo(models.Model):
  username = models.CharField(max_length=32)
  password = models.CharField(max_length=32)
  age = models.IntegerField()

命令行执行:

E:\WWWROOT\python\mysite>python manage.py makemigrations
E:\WWWROOT\python\mysite>python manage.py migrate

完成后会在数据库创建一张数据表:

django基础之数据库操作方法(详解)

从上图中可以看出,Django默认会以APP名为数据表前缀,以类名为数据表名!

创建的字段如下图:

django基础之数据库操作方法(详解)

从上图可以看出,Django会默认加上一个id字段,该字段为主键且自增长

在blog_UserInfo表中添加数据:

Django是在views.py文件中,通过导入models.py文件来创建数据的:

from django.shortcuts import render
 
# Create your views here.
from blog import models    #导入blog模块
from django.shortcuts import HttpResponse
def db_handle(request):
  models.UserInfo.objects.create(username='andy',password='123456',age=33)
  return HttpResponse('OK')

下面我们配置路由,以便让浏览器能够访问到views.py文件:

from django.conf.urls import url
from django.contrib import admin
 
from blog import views
urlpatterns = [
  url(r'^admin/', admin.site.urls),
  url(r'^db_handle', views.db_handle),
]

下面我们来访问http://127.0.0.1/db_handle

django基础之数据库操作方法(详解)

查看数据库是否创建成功:

django基础之数据库操作方法(详解)

上面就是创建表数据,也可以通过字典的格式来创建表数据:

def db_handle(request):
  # models.UserInfo.objects.create(username='andy',password='123456',age=33)
  dic = {"username":"bruce","password":"123456","age":23}
  models.UserInfo.objects.create(**dic)
  return HttpResponse('OK')

通过上面的方法,我们多创建几条数据,完成后如下图所示:

django基础之数据库操作方法(详解)

删除表数据:

views.py文件如下:

from django.shortcuts import render
 
# Create your views here.
from blog import models
from django.shortcuts import HttpResponse
def db_handle(request):
  # models.UserInfo.objects.create(username='andy',password='123456',age=33)
  # dic = {"username":"bruce","password":"123456","age":23}
  # models.UserInfo.objects.create(**dic)
  models.UserInfo.objects.filter(id=2).delete()
  return HttpResponse('OK')

操作方法同上,在浏览器中执行一遍,数据中的id=2的数据即被删除:

django基础之数据库操作方法(详解)

修改表数据:

from django.shortcuts import render

# Create your views here.
from blog import models
from django.shortcuts import HttpResponse
def db_handle(request):
  models.UserInfo.objects.filter(id=1).update(age=18) #找到id=1的数据,将age改为18
  return HttpResponse('OK')

数据的查询:

为了让查询出来的数据更加直观地显示出来,这里我们将使用Django的模板功能,让查询出来的数据在WEB浏览器中展示出来

在templates目录下新建一个t1.html的文件,内容如下:

<!DOCTYPE html>
<html>
<head lang="en">
  <meta charset="UTF-8">
  <title>Django操作数据库</title>
</head>
<body>
  <table border="1">
    <tr>
      <th>用户名</th>
      <th>密码</th>
      <th>年龄</th>
    </tr>
    {% for item in li %}
    <tr>
      <td>{{ item.username }}</td>
      <td>{{ item.password }}</td>
      <td>{{ item.age }}</td>
    </tr>
    {% endfor %}
  </table>
</body>
</html>

views.py文件查询数据,并指定调用的模板文件,内容如下:

from django.shortcuts import render

# Create your views here.
from blog import models
from django.shortcuts import HttpResponse
def db_handle(request):
  user_list_obj = models.UserInfo.objects.all()
  return render(request,'t1.html',{'li':user_list_obj})

注意:由于这里是在工程下面的templates目录下建立的模板,而不是在blog应用中创建的模板,上面views.py文件中调用的t1.html模板,运行时会出现找不到t1.html模板的错误,为了能找到mysite/templates下的模板文件,我们还需要在settings.py文件配置模板的路径:

TEMPLATES = [
  {
    'BACKEND': 'django.template.backends.django.DjangoTemplates',
    'DIRS': [os.path.join(BASE_DIR,'templates')], #配置模板路径
    'APP_DIRS': True,
    'OPTIONS': {
      'context_processors': [
        'django.template.context_processors.debug',
        'django.template.context_processors.request',
        'django.contrib.auth.context_processors.auth',
        'django.contrib.messages.context_processors.messages',
      ],
    },
  },
]

下面就可以在浏览器中查看:

django基础之数据库操作方法(详解)

引入JS,CSS等静态文件:

在mysite目录下新建一个static目录,将JS,CSS文件都放在此目录下!并在settings.py文件中指定static目录:

STATIC_URL = '/static/'
 STATICFILES_DIRS = (
   os.path.join(BASE_DIR,'static'),
 )

表单提交数据:

在Django中要使用post方式提交表单,需要在settings.py配置文件中将下面一行的内容给注释掉:

# 'django.middleware.csrf.CsrfViewMiddleware',

提交表单(这里仍然使用了t1.html):

<!DOCTYPE html>
<html>
<head lang="en">
  <meta charset="UTF-8">
  <title>Django表单</title>
  <link type="text/css" href="/static/base.css" rel="external nofollow" rel="stylesheet" />
</head>
<body>
  <table border="1">
    <tr>
      <th>用户名</th>
      <th>密码</th>
      <th>年龄</th>
    </tr>
    {% for item in li %}
    <tr>
      <td>{{ item.username }}</td>
      <td>{{ item.password }}</td>
      <td>{{ item.age }}</td>
    </tr>
    {% endfor %}
  </table>
  <form action="/db_handle/" method="post">
    <p><input name="username" /></p>
    <p><input name="password" /></p>
    <p><input name="age" /></p>
    <p><input type="submit" value="submit" /></p>
  </form>
</body>
</html>

写入数据库(views.py):

from django.shortcuts import render

# Create your views here.
from blog import models
from django.shortcuts import HttpResponse
def db_handle(request):

  if request.method == "POST":
    models.UserInfo.objects.create(username=request.POST['username'],password=request.POST['password'],age=request.POST['age'])
  user_list_obj = models.UserInfo.objects.all()
  return render(request, 't1.html', {'li': user_list_obj})

提交数据后,如下图:

django基础之数据库操作方法(详解)

Django执行流程

django基础之数据库操作方法(详解)

以上这篇django基础之数据库操作方法(详解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
使用python编写批量卸载手机中安装的android应用脚本
Jul 21 Python
Python初学时购物车程序练习实例(推荐)
Aug 08 Python
python 通过 socket 发送文件的实例代码
Aug 14 Python
pandas DataFrame 删除重复的行的实现方法
Jan 29 Python
python使用tkinter库实现五子棋游戏
Jun 18 Python
python将excel转换为csv的代码方法总结
Jul 03 Python
django将网络中的图片,保存成model中的ImageField的实例
Aug 07 Python
Django实现将一个字典传到前端显示出来
Apr 03 Python
keras打印loss对权重的导数方式
Jun 10 Python
Python如何使用vars返回对象的属性列表
Oct 17 Python
django注册用邮箱发送验证码的实现
Apr 18 Python
教你使用TensorFlow2识别验证码
Jun 11 Python
python bottle框架支持jquery ajax的RESTful风格的PUT和DELETE方法
May 24 #Python
Python生成密码库功能示例
May 23 #Python
Python计算两个日期相差天数的方法示例
May 23 #Python
基于Python_脚本CGI、特点、应用、开发环境(详解)
May 23 #Python
浅谈django model的get和filter方法的区别(必看篇)
May 23 #Python
Python常用内置模块之xml模块(详解)
May 23 #Python
Python使用PyCrypto实现AES加密功能示例
May 22 #Python
You might like
一道求$b相对于$a的相对路径的php代码
2010/08/08 PHP
浅析PHP的ASCII码转换类
2013/07/05 PHP
php教程之魔术方法的使用示例(php魔术函数)
2014/02/12 PHP
PHP命名空间定义与用法实例分析
2019/08/14 PHP
jquery获取当前元素索引值用法实例
2015/06/10 Javascript
js实现新浪微博首页效果
2015/10/16 Javascript
JavaScript优化专题之Loading and Execution加载和运行
2016/01/20 Javascript
详解JavaScript的AngularJS框架中的表达式与指令
2016/03/05 Javascript
基于React实现表单数据的添加和删除详解
2017/03/14 Javascript
慕课网题目之js实现抽奖系统功能
2017/09/19 Javascript
浅谈Node Inspector 代理实现
2017/10/19 Javascript
JS加密插件CryptoJS实现AES加密操作示例
2018/08/16 Javascript
Vue 中对图片地址进行拼接的方法
2018/09/03 Javascript
在Angular中使用JWT认证方法示例
2018/09/10 Javascript
Vue组件教程之Toast(Vue.extend 方式)详解
2019/01/27 Javascript
vue监听浏览器原生返回按钮,进行路由转跳操作
2020/09/09 Javascript
使用Python获取CPU、内存和硬盘等windowns系统信息的2个例子
2014/04/15 Python
Python 的 with 语句详解
2014/06/13 Python
python对json的相关操作实例详解
2017/01/04 Python
python3+PyQt5实现拖放功能
2018/04/24 Python
python实现NB-IoT模块远程控制
2018/06/20 Python
对python中的高效迭代器函数详解
2018/10/18 Python
Python 通过调用接口获取公交信息的实例
2018/12/17 Python
如何使用Python标准库进行性能测试
2019/06/25 Python
基于Python获取城市近7天天气预报
2019/11/26 Python
Python的形参和实参使用方式
2019/12/24 Python
keras在构建LSTM模型时对变长序列的处理操作
2020/06/29 Python
Pycharm安装python库的方法
2020/11/24 Python
新西兰Bookabach:查找全球度假屋
2020/12/03 全球购物
迟到检讨书400字
2014/01/13 职场文书
市场营销专业毕业生求职信
2014/07/21 职场文书
二人合伙经营协议书
2014/09/13 职场文书
鲁滨逊漂流记读书笔记
2015/06/26 职场文书
2015年科学教研组工作总结
2015/07/22 职场文书
2015双创工作总结
2015/07/24 职场文书
nginx 多个location转发任意请求或访问静态资源文件的实现
2021/03/31 Servers