Django数据库(SQlite)基本入门使用教程


Posted in Python onJuly 07, 2022

1:创建工程

django-admin startproject mysite

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

Django数据库(SQlite)基本入门使用教程

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

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

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

2:创建blog应用

python manage.py startapp blog

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

Django数据库(SQlite)基本入门使用教程

3:数据库操作 

初始化数据库:

python 自带SQLite数据库,Django支持各种主流的数据库,这里我们首先使用SQLite。

如果使用其它数据库请在settings.py文件中设置。数据库默认的配置为:

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

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

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

Django数据库(SQlite)基本入门使用教程

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

python manage.py createsuperuser

注意⚠️:密码不能与用户名相似,密码不能纯数字 。

Django数据库(SQlite)基本入门使用教程

 接下来我们使用上面创建的账号密码登录后台试试。要登录后台,必须在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容器:

python manage.py runserver

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

Django数据库(SQlite)基本入门使用教程

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

Django数据库(SQlite)基本入门使用教程

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

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

from django.db import models
 
 
# Create your models here.
class Demo(models.Model):
    car_num = models.CharField(max_length=32)
    park_name = models.CharField(max_length=32)
    jinru_Date = models.CharField(max_length=32)
    chuqu_Date = models.CharField(max_length=32)
    time = models.CharField(max_length=32)

命令行执行:

python manage.py makemigrations
python manage.py migrate

Django数据库(SQlite)基本入门使用教程

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

创建的字段如下图:

Django数据库(SQlite)基本入门使用教程

4.在blog_demo表中添加数据:

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.Demo.objects.create(car_num='陕E-BV886', park_name='中医院', jinru_Date='2022-02-05',
                                   chuqu_Date='2022-02-06', time='1')
    return HttpResponse('OK')

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

from blog import views
 
urlpatterns = [
    path('admin/', admin.site.urls),
    path(r'db_handle', views.db_handle),
]

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

Django数据库(SQlite)基本入门使用教程

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

Django数据库(SQlite)基本入门使用教程

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

def db_handle(request):
    dic = {car_num='陕E-BV886', park_name='中医院', jinru_Date='2022-02-05',chuqu_Date='2022-02-06', time='1'}
    models.Demo.objects.create(**dic)
    return HttpResponse('OK')

删除表数据:

views.py文件如下:

def db_handle(request):
 
    #删除表数据
    models.Demo.objects.filter(id=1).delete()
    return HttpResponse('OK')

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

Django数据库(SQlite)基本入门使用教程

修改表数据: 

def db_handle(request):
    # 修改表数据
    models.Demo.objects.filter(id=2).update(time=18)  
    return HttpResponse('OK')

数据的查询:

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

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

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Django操作数据库</title>
    <link type="text/css" href="/static/base.css" rel="external nofollow"  rel="external nofollow"  rel="stylesheet" />
</head>
<body>
    <table border="1">
        <tr>
            <th>车牌号</th>
            <th>停车场名</th>
            <th>入场时间</th>
            <th>出场时间</th>
            <th>停车时间</th>
        </tr>
        {% for item in li %}
        <tr>
            <td>{{ item.car_num }}</td>
            <td>{{ item.park_name }}</td>
            <td>{{ item.jinru_Date }}</td>
            <td>{{ item.chuqu_Date }}</td>
            <td>{{ item.time }}</td>
         </tr>
        {% endfor %}
</body>
</html>

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

def db_handle(request):
        user_list_obj = models.Demo.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数据库(SQlite)基本入门使用教程

引入JS,CSS等静态文件:

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

Django数据库(SQlite)基本入门使用教程

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

表单提交数据:

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

# 'django.middleware.csrf.CsrfViewMiddleware',

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

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Django操作数据库</title>
    <link type="text/css" href="/static/base.css" rel="external nofollow"  rel="external nofollow"  rel="stylesheet" />
</head>
<body>
    <table border="1">
        <tr>
            <th>车牌号</th>
            <th>停车场名</th>
            <th>入场时间</th>
            <th>出场时间</th>
            <th>停车时间</th>
        </tr>
        {% for item in li %}
        <tr>
            <td>{{ item.car_num }}</td>
            <td>{{ item.park_name }}</td>
            <td>{{ item.jinru_Date }}</td>
            <td>{{ item.chuqu_Date }}</td>
            <td>{{ item.time }}</td>
         </tr>
        {% endfor %}
    </table>
    <form action="/db_handle" method="post">
         <p><input name="car_num" /></p>
         <p><input name="park_name" /></p>
         <p><input name="jinru_Date" /></p>
         <p><input name="chuqu_Date" /></p>
         <p><input name="time" /></p>
         <p><input type="submit" value="submit" /></p>
     </form>
