June 10, 2008 at 4:08 am
Hi,
Can anybody tell me,in which situation we will go for CLR integration?
---
June 11, 2008 at 7:00 am
Consider CLR when a procedure requires significant data access and computation. You would then separate the procedural code into a CLR portion calling the T-SQL procedure that performs data access, or vice-versa.
June 11, 2008 at 1:47 pm
I like to use CLR SPs when I have some special code I don't want the whole world to see. Could probably be reversed engineered but at least they will have to work at it.
June 11, 2008 at 2:03 pm
mike (6/11/2008)
I like to use CLR SPs when I have some special code I don't want the whole world to see. Could probably be reversed engineered but at least they will have to work at it.
I never really thought about using the CLR for obfuscation, but there is a case for it if you are willing to take a performance hit. I have never used the CLR because I have not found a situation that I could not solve in T-Sql. Most discussions I have read on it go back to string manipulation and regular expressions. There could be a case made for complex calculations as well.
Jack Corbett
Consultant - Straight Path Solutions
Check out these links on how to get faster and more accurate answers:
Forum Etiquette: How to post data/code on a forum to get the best help
Need an Answer? Actually, No ... You Need a Question
June 12, 2008 at 12:05 am
Thanks you guys for your valuable information. 🙂
June 12, 2008 at 8:17 pm
Heh... I'd have to say just about never... with the exception of RegEx, there's not much that can't be done using some form of set based programming in SQL Server that will also beat a CLR for performance. Heck, even the very procedural task of doing a running total can be done in SQL Server 2000 and it will blow the doors off an equivalent CLR.
SQL Server is an imagination limited tool... unlimited imagination, unlimited tool. Limited imagination, use a CLR 😉
--Jeff Moden
Change is inevitable... Change for the better is not.
June 13, 2008 at 12:38 am
What MS is not making particuarly clear is that CLR is intended to, in a couple of versions, replace extended stored procs.
Books Online
Extended Stored ProceduresImportant:
This feature will be removed in a future version of Microsoft SQL Server. Avoid using this feature in new development work, and plan to modify applications that currently use this feature. Use CLR Integration instead.
Essentially, you use CLR for things that T-SQL cannot do, if you find it necessary to do such things within the DB.
Where I work, we're mainly using it to query web services straight from a database. We've got a couple apps (CRM) that only accept data loads via their web service and only provide data via their web service, so we have a CLR proc that runs at night that syncs the CRM data with a couple other systems. Sharepoint's another example of this.
It's also interesting to note that a lot of the newer features of SQL 2008 (spacial data types, hierarchy, etc) are implemented using CLR.
Gail Shaw
Microsoft Certified Master: SQL Server, MVP, M.Sc (Comp Sci)
SQL In The Wild: Discussions on DB performance with occasional diversions into recoverability
June 14, 2008 at 8:50 am
CLR is useful in such cases as these (benefit in parentheses):
- string manipulation, regular expressions etc. (performance)
- OS-level operations, previously possible only using xp_cmdshell (more granular security, functionality with increased specialization, functionality with increased ease of use)
- complex mathematical calculations (performance)
- As Gail mentioned, replacing extended stored procedures (future SQL-Server compatibility)
- web services
Just as with any other tool, SQLCLR needs to be used judiciously and tested rigorously for performance against conventional T-SQL solutions. It's not a one-size fits all and there are no absolutes.
__________________________________________________________________________________
SQL Server 2016 Columnstore Index Enhancements - System Views for Disk-Based Tables[/url]
Persisting SQL Server Index-Usage Statistics with MERGE[/url]
Turbocharge Your Database Maintenance With Service Broker: Part 2[/url]
June 14, 2008 at 9:56 am
Another reason people haven't mentioned is code reuse.
In our shop we have a library of helper functions that is used by all our managed components. We also wanted to allow stored procs to have access to these helpers, so we expose the library in SQL Server as CLR UDFs and have only one code base to support.
---------------------------------------
elsasoft.org
June 14, 2008 at 9:57 am
Marios Philippopoulos (6/14/2008)
CLR is useful in such cases as these (benefit in parentheses):- string manipulation, regular expressions etc. (performance)
- OS-level operations, previously possible only using xp_cmdshell (more granular security, functionality with increased specialization, functionality with increased ease of use)
- complex mathematical calculations (performance)
- As Gail mentioned, replacing extended stored procedures (future SQL-Server compatibility)
- web services
Just as with any other tool, SQLCLR needs to be used judiciously and tested rigorously for performance against conventional T-SQL solutions. It's not a one-size fits all and there are no absolutes.
Good list... the one about OS-level operations isn't exactly correct, though. Many operations were available through undocumented stored procedures. Please don't get religious about that... even documented features can go away at a moment's notice. 😉
--Jeff Moden
Change is inevitable... Change for the better is not.
June 15, 2008 at 8:36 pm
Jeff Moden (6/14/2008)
Marios Philippopoulos (6/14/2008)
CLR is useful in such cases as these (benefit in parentheses):- string manipulation, regular expressions etc. (performance)
- OS-level operations, previously possible only using xp_cmdshell (more granular security, functionality with increased specialization, functionality with increased ease of use)
- complex mathematical calculations (performance)
- As Gail mentioned, replacing extended stored procedures (future SQL-Server compatibility)
- web services
Just as with any other tool, SQLCLR needs to be used judiciously and tested rigorously for performance against conventional T-SQL solutions. It's not a one-size fits all and there are no absolutes.
Good list... the one about OS-level operations isn't exactly correct, though. Many operations were available through undocumented stored procedures. Please don't get religious about that... even documented features can go away at a moment's notice. 😉
Thanks Jeff, valid point.
__________________________________________________________________________________
SQL Server 2016 Columnstore Index Enhancements - System Views for Disk-Based Tables[/url]
Persisting SQL Server Index-Usage Statistics with MERGE[/url]
Turbocharge Your Database Maintenance With Service Broker: Part 2[/url]
Viewing 11 posts - 1 through 10 (of 10 total)
You must be logged in to reply to this topic. Login to reply