As part of one of requirements we have to configure a job in which we need to use DBMail part.
From the DBMail we need to send a query results.
Query is like below:
But it is failed With below Error:
failed to initialize sqlcmd library with error number -2147467259. [SQLSTATE 42000] (Error 22050). The step failed.
When I googled in some place I found one work around for this:
We need to mention the Table name as:
Dbname.owner.tablename
Here in my scenario it is:
msdb.dbo.jobstatus
Query looks like below:
@query='select [Job Name],[last start date] from msdb.dbo.jobstatus where [Job Name] NOT LIKE (''DBA -%'') and [last run message] like ''the job faile%'''
This work around was very useful but at one of the server, again same error was thrown.
After researching and googling in one of the article mentioned to run the profiler, which resolved the issue.
SQL Server agent service accounts were mapped to local system account.
And the query was running by NT Authority/System user which have only public role, nothing else.
So I have given DBOwner privilages on MSDB database to that account.
Immediately issue got resolved.
From the DBMail we need to send a query results.
Query is like below:
exec
sp_send_dbmail @profile_name='SQL Server Alerts',
@recipients
= 'mailed@mailed.com;',
@subject ='Job failures on server',
@query='select [Job Name],[last start date] from jobstatus where [Job Name] NOT LIKE (''DBA -%'') and [last run message] like ''the job faile%''',
@body='Jobs Failure list';
But it is failed With below Error:
failed to initialize sqlcmd library with error number -2147467259. [SQLSTATE 42000] (Error 22050). The step failed.
When I googled in some place I found one work around for this:
We need to mention the Table name as:
Dbname.owner.tablename
Here in my scenario it is:
msdb.dbo.jobstatus
Query looks like below:
@query='select [Job Name],[last start date] from msdb.dbo.jobstatus where [Job Name] NOT LIKE (''DBA -%'') and [last run message] like ''the job faile%'''
This work around was very useful but at one of the server, again same error was thrown.
After researching and googling in one of the article mentioned to run the profiler, which resolved the issue.
SQL Server agent service accounts were mapped to local system account.
And the query was running by NT Authority/System user which have only public role, nothing else.
So I have given DBOwner privilages on MSDB database to that account.
Immediately issue got resolved.
No comments:
Post a Comment