从零开始搭建Python web框架——Django(三)
程序员文章站
2022-06-17 09:29:13
...
Django支持多种数据库,如PostgreSQL、MySQL、SQLite、Oracle。Django模型提供了统一的接口实现数据的CURD操作,所以可以很方便地切换数据库。
下面将介绍Django model的使用,笔者以MySQL数据库为例:
步骤↓
- 安装mysqlclient,用于Django与数据库的交互:
ubuntu系统如下:
sudo apt-get install libmysql-dev sudo apt-get install libmysqlclient-dev sudo apt-get install python-dev sudo pip install mysqlclient
windows系统如下:(1) https://www.lfd.uci.edu/~gohlke/pythonlibs/# 下载对应python版本且对应操作系统位数的版本安装包,如python 2.7,64位操作系统下载:mysqlclient-1.3.7-cp27-none-win_amd64.zip
(2) 解压安装包,进入目录打开cmd,使用pip install命令安装:
pip install mysqlclient-1.3.7-cp27-none-win_amd64
注:若没有安装pip请自行安装。 - 配置数据库参数:打开Django项目中的settings.py,做如下配置:
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', # 或者使用 mysql.connector.django 'NAME': 'ds', #数据库名 'USER':'root', #数据库用户 'PASSWORD': '1234', #数据库密码 'HOST':'localhost', #数据库服务器IP 'PORT':'3306', #端口 } }
- 创建app:进入项目根目录,执行:
django-admin.py startapp TestModel
windows系统执行:django-admin startapp TestModel
在settings.py中做如下配置,将刚刚建好的app TestModel 配置进项目中:
INSTALLED_APPS = ( 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'TestModel', # 添加此项 )
HelloWorld |-- TestModel | |-- __init__.py | |-- admin.py | |-- models.py | |-- tests.py | `-- views.py
- 建立模型:打开models.py,编写一个模型:
class Movie(models.Model): moviename = models.CharField('电影名', max_length=100) createtime = models.DateTimeField('发表时间', auto_now_add=True) updatetime = models.DateTimeField('更改时间', auto_now=True) publishtime = models.CharField('发布时间', max_length=10, blank=True) types = models.CharField('类型', max_length=200, blank=True) area = models.CharField('地区', max_length=200, blank=True) language = models.CharField('语言', max_length=200, blank=True) def __unicode__(self): return self.moviename class Outsource(models.Model): num = models.IntegerField('第几集',default=1) outfilelink = models.CharField('外部文件链接',max_length=500) movie = models.ForeignKey(Movie,verbose_name="电影") def __unicode__(self): return self.num
说明:我们可以在models.py中通过建立一个集成model.Model的类来创建模型。Django可以根据models自动在数据库中建表,属性名即为表的字段名,models.IntegerField等表示字段的数据类型,default参数表示默认值,第一个参数可以显示在Django admin的表单中,我们可以理解为注释,但是Django不会真的给数据库表中添加注释。models.ForeignKey可以指定外键,一部电视剧有好多级,所以在资源表中使用剧集作为外键,除此之外Django模型还支持ManyToMany、OneToOne等关系。blank=True指定字段可以为空,默认不可以。null=True表示Django会使用null填充空字段,默认不允许为空。max_length指定字段长度。 - 创建migrations并创建表结构:
$ python manage.py migrate # 创建表结构 $ python manage.py makemigrations TestModel # 生成migrations $ python manage.py migrate TestModel # 创建表结构
说明:可以在app目录中看到migrations包,它会记录每次的变更,我们可以打开里边的文件阅读它。打开数据库,我们可以看到表结构已经构建好。注:如果对模型进行了修改,执行以上命令,Django会自动修改表结构,且不会清空表中已存在的数据,十分方便。 - 对数据进行CURD操作:(这里我贴一些零散的代码)
movie = get_object_or_404(Movie, id=id) #这个方法用在views中,若无记录会返回404 movie.playcount += 1 movie.save() #若数据库中存在数据,修改。若不存在,插入。相当于SQL中的merge语句 n = movie.avaliblesum=movie.outsource_set.count() #返回该电视剧一共有多少集,参看上边的模型定义例子 print n for outsource in movie.outsource_set.all(): ##返回该电视剧的每一集 print outsource.outfilelink #过滤器,相当于where语句,以下意思是(where weight>=5 and classkey=#{key} order by createtime desc limit 0 12) movies = Movie.objects.filter(weight__gte=5).filter(classkey=key).order_by('-createtime')[:12] #以下意思是(where keyword like '%#{key}%' or moviename like '%#{key}%' ),若要使用'或',必须使用Q对象 allmovies = Movie.objects.filter(Q(keyword__icontains=key) | Q(moviename__icontains=key)) # 删除id=1的数据 # Test.objects.filter(id=1).delete() # 删除所有数据 # Test.objects.all().delete() # 修改其中一个id=1的name字段,再save,相当于SQL中的UPDATE test1 = Test.objects.get(id=1) test1.name = '222' test1.save() # 另外一种方式 #Test.objects.filter(id=1).update(name='222') # 修改所有的列 # Test.objects.all().update(name='222') # 通过objects这个模型管理器的all()获得所有数据行,相当于SQL中的SELECT * FROM list = Test.objects.all() # 获取单个对象 response3 = Test.objects.get(id=1)
注:此处只是举了一些常用例子,若要详细了解,请看官方文档。Django 模型非常强大,可以代替大部分常用的原生SQL语句。当然使用Django也支持引入原生SQL语句,此处不介绍。且使用Django也并非必须要使用Django model,Django是一个低耦合框架,它的每一个模块都可以按需求和喜好取舍。
上一篇: 150行代码写爬虫(一)
下一篇: C++书籍阅读列表
推荐阅读
-
全面解读Python Web开发框架Django
-
python常用web框架简单性能测试结果分享(包含django、flask、bottle、tornado)
-
Linux系统上Nginx+Python的web.py与Django框架环境
-
【从零开始搭建自己的.NET Core Api框架】(三)集成轻量级ORM——SqlSugar:3.3 自动生成实体类
-
使用Python的Flask框架来搭建第一个Web应用程序
-
给Python的Django框架下搭建的BLOG添加RSS功能的教程
-
Python实现手写一个类似django的web框架示例
-
python的web框架---Django项目
-
python自己动手从零开始搭建FTP服务器2 FTP初步框架
-
Linux系统上Nginx+Python的web.py与Django框架环境