LessThanDot Site Logo

LessThanDot

A decade of helpful technical content

This is an archive of the posts published to LessThanDot from 2008 to 2018, over a decade of useful content. While we're no longer adding new content, we still receive a lot of visitors and wanted to make sure the content didn't disappear forever.

Dealing with The row value(s) updated or deleted either do not make the row unique or they alter multiple rows errors

Someone asked about this error this morning and I decided to turn it into a blog post. Basically the person was using the designer/editor in SSMS to delete a row, the table didn’t have a key and the rows were not unique, he got the following error: The row value(s) updated or deleted either do not make the row unique or they alter multiple rows. Let’s see this in action and also take a look at how we can get around this.

Read More...

Exploring Reactive Extensions – Subscription Management

I sat down to write a post on testing the core interfaces in the reactive library, and found myself going off onto a bit of a tangent. I made a big enough change to the way everything was set up that I didn’t really feel comfortable including it in the post on testing, but it seemed worth mentioning. So this post was born. I started thinking about an object responsible for managing the subscription, which can be returned as the IDisposable from the observable’s Subscribe method. I think this could help not only with usability, but testability as well.

Read More...

Mirroring and Transactional Replication setup – Auto Failover

Since mirroring has come to the SQL Server feature set, High Availability (HA) has become a much easier, inexpensive and available option. Prior to mirroring, third party software and hardware were the main options to achieve HA. This was due to replication never being accepted as a high availability option. With any solution like SQL Server, growth over time builds a better and more stable solution. This has been the fact with many features of SQL Server, including replication. Replication had some issues in previous versions of SQL Server. Maintaining the uptime and stability was not a trivial task. With replication, there is a more in-depth knowledge requirement to maintain it, while mirroring does not require as much in-depth knowledge to provide a solid solution. Do think that mirroring does not include a strict discipline of skills in order to make it a successful HA solution. Mirroring is simplistic from the outside, both in setup and maintainability. However, troubleshooting mirroring is a critical aspect to making it work for HA. In order to be successful, knowledge of the internals of mirroring is as important as replication.

Read More...

Exploring Reactive Extensions – Adding a Dash of Linq

I think the reactive extensions library starts to look even better when you start taking into consideration all the cool linq stuff it lets you do with sequences of events. In order to use this we need to add another reference, this time to System.Reactive. It’s interesting that the stuff we are importing with these references becomes available anyplace the System namespace is available – there’s no need to add using directives to our code files. I guess this is because it’s intended to become a first class feature in .net some time.

Read More...

Run SSIS Package from Stored Procedure

There are a few methods to execute a SQL Server Integration Services (SSIS) package from T-SQL. Very often the use of xp_cmdshell is the first choice to accomplish this task. Xp_cmdshell has primarily been a system administration extended stored procedure. Many types of extended stored procedures such as this one are meant for tasks that are either manual or very refined and controlled tasks. This is all due to the requirements of the levels of sysadmin roles – or CONTROL SERVER to be exact. Further on this topic, xp_cmdshell is disabled by default because it has been a known attack method. Having the ability to execute xp_cmdshell exposes operating system level access. In worst case scenarios, the SQL Server Service account is also a domain account with either Domain Admin rights or rights to other resources on the domain that are sensitive or open to damaging effects to the business. To expose xp_cmdshell then opens one of the highest security risks relating to SQL Server.

Read More...

What am I thankful for?

This will be a short post but nonetheless a very important one to me. A good friend of mine, Jason Strate (Blog | Twitter), posted a blog, “What are you thankful for?” In this post he asked all of his readers to also take a few moments and blog about the same. So here we go… Most know that I recently changed jobs. This change was pretty big for me. The reason this was not a small move is due to leaving a production DBA role and moving into consulting. The commute is longer as well but as odd as it may seem, I don’t mind the drive. The drive gives me time to catch podcasts and other audio type training materials. With the change I find myself extremely thankful for the fact that I have a great amount of support from another good friend, Aaron Lowe (Blog | Twitter). Moving into this role has been nothing but smooth. Finding things, meeting people (which are next to impossible when consultants are in and out), knowing what and where I need to be and what to focus on are all things that typically is a bumpy ride when you jump in. That hasn’t been the case this time and between Aaron and my new management, has been extremely pleasant. An added bonus has been Wendy Pastrick (Blog | Twitter) also working alongside helping me pave the way forward with the new company. The SQL Saturday in Chicago crew took it to the next level of working together!

Read More...

Using SSIS to import a directory of images

SQL Server provides database professionals with several paths in order to import and export data in and out of many data sources and file services. One main task, the Foreach Loop Container, allows for processing large (or small) groups of files with one contained and manageable process. Tasks that once were difficult and required larger scale development efforts have now moved into the realm of the rapid development methodology. Rapid Development is defined as requiring a much lower amount of resources in order to push a process into a production environment. Resources can contain any one of the main components in developing strategies such as management, developers, infrastructure changes and so on. The resources take time in planning stages, developing stages and testing stages. Accomplishing this methodology is done by placing each of these on top of each other in a sense. Planning is done alongside developing and testing.

Read More...

The Productive DBA: Part 2 Document the Database

How many times have you started at a new company or been given a new database that you have to code for and you have no clue how the schema relates? How much time is wasted trying to figure out that schema? If you’re lucky you will be given a database that has at least been developed correctly with foreign keys and a document to accompany it. If you’re not lucky, you’ve just been handed a database with 50,000 objects that you need to document. Don’t be that DBA that hands off a database to someone else without an accompanying diagram and document that defines each table and object in plain English.

Read More...

The Productive DBA

Over the past 12 years I’ve received a lot of great suggestions from some very good DBAs on how to best be productive and organized. One of the best pieces of advice I ever read was out of SQL Server magazine a few years back on how to be organized. That advice was to create yourself a DBA repository! What is a DBA repository you ask… Well it’s simple, it’s the one single place where you keep ALL of the things you need to do your job, scripts, logs, executables, trace files, reports. It’s anything and everything you would use daily. So what’s my repository like? I have a small server that I loaded all my diagnostic and SQL Tools on where I keep a share named DBA. In that share I have the following folders, Executable, DR, Diagrams, Documents, SQL Scripts, SSAS, SSIS, SSRS, Trace, Bugs and Fixes and HA.

Read More...

Unit Testing Costs Too Much – Too Many Things To Learn

For someone that is just interested in trying out Unit Testing the number of topics out there can seem overwhelming. From passionate articles about using TDD, to deeply technical articles around the differences in mocking frameworks, to complete sidetracks into architecture theory and how to make code more testable…just learning enough to get started and try out Unit Testing can seem like you need weeks of classes. If you’re just catching up, I’ve been sharing commentary on the costs (and value) of Unit Testing, starting with a brief (intended to be humorous) post, a presentation at the Raleigh CodeCamp, and last weeks discussion of the “Twice as Much Code” issue.

Read More...