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 相关文章推荐
pandas中Timestamp类用法详解
Dec 11 Python
python编程培训 python培训靠谱吗
Jan 17 Python
如何利用python查找电脑文件
Apr 27 Python
Django 接收Post请求数据,并保存到数据库的实现方法
Jul 12 Python
Python数据可视化 pyecharts实现各种统计图表过程详解
Aug 15 Python
Python实现图片添加文字
Nov 26 Python
使用Puppeteer爬取微信文章的实现
Feb 11 Python
在Python IDLE 下调用anaconda中的库教程
Mar 09 Python
Python列表如何更新值
May 27 Python
python实现登录与注册系统
Nov 30 Python
python基于socket模拟实现ssh远程执行命令
Dec 05 Python
解决tensorflow模型压缩的问题_踩坑无数,总算搞定
Mar 02 Python
Python可视化神器pyecharts之绘制地理图表练习
Django中celery的使用项目实例
Python可视化神器pyecharts绘制地理图表
Python软件包安装的三种常见方法
Python+SeaTable实现计算两个日期间的工作日天数
Jul 07 #Python
Python实现数据的序列化操作详解
Jul 07 #Python
Python如何利用pandas读取csv数据并绘图
You might like
PHP中使用虚代理实现延迟加载技术
2014/11/05 PHP
php 删除cookie方法详解
2014/12/01 PHP
JQuery 学习笔记 选择器之一
2009/07/23 Javascript
解决jquery中美元符号命名冲突问题
2014/01/08 Javascript
文本框文本自动补全效果示例分享
2014/01/19 Javascript
jQuery Migrate 1.1.0 Released 注意事项
2014/06/14 Javascript
js在数组中删除重复的元素自保留一个(两种实现思路)
2014/08/22 Javascript
三种取消选中单选框radio的方法
2014/09/09 Javascript
jQuery修改class属性和CSS样式整理
2015/01/30 Javascript
js关于命名空间的函数实例
2015/02/05 Javascript
基于jQuery实现复选框是否选中进行答题提示
2015/12/10 Javascript
JavaScript中利用jQuery绑定事件的几种方式小结
2016/03/06 Javascript
jQuery多级联动下拉插件chained用法示例
2016/08/20 Javascript
简单理解vue中track-by属性
2016/10/26 Javascript
Angular ui.bootstrap.pagination分页
2017/01/20 Javascript
jQuery Ajax全解析
2017/02/13 Javascript
详解vue引入子组件方法
2019/02/12 Javascript
利用Angular7开发一个Radio组件的全过程
2019/07/11 Javascript
jstree中的checkbox默认选中和隐藏示例代码
2019/12/29 Javascript
Vue实现小购物车功能
2020/12/21 Vue.js
[01:19:11]Ti4 循环赛第二日 NaVi.us vs iG
2014/07/11 DOTA
[00:56]跨越时空加入战场 全新祈求者身心“失落奇艺侍祭”展示
2019/07/20 DOTA
在Django中限制已登录用户的访问的方法
2015/07/23 Python
Python中的数据对象持久化存储模块pickle的使用示例
2016/03/03 Python
Python中staticmethod和classmethod的作用与区别
2018/10/11 Python
Python和Anaconda和Pycharm安装教程图文详解
2020/02/04 Python
python 日志模块 日志等级设置失效的解决方案
2020/05/26 Python
python函数map()和partial()的知识点总结
2020/05/26 Python
Python代码中如何读取键盘录入的值
2020/05/27 Python
Unineed旗下时尚轻奢网站:FABHunt
2019/05/13 全球购物
超市实习总结自我鉴定
2013/09/19 职场文书
文史专业毕业生自荐信
2013/11/17 职场文书
煤矿班组长岗位职责
2013/12/29 职场文书
鲁迅故里导游词
2015/02/05 职场文书
酒店辞职信怎么写
2015/02/27 职场文书
Python机器学习算法之决策树算法的实现与优缺点
2021/05/13 Python