Just a quick post with two T-SQL functions to compute the first and last day of the month for any DATETIME. These have been incredibly useful on a daily basis and I figured that I would pass them along. Keep in mind that these are inline scalar-value functions and will be evaluated for every row in a result set. This isn’t so bad when you only have a few rows, but when you have a million rows, it’s expensive.
Let’s say that we have an application that tracks and reports customer bills. Customers are able to view reports based on their bill. As time goes on, the customers have a need to create adjustments to their bill. It should be simple enough to add some identifying data to the bill to determine which bill is an adjustment, right? Well, not quite. It turns out that the Bill table is being loaded automatically on a regular (hourly) basis by an SSIS package.
SQL SERVER Scripting DBA Actions – Dan Jones (Microsoft SQL Server team member) has put together a great overview of his tips and techniques for automating DBA tasks. This comes as a direct result of sitting in on the panel discussion on automation from PASS. Summer Camp for DBA’s (#SQLPASS) is over for 2008 – TJay Belt summarizes what he got out of PASS and how we were all able to use twitter to keep up to date on conference happenings.
A co-worker approached me with the problem of sorting an ArrayList of ArrayLists. Normally you might handle this in a DataTable or entity collection in your particular ORM. In this case, this was the data structure that was available to sort:\[\[sortorder\]\[type\]\[message\] \[sortorder\]\[type\]\[message\] \[sortorder\]\[type\]\[message\]\]Knowing a little bit about how ORM tools work, I made the guess that they implement a custom comparer to perform this functionality, so I took a look at what it would take for this instance.
Brent Ozar provided the inspiration for this blog post and the others that will follow. Essentially, the goal is to put together a list of the most interesting/entertaining links that I’ve found in the last week. If you’re easily offended by SQL Server, I suggest you turn away now. 5 Quick Tips for the Query Using the ‘Wrong’ Index – Quick tips from Jason Massie about making sure the ‘correct’ index is being used by the query engine.
Cross database ownership chaining is bad. Very bad. How bad? Despite being included in SQL Server 2005, this feature is disabled by default. SQL Server 2005 Books Online goes on to say “Setting cross db ownership chaining to 1 is not recommended unless all of the databases hosted by the instance of SQL Server must participate in cross-database ownership chaining and you are aware of the security implications of this setting.
Cursors. Many database developers have to suppress a shudder of horror when they open up a stored procedure only to find a cursor lurking inside. They certainly have their place in the database developer’s arsenal of tools, but they can usually be rewritten as an easily understood set operation. I’ve spent the first three days at my new client learning the database schema and migrating four load routines from the old to the new database schema.
That’s right, now you too can use T-SQL to get dates quickly! Today at the client I came across the following chunk of SQL in a where clause: dateadd(m,-24,(cast(datepart(m,getdate()) as varchar(2))+'/1/'+cast(datepart(yyyy,getdate()) as varchar(4)))) It’s used to return the first of the month two years ago. So, for today, this would return 2006-09-01 What’s wrong with this? Well, in this query there are two string concatenations, two explicit conversions from an INTEGER to a VARCHAR, and an implicit conversion from VARCHAR to DATETIME.
My amazing co-worker pointed out a great post from Justin Etheredge onstrategies for becoming a better developer. Self-improvement is a huge thing for me, both personally and professionally. I like both Justin and Rick’s ideas – Emulate, Get Involved, Read, and Stretch. My strategies tie these all together and are pretty simple, really: Learn and Teach. Teaching I’ve gained the greatest understanding of programming by sharing my knowledge with other developers.
I was catching up on the Information Architecture Institute mailing list and some feed reader backlog when I came across the concept of shingling. Seeing as how I have never heard of this term in the 8+ years I’ve been working, I decided it was high time that I learned about it. In essence, shingling seeks to solve the problem of indexing large quantities of data:
How can you tell if two pieces of content are the same?