orm(Manager isn't accessible via %s instances" % cls.__name)报错
报错信息
Manager isn't accessible via %s instances" % cls.__name
解决方法
https://www.jianshu.com/p/5e05c9360662 转载自这位大佬,非常感谢
Django 的 orm 中使用到了元类和描述符这些高级知识,了解一下的可以看看这篇文章。 元类其实就是用来定义类的,我的理解是这样的:当很多类有相同的属性,那么就可以提取这些相同的属性到一个类中,元类就是用来封装那些的,或者给某些类添加一些属性,定制类。你看看 Django model 写的代码有多少,而背后元类默默做了很多东西。 Django model 需要继承自 models.Model,跟踪进去发现 class Model(metaclass=ModelBase):,Model 其实是根据 ModelBase 构建的,在实例化的时候,会首先执行 ModelBase 的 __new__ 方法。
里面为我们封装了 _meta 这么一个属性,具体的可以看看源码。 我们查询数据的时候一直用到 obejcts 方法,那么它是哪来的呢?在封装self._meta 后调用了 _prepare,在它里面发现了一个管理器 manager。 if not opts.managers: if any(f.name == 'objects' for f in opts.fields): raise ValueError( "Model %s must specify a custom Manager, because it has a " "field named 'objects'." % cls.__name__ ) manager = Manager() manager.auto_created = True cls.add_to_class('objects', manager) 这里使用了 manager ,然后注册了 objects。那么来看看 Manager: class Manager(BaseManager.from_queryset(QuerySet)): pass 什么也没做,只是根据 BaseManager 的类方法构造了一个类,然后继承了它,就是 QuerySet,到这里,你就大体明白了吧,我们一般查询出来的都是一个 QuerySet 对象。
@classmethod def from_queryset(cls, queryset_class, class_name=None): if class_name is None: class_name = '%sFrom%s' % (cls.__name__, queryset_class.__name__) class_dict = { '_queryset_class': queryset_class, } class_dict.update(cls._get_queryset_methods(queryset_class)) return type(class_name, (cls,), class_dict) 这里使用了 type 来创造一个类。 其实准确来说,Manager 应该是继承了两个类 BaseManager 和 QuertSet。 再来看看 add_to_class: def add_to_class(cls, name, value): # We should call the contribute_to_class method only if it's bound if not inspect.isclass(value) and hasattr(value, 'contribute_to_class'): value.contribute_to_class(cls, name) else: setattr(cls, name, value) 这里又调用了 manager 的 contribute_to_class 方法: def contribute_to_class(self, model, name): if not self.name: self.name = name self.model = model setattr(model, name, ManagerDescriptor(self)) model._meta.add_manager(self) 又给 objects 赋值了一个 ManagerDescriptor 实例,这个是干嘛的呢?属性描述符: class ManagerDescriptor: def __init__(self, manager): self.manager = manager def __get__(self, instance, cls=None): if instance is not None: raise AttributeError("Manager isn't accessible via %s instances" % cls.__name__) if cls._meta.abstract: raise AttributeError("Manager isn't available; %s is abstract" % ( cls._meta.object_name, )) if cls._meta.swapped: raise AttributeError( "Manager isn't available; '%s.%s' has been swapped for '%s'" % ( cls._meta.app_label, cls._meta.object_name, cls._meta.swapped, ) ) return cls._meta.managers_map[self.manager.name] 这里做了一些限制。 Django orm 四个重要类: Model,QuerySet,Query,Objects。 QuerySet 主要是定义了一些接口,如 filter, count 等。它是惰性求值的,它并不直接求出值,只是在需要的时候查询。 Query 实现 sql 的拼接,它将语句交给 sql 编译对象。 一次查询过程: Django 模型查询过程 如果还想深入,可以看看 QuerySet 的源码。 ps:objects 是一个 Manager 实例,而 Manager 是一个空壳,它继承自 QuerySet。
orm(Manager isn't accessible via %s instances" % cls.__name)报错的更多相关文章
- django报错Manager isn't accessible via UserInfo instances
		
出现这种错误是因为调用模型对象时使用了变量名,而不是对象名(模型类),例如: user = UserInfo()user_li = user.objects.filter(uname=username ...
 - CDH报错:ScmActive at bootup: Failed to validate the identity of Cloudera Manager.
		
报错原因以及解决办法在官网: https://www.cloudera.com/documentation/enterprise/5-8-x/topics/cm_failover_db.html 1. ...
 - tomcat8.5打开manager页面报错的问题
		
之前用的8.0版本的tomcat,最近需要将版本升级,当前8的最新的版本是8.5.42,升级之后发现manager页面打不开了,就是下面这个按钮的页面 点击之后报403没权的错误 还是按照8.0版本的 ...
 - Windows 8.1升级至Windows 10后,启动VisualSVN Server Manager报错:提供程序无法执行所尝试的操作 (0x80041024)的解决
		
1.1.Windows 8.1升级至Windows 10后,启动VisualSVN Server Manager报错:提供程序无法执行所尝试的操作 (0x80041024),VisualSVN Ser ...
 - Python报错TypeError: '<' not supported between instances of 'str' and 'int'
		
n = input() if n>=100:print(int(n)/10) else:print(int(n)*10) 报错内容: Traceback (most recent call la ...
 - python3 tkinter报错:_tkinter.TclError: cannot use geometry manager pack inside . which already has slaves managed by grid
		
报错: _tkinter.TclError: cannot use geometry manager pack inside . which already has slaves managed by ...
 - pytest pluggy.manager.PluginValidationError: unknown hook 'pytest_namespace'报错处理办法
		
一.背景说明 上周测试的同事说pytest+allure环境在别人电脑上跑没问题,在她的环境跑却报错让帮看一下.其实pytest只是听说过allure直接没听过,但不能直接表示不会,祭出百度大法. 看 ...
 - applicationContext.xml报错org.springframework.orm.hibernate3.LocalSessionFactoryBean not found
		
applicationContext.xml报错org.springframework.orm.hibernate3.LocalSessionFactoryBean not found 解决办法: 1 ...
 - linux===启动sdk manager下载配置sdk的时候报错的解决办法
		
当启动sdk manager下载配置sdk的时候,报错如下: botoo@botoo-virtual-machine:/opt/android-sdk-linux/tools$ sudo ./and ...
 
随机推荐
- Pytest测试框架(二):pytest 的setup/teardown方法
			
PyTest支持xUnit style 结构, setup() 和 teardown() 方法用于初始化和清理测试环境,可以保证测试用例的独立性.pytest的setup/teardown方法包括:模 ...
 - light-rtc: 理念与实践
			
在与同行交流过程中,发现很多同行对 WebRTC 改动太多,导致无法升级 WebRTC 版本.而 WebRTC 开源社区的快速迭代,让他们感到欣喜又焦虑:开源社区的迭代效果,是不是超过了他们对 Web ...
 - JVM内存模型总结,有各版本JDK对比、有元空间OOM监控案例、有Java版虚拟机,综合实践学习!
			
作者:小傅哥 博客:https://bugstack.cn Github:https://github.com/fuzhengwei/CodeGuide/wiki 沉淀.分享.成长,让自己和他人都能有 ...
 - i5 11300H和i5 10300H 的区别
			
i5-11300H 为 4 核 8 线程,主频 3.1GHz,睿频 4.4GHz,三级缓存 8MB 选 i5-11300H还是i5 10300h 这些点很重要!看完你就知道了https://list. ...
 - Modbus 仿真测试工具 Mod_Rssim 详细图文教程
			
Mod_RSsim是一款轻量级的Modbus从机模拟器,它可以模拟ModBusTCP和ModBusRTU的从机,能够同时模拟254个被控站,软件使用简单方便,可以满足一般的主机调试. 官方网站:www ...
 - 关于es6 let  var  const    以及Symbol的总结
			
```javascript //es6新增块级作用域.声明变量用关键字let const , // es5中只有函数作用域和全局作用域,声明变量用关键字var // let 和const 声明的变量 ...
 - 【Java】Jsoup爬虫,一个简单获取京东商品信息的小Demo
			
简单记录 - Jsoup爬虫入门实战 数据问题?数据库获取,消息队列中获取中,都可以成为数据源,爬虫! 爬取数据:(获取请求返回的页面信息,筛选出我们想要的数据就可以了!) 我们经常需要分析HTML网 ...
 - K8s 平台可以如何处理 Pod 预授权问题
			
前言 TKEx-CSIG 是基于腾讯公有云 TKE 和 EKS 容器服务开发的内部上云容器服务平台,为解决公司内部容器上云提供云原生平台,以兼容云原生.适配自研业务.开源协同为最大特点. 业务容器上云 ...
 - 【Linux】make编译的小技巧
			
------------------------------------------------------------------------------------------------- | ...
 - SQL Server management studio使用sa连接时报错与伺服器的连接已成功,但在登入程序是发生错误
			
使用Sql Server management studio的sa用户连接数据库时,报如下错误 解决方法: 1.使用windows验证登录 2.右键点击连接,点击属性,点击安全性,选择混合验证 3.重 ...