Django 使用myslq视图

1、创建两张表

class Customer(models.Model):
    pass
    
    class Meta:
        db_table = 'Customer'


class Sale(models.Model):
    pass
    
    class Meta:
        db_table = 'Sale'

2、在MySQL中创建视图

3、在models同级的目录下创建文件(表的名字必须与数据库中创建的视图同名)(!!!在class名中 的最后加上V,在migrate时会忽略视图

class CustomerInfoSaleV(models.Model):
    name = models.CharField(max_length=50, verbose_name="客户姓名")
    phone = models.CharField(max_length=50, verbose_name="客户电话")
    introducer = models.CharField(max_length=50, verbose_name="被介绍人")
    introducer_phone = models.CharField(max_length=50, verbose_name="被介绍人电话")
    buy_date = models.CharField(max_length=50, verbose_name="被介绍时间")

    class Meta:
        db_table = 'view_customer_sale'

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Django使用数据库视图非常简单,只需要在模型类中使用Meta类的db_table属性指定视图的名称即可。下面是一个使用MySQL视图的示例: 假设我们有一个名为my_view的MySQL视图,它是基于以下SQL查询创建的: ```sql CREATE VIEW my_view AS SELECT column1, column2 FROM my_table WHERE column3 = 'value'; ``` 现在我们需要在Django中访问这个视图。首先,我们需要在Django的settings.py文件中配置数据库连接信息。这个过程略过。 接下来,我们可以创建一个名为MyView的模型类,用于访问这个视图: ```python from django.db import models class MyView(models.Model): column1 = models.CharField(max_length=100) column2 = models.CharField(max_length=100) class Meta: managed = False db_table = 'my_view' ``` 在这个模型类中,我们定义了与视图中相同的字段,并使用Meta类的managed属性将其设置为False,表示这个模型类不会被Django管理。然后,我们使用db_table属性指定视图的名称。 现在,我们就可以像使用任何其他Django模型类一样使用MyView了: ```python # 获取所有数据 my_view_data = MyView.objects.all() # 过滤数据 my_view_data_filtered = MyView.objects.filter(column1='value') ``` 这样,我们就可以在Django中访问MySQL视图了。需要注意的是,由于视图是只读的,因此我们无法通过模型类来修改视图中的数据。如果需要修改数据,还是需要通过原始的MySQL表来进行操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值