获取postgres数据库所有表名

  • 获取postgres数据库的所有表名

        def get(self):
            try:
                tables = connection.introspection.table_names()
                return JsonRes(tables, success=True, info="get database name Successfully.")
            except Exception as err:
                return JsonRes(None, success=False, info='get database name failed, please check the format.')
    

    最后tables=[‘table1’, ‘table2’]

  • 获取postgres数据库的一个表的所有column

    def get(self, request, tablename):
        try:
            with connection.cursor() as cursor:
                desc = connection.introspection.get_table_description(cursor, tablename)
                columns = [r[0] for r in desc]
            return JsonRes(columns, success=True, info="get column name Successfully.")
        except Exception as err:
            return JsonRes(None, success=False, info='get column name failed.')

这里区分以下flask和django下module的区别
django

# 从django引入module
from django.db import models

class USER(models.Model):

    name = models.CharField(db_index=True, max_length=200, null=False, default='')
    description = models.CharField(max_length=255, null=False, default='')
    teacher_id= models.ForeignKey('TEACHER', on_delete=models.CASCADE, default=1)
	# teacher_id作为user的外键
  
    class Meta:
        db_table = 'user'
        # 数据库名

    def __str__(self):
        return self.name

flask

from sqlalchemy import Column, String, ForeignKey

from cxcomm.db.model import BaseTable, HasId, HasTime


class USER(BaseTable, HasId, HasTime):
 
    __tablename__ = 'user'

    name = Column(String(255), nullable=False)
	description = Column(String(255), nullable=False)
    teacher_id= Column(String(36), ForeignKey('teacher.id'), nullable=True, index=True)

from yactrl.models.user import USER
# 导入之前的模型
from cxcomm.db.ormobject import ORMBaseObject
from cxcomm.db import fields


class USERObj(ORMBaseObject):
    """snmp object
    """
    db_model = USER
    fields = {
        'id': fields.UUIDField(nullable=True),
        'name ': fields.StringField(nullable=False),
        'description ': fields.UUIDField(nullable=False),
        'teacher_id': fields.StringField(nullable=True)
    }
    allow_update_key = ['description ']
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值