Solved

DOEVENTS in SQL

Posted on 2004-08-04
8
2,171 Views
Last Modified: 2012-05-05
Hi,

anyone know of a DOEVENTS type command in SQL Server?

For info, this is to allow processor time to catch-up while processing OA objects.

bukko
0
Comment
Question by:bukko
  • 5
  • 3
8 Comments
 
LVL 26

Expert Comment

by:Hilaire
ID: 11715702
There is no event handling in SQL Server, at least not the same kind of events(mousemove, keypress, paint, activate) than in client applications in which you'd use DoEvents in VB.

The only "events" in SQL server are, unless I'm wrong, the INSERT, UPDATE, DELETE events that fire triggers.
You can disable and enable triggers using alter table ....

COuld you be more precise on what you want to achieve ?
0
 
LVL 8

Author Comment

by:bukko
ID: 11715779

I'm calling a method in an OA object, then reading an IsRunning type property, which contantly returns 1 (Yes).
I'm wondering if this is because it doesn't have time to do what it needs because of being contanly polled.
If I build the object into an exe and call using xp_cmdshell, all works fine. However, I'm not allowed access to xp_cmdshell for security reasons.
So, what I need is a way to release processor time so the component can get on with its life without me bothering it too much.

Any ideas?

bukko
0
 
LVL 26

Accepted Solution

by:
Hilaire earned 500 total points
ID: 11715808
If you use the OA objects in a loop,

I think (not sure but it's worth a try) the issuing a
WAITFOR DELAY '00:00:01'
inside the loop
will leave a little CPU time (1 sec) for other processes

If it's the OA objects that take CPU time and don't leave enough for SQL Server to handle client requests properly, I'm afraid there's not much you can do.

Can you post your code ?
0
 
LVL 8

Author Comment

by:bukko
ID: 11715833
I'll try the WAITFOR thing; if that doesn't work I'll post my code.

Ta...
0
What Should I Do With This Threat Intelligence?

Are you wondering if you actually need threat intelligence? The answer is yes. We explain the basics for creating useful threat intelligence.

 
LVL 8

Author Comment

by:bukko
ID: 11715986
Hilaire,

I think your logic is ok, but it still aint working. Maybe it's not a CPU thing at all.

The component is a PDF creating component.
My SQL code as follows:

      -- Check if object busy
      EXEC      @result      = master.dbo.sp_OAGetProperty @h_pdf, 'StillRunning', @running OUT
      IF (@@ERROR|@result > 0)
            RAISERROR('Unable to read StillRunning property', 16, 1)

      WHILE      @running = 1
            BEGIN
            WAITFOR DELAY '00:00:01'
            EXEC      @result      = master.dbo.sp_OAGetProperty @h_pdf, 'StillRunning', @running OUT
            IF (@@ERROR|@result > 0)
                  RAISERROR('Unable to read StillRunning property', 16, 1)
            PRINT @running
            END

      EXEC      @result      = master.dbo.sp_OADestroy 16711422
      IF (@@ERROR|@result > 0)
            RAISERROR('Unable to destroy PDF component', 16, 1)


Any ideas?
0
 
LVL 26

Expert Comment

by:Hilaire
ID: 11716015
the "createObject" or sp_OACreate should return an INT value @h_pdf

You should use this handle to destroy the object
Instead, you use a hard-coded 16711422

Is it a typo ?

it should be

EXEC     @result     = master.dbo.sp_OADestroy @h_pdf

0
 
LVL 8

Author Comment

by:bukko
ID: 11716073
Yeah, that's just my test snip.
I do normally use @h_pdf
0
 
LVL 8

Author Comment

by:bukko
ID: 11716478
I wrapped the PDf component in an ActiveX dll and it works fine now.

I'm giving you the points for your suggestion, which is actually what I asked for!

Thanks.

bukko
0

Featured Post

Enabling OSINT in Activity Based Intelligence

Activity based intelligence (ABI) requires access to all available sources of data. Recorded Future allows analysts to observe structured data on the open, deep, and dark web.

Join & Write a Comment

Nowadays, some of developer are too much worried about data. Who is using data, who is updating it etc. etc. Because, data is more costlier in term of money and information. So security of data is focusing concern in days. Lets' understand the Au…
Slowly Changing Dimension Transformation component in data task flow is very useful for us to manage and control how data changes in SSIS.
Via a live example, show how to setup several different housekeeping processes for a SQL Server.
Viewers will learn how to use the SELECT statement in SQL and will be exposed to the many uses the SELECT statement has.

762 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

24 Experts available now in Live!

Get 1:1 Help Now