Solved

How to make a scheduled query

Posted on 2004-03-26
6
179 Views
Last Modified: 2010-07-27
Is there a way to do the following?: I need a simple count query to automatically run once a day and save the resulting text to a textfile (or preferably a html document...).  Please put up an example.

Thanks.
0
Comment
Question by:fabbo77
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 3
  • 2
6 Comments
 
LVL 8

Expert Comment

by:Dishan Fernando
ID: 10685430
Hi fabbo77,

Yes. You can do this. Create a Job and sechdule it.

Cheers!
DishanF.
0
 
LVL 8

Expert Comment

by:Dishan Fernando
ID: 10685477
fabbo77,

BCP works ok if you want to store the contents of a table to text file. If you want the contents of a stored procedure it gets complicated. In summary, you must use the stored procedure to fill a table, then use BCP to export the table, and finally you need to clear the table. I wish there was a better way!

Wait. There is and it's called OSQL. OSQL is a command line program that allows you to run SQL Statements. Let's look at the simplest form:

osql /U sa /P password /d pubs /S Server9 /Q "Select * from Authors"

Remember you are typing this into the operating system (command prompt) and NOT Query Analyzer. This will connect to the pubs database on Server9 and run the query Select * from Authors and output the results back to stdout (which is the screen unless you redirect it). And the arguement headers (-U, -P, etc.) are case sensitive. Go figure.

You wanted to get the result of a stored procedure. You can do that like this:

osql /U sa /P password /d pubs /S Server9 /Q "sp_help"

Now we need to save this in a file. The simplest way is like this:

osql /U sa /P password /d pubs /S Server9 /Q "sp_help" -o ofile.txt

This will store the results in a file called ofile.txt. You could store them in a Unicode file using -u ofile.txt. You can also embed the path information in the file name using quotes.

There are a couple of other cool things you can do with this. It's really easy to put the SQL statement you want to run in an environment variable using a batch file. You batch file will look something like this:

set mysqlcommand=sp_help
osql /U sa /P password /d pubs /S Server9 /Q "%mysqlcommand%"

This makes it pretty easy to build a batch system. You can also capture the SQL Server result code at the operating system level using the -b flag.

Other popular settings include disabling headers, setting the row width, using trusted connections and input redirection. With input redirection you can put a series of SQL commands into a file and execute them. Books Online has quite a bit more detail on OSQL if you're so inclined.

http://www.sqlteam.com/item.asp?ItemID=744

HTH
DishanF.
0
 
LVL 8

Expert Comment

by:Dishan Fernando
ID: 10685482
fabbo77,

place following statement in sql server job

EXEC master..xp_cmdshell 'osql /U sa /P password /d DatabaseName /S ServerName /Q "SELECT COUNT(1) AS Count FROM TableName" -o ofile.txt'


HTH
DishanF.
0
Percona Live Europe 2017 | Sep 25 - 27, 2017

The Percona Live Open Source Database Conference Europe 2017 is the premier event for the diverse and active European open source database community, as well as businesses that develop and use open source database software.

 

Author Comment

by:fabbo77
ID: 10687943
DishanF,

Thanks for the reply. Your script Works nicely. But the text is horribly corrupted when viewing in a text editor. Any tips, or should I live with it? :)

Best regards,
Janne
0
 
LVL 34

Accepted Solution

by:
arbert earned 250 total points
ID: 10688627
If you're going to make an HTML file, take a look at the SQL Web Task.  In enterprise mangaer, go to the tools menu, Wizards, Management, Web Assistant Wizard.

If will create the web page for you and schedule it to run....

Brett
0
 

Author Comment

by:fabbo77
ID: 10694767
Thanks Brett. This was exactly what I wanted. :)
Thanks also to DishanF for his answers.

Cheers,
Janne
0

Featured Post

Announcing the Most Valuable Experts of 2016

MVEs are more concerned with the satisfaction of those they help than with the considerable points they can earn. They are the types of people you feel privileged to call colleagues. Join us in honoring this amazing group of Experts.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Why is this different from all of the other step by step guides?  Because I make a living as a DBA and not as a writer and I lived through this experience. Defining the name: When I talk to people they say different names on this subject stuff l…
Recently we ran in to an issue while running some SQL jobs where we were trying to process the cubes.  We got an error saying failure stating 'NT SERVICE\SQLSERVERAGENT does not have access to Analysis Services. So this is a way to automate that wit…
Via a live example, show how to shrink a transaction log file down to a reasonable size.
Viewers will learn how to use the UPDATE and DELETE statements to change or remove existing data from their tables. Make a table: Update a specific column given a specific row using the UPDATE statement: Remove a set of values using the DELETE s…

617 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