</body>
</html>

写入数据库(views.py):

def db_handle(request):
        if request.method == "POST":
                 models.Demo.objects.create(car_num=request.POST['car_num'],park_name=request.POST['park_name'],jinru_Date=request.POST['jinru_Date'],chuqu_Date=request.POST['chuqu_Date'],time=request.POST['time'])
        user_list_obj = models.Demo.objects.all()
        return render(request, 't1.html', {'li': user_list_obj})

提交数据后,如下图:

Django数据库(SQlite)基本入门使用教程

Django数据库(SQlite)基本入门使用教程

Django数据库(SQlite)基本入门使用教程

总结

到此这篇关于Django数据库(SQlite)基本入门使用教程的文章就介绍到这了,更多相关Django数据库SQlite使用内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!


Tags in this post...

Python 相关文章推荐
使用Python编写提取日志中的中文的脚本的方法
Apr 30 Python
详解python Todo清单实战
Nov 01 Python
Python实现繁体中文与简体中文相互转换的方法示例
Dec 18 Python
Python叠加两幅栅格图像的实现方法
Jul 05 Python
Python用字典构建多级菜单功能
Jul 11 Python
Python学习笔记之lambda表达式用法详解
Aug 08 Python
python 爬取疫情数据的源码
Feb 09 Python
基于python爬取有道翻译过程图解
Mar 31 Python
Python pickle模块常用方法代码实例
Oct 10 Python
python小技巧——将变量保存在本地及读取
Nov 13 Python
查找适用于matplotlib的中文字体名称与实际文件名对应关系的方法
Jan 05 Python
看看如何用Python绘制小米新版天价logo
Apr 20 Python
Python可视化神器pyecharts之绘制地理图表练习
Django中celery的使用项目实例
Python可视化神器pyecharts绘制地理图表
Python软件包安装的三种常见方法
Python+SeaTable实现计算两个日期间的工作日天数
Jul 07 #Python
Python实现数据的序列化操作详解
Jul 07 #Python
Python如何利用pandas读取csv数据并绘图
You might like
实例讲解通过​PHP创建数据库
2019/01/20 PHP
javascript 获取元素样式必杀技
2014/05/04 Javascript
JS获取客户端IP地址、MAC和主机名的7个方法汇总
2014/07/21 Javascript
javascript实现的字符串与十六进制表示字符串相互转换方法
2015/07/17 Javascript
浅谈javascript中的constructor
2016/06/08 Javascript
Bootstrap Table从零开始
2017/06/30 Javascript
详解Vue2中组件间通信的解决全方案
2017/07/28 Javascript
解析Angular 2+ 样式绑定方式
2018/01/15 Javascript
微信小程序上线发布流程图文详解
2019/05/06 Javascript
微信小程序npm引入vant-weapp的踩坑记录
2019/08/01 Javascript
JavaScript 斐波那契数列 倒序输出 输出100以内的质数代码实例
2019/09/11 Javascript
小程序如何支持使用 async/await详解
2019/09/12 Javascript
Python实现堆排序的方法详解
2016/05/03 Python
Python解惑之True和False详解
2017/04/24 Python
flask框架中勾子函数的使用详解
2018/08/01 Python
阿里云ECS服务器部署django的方法
2019/08/29 Python
python numpy中cumsum的用法详解
2019/10/17 Python
python基于plotly实现画饼状图代码实例
2019/12/16 Python
Python类中的装饰器在当前类中的声明与调用详解
2020/04/15 Python
CSS3 实现穿梭星空动画
2020/11/13 HTML / CSS
ECCO爱步官方旗舰店:丹麦鞋履品牌
2018/01/02 全球购物
Carter’s OshKosh加拿大:购买婴幼儿服装和童装
2018/11/27 全球购物
类如何去实现接口
2013/12/19 面试题
几个MySql的面试题
2013/04/22 面试题
应用化学专业本科生求职信
2013/09/29 职场文书
材料加工硕士生求职信
2013/10/10 职场文书
仓库管理专业个人的自我评价
2013/12/30 职场文书
韩国商务邀请函
2014/01/14 职场文书
私人会所最新创业计划书范文
2014/03/24 职场文书
2014年新生军训方案
2014/05/01 职场文书
社区反邪教工作方案
2014/06/16 职场文书
幼儿园六一儿童节开幕词
2016/03/04 职场文书
mysql外连接与内连接查询的不同之处
2021/06/03 MySQL
Log4j.properties配置及其使用
2021/08/02 Java/Android
Go语言基础函数基本用法及示例详解
2021/11/17 Golang
Android Rxjava3 使用场景详解
2022/04/07 Java/Android