`

从零开始搭建Python web框架——Django(三)

阅读更多

Django支持多种数据库,如PostgreSQL、MySQL、SQLite、Oracle。Django模型提供了统一的接口实现数据的CURD操作,所以可以很方便地切换数据库。

 下面将介绍Django model的使用,笔者以MySQL数据库为例:

步骤↓

  1. 安装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请自行安装。

     

  2. 配置数据库参数:打开Django项目中的settings.py,做如下配置:
    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.mysql',  # 或者使用 mysql.connector.django
            'NAME': 'ds',               #数据库名
            'USER':'root',              #数据库用户
            'PASSWORD': '1234',         #数据库密码
            'HOST':'localhost',         #数据库服务器IP
            'PORT':'3306',              #端口
        }
    }
     
  3. 创建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',               # 添加此项
    )
     

     

     说明:项目和应用的区别?一个应用程序是一个Web应用程序,它可以执行某些操作,例如一个博客系统。一个项目是特定网站的配置和应用程序的集合。一个项目可以包含多个应用。一个应用可以运用到多个项目中去。
    HelloWorld
    |-- TestModel
    |   |-- __init__.py
    |   |-- admin.py
    |   |-- models.py
    |   |-- tests.py
    |   `-- views.py
     
  4. 建立模型:打开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指定字段长度。
  5. 创建migrations并创建表结构:
    $ python manage.py migrate   # 创建表结构
    $ python manage.py makemigrations TestModel  # 生成migrations
    $ python manage.py migrate TestModel   # 创建表结构
      说明:可以在app目录中看到migrations包,它会记录每次的变更,我们可以打开里边的文件阅读它。打开数据库,我们可以看到表结构已经构建好。注:如果对模型进行了修改,执行以上命令,Django会自动修改表结构,且不会清空表中已存在的数据,十分方便。
  6. 对数据进行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是一个低耦合框架,它的每一个模块都可以按需求和喜好取舍。

 

1
0
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics