Tuesday, December 22, 2009
SSIS handling errors in control flow
FailParentOnFailure = True
MaximumErrorCount = 99999 (an "infinite" value)
Monday, December 21, 2009
SQL Server Agent Jobs and GUI Automation
An application vendor has provided an application database maintenance utility that only has a GUI interface. You want to automate this maintenance activity as a SQL Server Agent job.
The best solution would probably be to tell the vendor to add a command line interface to the utility to facilitate unattended use. Unfortunately the vendor may be unable or unwilling to achieve this.
A Solution
- Use AutoIt to script and compile an executable that will perform unattended execution of the ute
- Call the AutoIt-generated exe from a SQL job using CmdExec
Step 1 is challenging, particularly if the vendor's utility is complex or poorly documented. Step 2 can be difficult to implement due to environment constraints.
With AutoIt you have the choice of
- installing the AutoIt environment and running the .au3 script file
- compiling a .exe from the script
In my experience you'll have far less trouble getting the exe approved by change control than requesting deployment of the entire AutoIt installation.
1. AutoIt
AutoIt v3 is the latest available version. The download contains a useful help file and example scripts. The web also has plenty of documentation and forum discussions on most topics you might be interested in. I'll just cover off a few points I thought were important:
- The language is a variant of Pascal
- Line continuation is performed with _
- Carriage return & line feed is represented by @CRLF
- Variable $CmdLine[0] contains the number of command line parameters provided
- ConsoleWrite() can be used to provide feedback and debug info
- The included Au3Info.exe is a handy GUI spy for identifying those much-needed CLASS and INSTANCE values
- Some functions are not suited to unattended use (see Q21 excerpt from AutoIt FAQ below)
- If your script is too fast, add some Sleep(n) statements to let the GUI catch up
- With the WinExists() function, AutoIt is able to handle GUI events that are too fast for a human to intercept or even perceive. Therefore writing a script based on manual user steps may be insufficient to properly control the GUI
A21. On locked station any window will never be active (active is only dialog with text "Press Ctrl+Alt+Del")In Windows locked state applications runs hidden (behind that visible dialog) and haven't focus and active status.
So generally don't use Send() MouseClick() WinActivate() WinWaitActive() WinActive() etc.Instead use ControlSend() ControlSetText() ControlClick() WinWait() WinExists() WinMenuSelectItem() etc.
This way you may have your script resistive against another active windows.and it's possibe to run such script from scheduler on locked Windows station.
2. SQL job
The SQL Server Agent is a service. By default, services do not interact with the desktop. This means your AutoIt exe can launch the utility but will be unable to detect or use any of its GUI elements.
To allow SQL Server Agent to interact with the desktop:
- Start:Administrative Tools:Services
- Right-click SQL Server Agent and select Properties
- Select the Log On tab
- Select Local System Account, check "Allow service to interact with desktop" and click OK
- Restart SQL Server Agent (right-click and Restart)
Note the checkbox "Allow service to interact with desktop" is only available for the Local System Account. To use other accounts, they would need to be enabled to "Act as part of the operating system".
Potential problems are around whether Local System is suitable for running the agent service. Local System may not be suitable for other jobs on the same server. Some jobs may need permissions to other servers and it may not be appropriate to grant them to Local System.
A workaround would be to create a separate SQL Server Agent instance on the same server, just for jobs that need to interact with the desktop. However the additional instance will consume server resources.
A minor annoyance: a desktop-interaction-enabled SQL Server Agent will insist on keeping a Command Prompt window open while it's running.
Tuesday, December 15, 2009
SSIS - annoying animated data viewer creation
Mild irritation becomes serious annoyance when a live issue is being tested on a box under heavy load and the lil data viewers are taking a minute each to parachute into the data flow.
Tuesday, December 8, 2009
Copying SQL Server 2005 push replication using Generate Scripts
- Right-click the publication (in SSMS, Replication: Local Publications) and select Generate Scripts...
- Select To Create or Enable the Components
- Choose file location and Save
- OK and Close
- If the server has never had replication before, manually create and delete a test publication (right-click Local Publications & select New Publication, choose some random stuff, then right-click the test publication and Delete). This will ensure the distribution database is created along with other stuff needed for replication
- Open the script, replace the servers and logins as appropriate
- Run on the target server
Monday, December 7, 2009
Using sp_msforeachtable on remote databases
- Right-click the Linked Server and select properties
- Select Server Options
- Click RPC & RPC Out and OK
exec [remoteserver].[remotedb].[dbo].sp_MSforeachtable "ALTER TABLE ? DISABLE TRIGGER ALL"
Monday, November 23, 2009
SSAS and percentage measures
Let's say you have the following base measures that are the raw data held in the source system:
- ListPriceDollars
- StandardDiscountPercentage
The cube users require these two measures and an additional StandardDiscountPriceDollars measure to be available for use.
In this situation, it's easy to get stuck at the point of ensuring StandardDiscountPercentage displays sensible numbers at all aggregation levels. There are plenty of options to play with - aggregation functions, measure expressions, calculated members, etc. For people with more of a SQL than MDX background there's a lot to understand here. Throw in some null values and a parent-child relationship and you'll be torturing yourself trying to find the best way to represent this in SSAS.
Solution Option
One possibility is to completely avoid trying to aggregate percentages.
- Change your source view or named query to calculate StandardDiscountPriceDollars (=Product.ListPriceDollars / (1 - (Product.StandardDiscountPercentage/100))
- Don't use the raw StandardDiscountPercentage value in the cube - instead, create a simple replacement calculated member (= 1 - ([Measures].[Standard Discount Price Dollars] / [Measures].[List Price Dollars])
With a little bit of zero and null handling the job will be done.
Thursday, November 12, 2009
Getting MDX from Excel pivot tables
- Data: Connections
- Properties
- Select Definition Tab
- Add Log File=c:\temp\pivotlog.txt;
- OK
- Close
- Refresh Pivot
Note: the definition text provided above is case sensitive! Particularly Log File
Tuesday, November 10, 2009
Displaying data source information in Reporting Services reports using expressions
=DataSources("myDataSource").DataSourceReference & " " & DataSources("myDataSource").Type
This will display:
- Data source name - probably also "myDataSource" in this example. The full path is provided when the report is run in Report Manager
- Data source type e.g. "OLEDB-MD" is an Analysis Services data source
Limitations:
- You can't use expressions referring to data sources in the header or footer. But who wants the data source details displayed in the report body??
- The data source reference has to be hard coded in every report. I'm not aware of any way to enumerate this to just fetch the first datasource. It would be fantastic if the following worked, but it doesn't:
Monday, November 2, 2009
Pausing SQL Server transactional replication without losing queue contents
- Open SSMS and connect to the distributor
- Disable and Stop the "Distribution clean up: distribution" job
- Expand SQL Server Agent, right-click on Jobs, select View Job Categories and choose REPL-Distribution
- Disable and Stop all listed jobs
- Enable and Start all the jobs that were stopped
Friday, October 30, 2009
SSIS OLE DB Command error with NOT NULL constrained columns
OLE DB Command fails with the following error reported to the package log:
SSIS Error Code DTS_E_OLEDBERROR. An OLE DB error has occurred. Error code: 0x80040E14. An OLE DB record is available. Source: "Microsoft SQL Native Client" Hresult: 0x80040E14 Description: "The incoming tabular data stream (TDS) remote procedure call (RPC) protocol stream is incorrect. The RPC name is invalid.".
Possible Cause:
The data flow task is experiencing a constraint violation.
For a table ThisTable defined as follows:
ThisTableKey int not null
ThisTableValue varchar(10)
and OLE DB Command data flow task containing the following statement:
update ThisTable set ThisTableValue = 'UpdateVal' where ThisTableKey = ?
where ? has been mapped to a data flow column.
If the data flow column contains a NULL value then the task will fail because of the NOT NULL constraint on the column.
Diagnosis:
This is hard to diagnose in SSMS because the SQL statement above will run fine (and do nothing) when ? is substituted with NULL.
Instead add data viewers to the outputs of the offending OLE DB Command. You should see the following columns at debug time:
- ErrorCode: -1071607702
- ErrorColumn: 12345 (this is an example value)
- ErrorDescription: The data value violated the schema constraint.
Resolution:
Use a Conditional Split task to filter out all NULL values in the data flow column before the OLE DB Command.
Monday, September 21, 2009
SSAS Aggregation Design error
Symptom:
The following error appears when deploying the cube or designing aggregations
The reference to attribute is not valid
Cause:
The partitions file has gotten out of sync with the cube file. Perhaps the cube file got checked back in to source control but the partitions file changes were undone.
Solution Options:
You may be able to hack the partitions file to clean up invalid attribute references.
Then again it may be easier just to roll back and reapply your changes.
Thursday, August 27, 2009
SSAS processing error could be due to proactive caching settings
"Errors in the high-level relational engine. The data source view does not contain a definition for the [object] table or view. The Source property may not have been set."
But the data source view doesn't contain this table.
Possible Cause:
A table has been specified for tracking in the notifications for proactive caching, but isn't available any more for some reason.
Solution Options:
- Update the table name and location as required
- Disable proactive caching for the partition
See http://www.mssqltips.com/tip.asp?tip=1563 for more details.
Monday, July 20, 2009
Stupid SSIS variable list bug
- Bring up the variable list and start editing the name of the first variable
- Click the Name column of the variable list to sort the list
- Hit Escape to cancel the edit
The variable name you were editing has now replaced the name of the variable that was top of the list after your sort! Cancelling the edit didn't stop this from happening.
Workaround: remember and reenter the variable name that was overwritten. Bleagh.
Thursday, July 2, 2009
Adding folders to SSMS project
Can't create folders in a SQL Server 2005 Management Studio project.
It would be handy to be able to separate scripts into folders. Unfortunately only three default folders are available: Connections, Queries and Miscellaneous
Workaround:
- Open the .ssmssqlproj file in a text editor
- Copy one of the LogicalFolder tags e.g. Miscellaneous
- Replace the Folder Name and Type. Make sure the Type value is different from all of the existing folders
- Your new folder(s) should now be available in SSMS
<Items />
</LogicalFolder>
Tuesday, June 30, 2009
Getting excel into a sharepoint list
Symptom:
When you try to import an Excel spreadsheet into a Sharepoint list using the "Import Spreadsheet" option, the following message appears.
The website declined to show this webpage HTTP 403
Most likely causes:
This website requires you to log in.
What you can try:
Go back to the previous page.
More information
This error (HTTP 403 Forbidden) means that Internet Explorer was able to connect to the website, but it does not have permission to view the webpage.
For more information about HTTP errors, see Help.
Cause and Resolution:Some have suggested reinstalling Office components on the server or formatting your spreadsheet in table format. Dunno, haven't tried.
Workaround:
Push from Excel as follows:
- Data: List: Create List
- Choose your list range and click OK
- Data: List: Publish List
- Enter url and name, and click Finish. All done!
Wednesday, June 17, 2009
SSIS can't find environment variables
Symptom: Can run packages manually, but the scheduled task fails.
Cause: Environment variables. You have probably logged off and on to the server a few times while attempting to run the packages manually, which means your login has the latest environment variables. However the SQL Server Agent may not have "logged in" recently and will be unaware of the new environment variables.
Resolution: Restart the SQL Server Agent (which is the equivalent of logging it back on to pick up the latest environment variables).
Tuesday, June 16, 2009
SSIS package location selection criteria
Advantages of Saving to Files:
- Easier to do shared source control
- Ultra secure when using the Encrypt with User Key encryption option
- Not subject to network downtime problems (saved locally)
- May escrow deployment bundles including miscellaneous files
- Less steps to load into the designer
- Easier direct access for viewing
- May store packages hierarchically in file system
- Projects in Visual Studio are disk based and require the package to be in the file system
- Generally, a better experience during development
Advantages of Saving to SQL Server:
- Easier access by multiple individuals
- Benefits of database security, DTS roles and Agent interaction
- Packages get backed up with normal DB backup processes
- Able to filter packages via queries
- May store packages hierarchically via new package folders
- Generally, a better in-production experience
Saturday, May 16, 2009
x:\desktop refers to a location that is unavailable
One of the registry settings wasn't updated by the move.
HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\User Shell Folders
This probably still has a value of x:\desktop. Change it to %USERPROFILE%\Desktop
I'm using Windows XP Pro SP2, I have no idea which other OS's & versions are affected.
Friday, March 27, 2009
SSIS Breakpoint and other debug problems
- When you add a or remove breakpoint from a breakpoint, the breakpoints of other tasks in other packages also change
- SSIS ignores breakpoints or breaks unexpectedly during debug
- Tasks execute unexpectedly during debug
Duplicate Task Ids
When a package is created by copying another package, all the object IDs will be identical to the original package's IDs. This confuses visual studio with symptoms as described.
Resolution:
Install BIDS Helper if you haven't already, and use Reset GUIDs.
Thursday, January 29, 2009
SSIS Parent Package variables - reading and writing in both directions
Discounted Option
- The Set Variable Custom Task. It errors when referring to non local variables.
- Script Task in the Child Package (bleagh)
Public Sub Main()
Dim vars As Variables
'If package executed directly then no parent variables exist!
Try
Dts.VariableDispenser.LockForRead("ParentVar")
Dts.VariableDispenser.LockForWrite("ChildVar")
Dts.VariableDispenser.GetVariables(vars)
vars("ChildVar").Value = vars("ParentVar").Value
vars.Unlock()
Catch ex As Exception
'Do Nothing
Finally
Dts.TaskResult = Dts.Results.Success
End Try
End Sub
"The Parent Variable Write"
Public Sub Main()
Dim vars As Variables
'If package executed directly then no parent variables exist!
Try
Dts.VariableDispenser.LockForWrite("ParentVar")
Dts.VariableDispenser.LockForRead("ChildVar")
Dts.VariableDispenser.GetVariables(vars)
vars("ParentVar").Value = vars("ChildVar").Value
vars.Unlock()
Catch ex As Exception
'Do Nothing
Finally
Dts.TaskResult = Dts.Results.Success
End Try
End Sub
Notes
- No need for Parent Package Configurations if the child and parent variables are differently named
- There's no need to do anything in the Parent Package.
- Don't put anything in ReadVariables or ReadWriteVariables! This will cause additional LockForRead, LockForWrite and Unlock method calls.
- Set Parent Variable Custom Task
- Set Multiple Variables Custom Task
Hard to Template
If you want to go large with a deep package invocation hierarchy then it will be somewhat tiresome to code. This is because local variables override parent variables if they have the same name, so you can't use the same package template for all hierarchy levels.
e.g. if you have a package template with variables var1 and localvar1, create two packages from it and call one package from the other, the child package will use the local var1 and ignore the parent var1.
This is unfortunate because it's becoming steadily easier to work with templates in SSIS using tools such as Pacman.
 
