Is there any way to obscure the schema of a database on SQL Server?
If I have SQL Server Express installed on a client site, is there a way to obscure the schema and data so that someone else cannot come along and learn the schema in order to extract data out of it and into another product?
This is a tricky one and may not even be 100% possible. However, there are a few tricks to setting it up:
There are several commercial applications that I know of that don’t even tell you they are installing an instance of MS SQL express. They too will create their own named instance with a named SA account. I can’t say I like that as a customer (as SQL takes a hit on the CPU and I don’t want “secret” instances running on my workstation). But so long as you disclose this to your customers upfront, they may understand.
**Keep in mind a skilled DBA may have the knowledge to mess with system tables and what not to manually grant access to your database. These techniques really are just “obfuscation” and won’t be 100% bullet proof.
As a side note: With the plethora of available 3rd party datalayers and webservice technologies, I think many companies are finding their database schema alone isn’t so proprietary or valuable anymore. There was a time when the database schema alone could have represented hundreds of hours of coding. But today tools like EntityFramework, NHibernate, Linq-to-SQL, XPO, etc all create your database schema for you based on your software class definitions and in code attributes. So just seeing a DB table isn’t really very valuable. Plus you might write a bunch of business logic, statistical analysis or other helper methods in your software that aren’t in your database schema. In my opinion, this is where today’s “value add” is found, in the business logic, analysis and reporting functionality of your software – not in the raw datatables.
This is also why another poster recommended obfuscating stored procedures, because these could be many times the work of the database schema itself if you have some nice analysis and reporting procedures written up. Its also what customer’s would most likely want to customize for their own reporting needs. You may be inclined to have a policy that custom reporting can only be done by your company (hey, even the big guys like SAP are sticky with who can modify what).