Still celebrating National IT Professionals Day with 3 months of free Premium Membership. Use Code ITDAY17

x
?
Solved

How to make a scheduled query

Posted on 2004-03-26
6
Medium Priority
?
180 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
Efficient way to get backups off site to Azure

This user guide provides instructions on how to deploy and configure both a StoneFly Scale Out NAS Enterprise Cloud Drive virtual machine and Veeam Cloud Connect in the Microsoft Azure Cloud.

 

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 1000 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

Concerto's Cloud Advisory Services

Want to avoid the missteps to gaining all the benefits of the cloud? Learn more about the different assessment options from our Cloud Advisory team.

Question has a verified solution.

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

What if you have to shut down the entire Citrix infrastructure for hardware maintenance, software upgrades or "the unknown"? I developed this plan for "the unknown" and hope that it helps you as well. This article explains how to properly shut down …
Ready to get certified? Check out some courses that help you prepare for third-party exams.
Using examples as well as descriptions, and references to Books Online, show the documentation available for date manipulation functions and by using a select few of these functions, show how date based data can be manipulated with these functions.
Viewers will learn how the fundamental information of how to create a table.

722 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