2017-04-25 107 views
1

我正在尝试调用我正在使用的多数据库项目上的存储过程。我有我的存储过程的2个工作,但这个特殊的存储过程不工作,并返回一个错误:使用django-mssql调用存储过程

Traceback (most recent call last): 
File "d:\Projects\Django\AAAVirtualEnv\lib\site-packages\django\core\handlers\exception.py", line 39, in inner 
response = get_response(request) 
File "d:\Projects\Django\AAAVirtualEnv\lib\site-packages\django\core\handlers\base.py", line 187, in _get_response 
response = self.process_exception_by_middleware(e, request) 
File "d:\Projects\Django\AAAVirtualEnv\lib\site-packages\django\core\handlers\base.py", line 185, in _get_response 
response = wrapped_callback(request, *callback_args, **callback_kwargs) 
File "d:\Projects\Django\AAAVirtualEnv\lib\site-packages\django\views\decorators\csrf.py", line 58, in wrapped_view 
return view_func(*args, **kwargs) 
File "d:\Projects\Django\AAAVirtualEnv\lib\site-packages\django\views\generic\base.py", line 68, in view 
return self.dispatch(request, *args, **kwargs) 
File "d:\Projects\Django\AAAVirtualEnv\lib\site-packages\rest_framework\views.py", line 483, in dispatch 
response = self.handle_exception(exc) 
File "d:\Projects\Django\AAAVirtualEnv\lib\site-packages\rest_framework\views.py", line 443, in handle_exception 
self.raise_uncaught_exception(exc) 
File "d:\Projects\Django\AAAVirtualEnv\lib\site-packages\rest_framework\views.py", line 480, in dispatch 
response = handler(request, *args, **kwargs) 
File "d:\Projects\Django\HRSys\hrs\hrs_api\views.py", line 79, in post 
result_set = cursor.fetchall() 
File "d:\Projects\Django\AAAVirtualEnv\lib\site-packages\django\db\utils.py", line 101, in inner 
return func(*args, **kwargs) 
File "d:\Projects\Django\AAAVirtualEnv\lib\site-packages\django\db\utils.py", line 94, in __exit__ 
six.reraise(dj_exc_type, dj_exc_value, traceback) 
File "d:\Projects\Django\AAAVirtualEnv\lib\site-packages\django\utils\six.py", line 685, in reraise 
raise value.with_traceback(tb) 
File "d:\Projects\Django\AAAVirtualEnv\lib\site-packages\django\db\utils.py", line 101, in inner 
return func(*args, **kwargs) 
File "d:\Projects\Django\AAAVirtualEnv\lib\site-packages\sqlserver_ado\dbapi.py", line 719, in fetchall 
return self._fetch() 
File "d:\Projects\Django\AAAVirtualEnv\lib\site-packages\sqlserver_ado\dbapi.py", line 671, in _fetch 
self._raiseCursorError(FetchFailedError, 'Attempting to fetch from a closed connection or empty record set') 
File "d:\Projects\Django\AAAVirtualEnv\lib\site-packages\sqlserver_ado\dbapi.py", line 488, in _raiseCursorError 
eh(self.connection, self, errorclass, errorvalue) 
File "d:\Projects\Django\AAAVirtualEnv\lib\site-packages\sqlserver_ado\dbapi.py", line 103, in standardErrorHandler 
raise errorclass(errorvalue) 
django.db.utils.Error: Attempting to fetch from a closed connection or empty record set 

这是我如何调用存储过程:

cursor = connections['backend'].cursor() 
    try: 
     cursor.callproc('[dbo].[GetLogonControlJSON]', ['10011', 'encrypted', '127.0.0.1']) 
     result_set = cursor.fetchall() 
    finally: 
     cursor.close() 

我这样做太,但我仍然得到相同的错误:

cursor = connections['backend'].cursor() 
try: 
    cursor.execute('EXEC [dbo].[GetLogonControlJSON] @LogonID=%s, @Password=%s, @IP=%s' % ('10011', 'encrypted', '127.0.0.1')) 
    result_set = cursor.fetchall() 
finally: 
    cursor.close() 

请帮助我。 :)

谢谢!

回答

1

在这种情况下,您应该使用​​方法而不是callproc()

错误消息告诉你的一切:

Attempting to fetch from a closed connection or empty record set

看看文档(第二个例子):Stored Procedures

+0

感谢您的快速回复。我已经完成了你所说的但仍然是同样的错误。 –

+0

然后,应该检查连接是否仍然打开。此外,您可以检查问题是否与返回的数据集有关 - 只需更改您的过程以在每次调用时返回至少一个元素。 –

+0

我很确定我的存储过程正在工作。因为我在SSMS中测试它工作正常。 –