django sqlite3 mysql_django+sqlite3进行web开发(一)

服务器配置

安装django

sudo apt-get install python-django -y

安装mysql(可选)

也可以直接使用sqlite

sudo apt-get install mysql-server-5.6

sudo apt-get install mysql-client-5.6

sudo apt-get install python-mysqldb

测试项目Hello World

在我们的项目根目录下执行:

django-admin startproject HelloWorld

HelloWorld即是我们的项目名称。截图后的目录结构:

xl@xl-Z270-HD3:~/file/code/HelloWorld$ tree

.

└── HelloWorld

├── HelloWorld

│ ├── __init__.py

│ ├── settings.py

│ ├── urls.py

│ └── wsgi.py

└── manage.py

2 directories, 5 files

各个文件的作用:

HelloWorld: 项目的容器

manage.py: 命令行工具,用于和Django交互

HelloWorld/init.py:空文件,告诉python,该目录是一个Python包

HelloWorld/settings.py : 对该项目的配置文件

HelloWorld/urls.py : 该项目的url声明

HelloWorld/wsgi.py : 服务器入口

然后,运行服务器:

python manage.py runserver

当服务器运行成功后,就可以访问http://127.0.0.1:8000查看'Welcome to Diango'界面。

添加自己的app

一个Django project下可以有多个App,而一个App就是一个具体的Web应用程序,用来实现具体的功能和完成具体的事项。

可以通过manage.py快速创建一个app:

python manage.py startapp testapp

这样就创建了一个名为testapp的Django App,看看当前目录的变化,在project根目录下会多出一个testapp的目录,其目录结是:

xl@xl-Z270-HD3:~/file/code/HelloWorld/HelloWorld/testapp$ tree

.

├── admin.py

├── apps.py

├── __init__.py

├── migrations

│ └── __init__.py

├── models.py

├── tests.py

└── views.py

1 directory, 7 files

其中:

admin.py:用于设置 Django 自带的强大管理后台;

apps.py:声明了这个的 App 信息;

models.py:用于定义数据模型(数据库表);

tests.py:用于单元测试;

views.py:用于定义 App 的视图,也就是业务函数。

这包含了一个 Web 应用的后台管理、数据库定义、逻辑视图,在结合项目的路由映射,就是一个 Django App 最基本的结构。

migrations 文件夹目前是一个空的文件夹,其中会记录应用的数据模型迁移的情况。

然后我们需要使用manage.py文件的migrate 和 makemigrations 命令,创建一些默认的数据库表:

python manage.py migrate

运行命令,会显示将会对数据库进行很多个表的实例化和迁移.

然后,我们将testapp添加到HelloWorld项目的App列表中,即在settings.py文件中找到INSTALLED_APPS,将testapp加到最后面。

接着,可以使用 makemigrations 命令来检测项目中数据模型的数据迁移变化:

python manage.py makemigrations testapp

创建超级用户

我们可以为项目创建一个超级管理员,通过这个账户,可以快速使用 Django 强大的后台功能,对数据模型进行管理:

python manage.py createsuperuser

根据提示输入用户名、邮箱和密码,一个超级用户就创建好了。我们可以运行项目,访问http://127.0.0.1:8000/admin路径看看:

python manage.py runserver

可以使用刚刚创建的管理员账户登录。

修改我们的网页

修改视图文件

编辑testapp目录下views.py,加入以下内容:

from django.http import HttpResponse

def hello(request):

return HttpResponse("Hello world!")

在这里,我们定义了一个hello视图。

注意, 一个视图就是Python的一个函数。这个函数第一个参数的类型是HttpRequest;它返回一个HttpResponse实例。为了使一个Python的函数成为一个Django可识别的视图,它必须满足这两个条件。

进行URL配置

为了告诉服务器我们配置的视图,需要进行URL配置。在HelloWorld目录下的urls.py中添加:

from testapp.views import hello

urlpatterns = [

...

url(r'^hello/$', hello),

]

这时,我们再重新启动服务器,访问http://127.0.0.1:8000/hello/,就可以看到不一样的结果了。

编写一个动态网页

上面的例子每次返回的都是一样的内容,它可以算是一个静态网页。但其实使用python每次返回不同的内容,就可以算是动态网页了。

我们把views.py中的添加一个视图:

import time

def current_time(request):

return HttpResponse("Current time is: "+time.strftime('%Y-%m-%d %H:%M:%S'))

同样在urls.py中配置URL:

from testapp.views import current_time

urlpatterns = [

......

url(r'^current_time/$', current_time),

]

这时,我们再重新启动服务器,访问http://127.0.0.1:8000/current_time/,就可以看到每次都不一样的网页了。

数据库

与数据库相关的代码一般写在models.py中,Django 支持 sqlite3, MySQL, PostgreSQL等数据库,只需要在settings.py中配置即可,不用更改models.py中的代码。

创建数据表

我们打开 testapp/models.py 文件,修改其中的代码如下:

from django.db import models

class Test(models.Model):

a = models.CharField(max_length=30)

b = models.IntegerField()

然后,同步一下数据库。(默认使用sqlite3数据库,无需做任何配置)

先进入到manager.py所在的文件夹下,输入以下命令:

# Django 1.6.x 及以下

python manage.py syncdb

# Django 1.7 及以上的版本需要用以下命令

python manage.py makemigrations

python manage.py migrate

Django生成了一系列的表,也包括我们在testapp/models.py中定义的testapp_test这个表。

插入和查询数据

作为测试,我们可以调起Django的shell:

xl@xl-Z270-HD3:~/file/code/HelloWorld/HelloWorld$ python manage.py shell

Python 2.7.15rc1 (default, Nov 12 2018, 14:31:15)

[GCC 7.3.0] on linux2

Type "help", "copyright", "credits" or "license" for more information.

(InteractiveConsole)

>>> from testapp.models import Test

>>> Test.objects.create(a="zhangsan", b=24)

>>> Test.objects.get(a="zhangsan")

>>>

注意这里使用.objects.get()方法查询出来的对象都是显示一个结构体。

具体操作可以参考https://code.ziqiangxuetang.com/django/django-models.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值