Index
[Prelude][1]
[Part 1][2]
[Part 2][3]
[Part 3][4]
[Conclusion][5]
Yes The stored procedures came to town.
Here is the first one.
CREATE PROC spo_getMspCoordinates
AS
SELECT TOP 1000000 id, a, WaveLenghtinnm
FROM dbo.tbl_MSPCoordinate
GO
This just gets the first million out of that database.
Now we hit a snag and something that kills performance. But I can’t think of a reasonable way around it without using dynamic sql.
So here it is.
CREATE PROC spo_getMspCoordinatesTop
@top VARCHAR(30)
AS
Declare @SQL VarChar(1000)
SELECT @SQL = 'SELECT TOP ' + @top + ' id, a, WaveLenghtinnm'
SELECT @SQL = @SQL + ' FROM dbo.tbl_MSPCoordinate'
Exec ( @SQL)
GO
And here are the tests.
Imports NUnit.Framework
Imports StructureMap
Namespace Test
<TestFixture()> _
Public Class TestSpeedNHibernate
<SetUp()> _
Public Sub Setup()
StructureMapConfiguration.UseDefaultStructureMapConfigFile = False
StructureMapConfiguration.ScanAssemblies.IncludeTheCallingAssembly()
End Sub
<Test()> _
Public Sub Select_MSP_SQLClientProcedures_1000000()
Dim _crud As DAL.Interfaces.IMSPCoordinate = StructureMap.ObjectFactory.GetNamedInstance(Of DAL.Interfaces.IMSPCoordinate)("sqlclientprocedure")
Assert.IsNotNull(_crud.Selectall)
Assert.Greater(_crud.Selectall.Count, 0)
Assert.AreEqual(1000000, _crud.Selectall.Count)
End Sub
<Test()> _
Public Sub Select_MSP_SQLClientProcedures_1000()
Dim _crud As DAL.Interfaces.IMSPCoordinate = StructureMap.ObjectFactory.GetNamedInstance(Of DAL.Interfaces.IMSPCoordinate)("sqlclientprocedure")
Assert.IsNotNull(_crud.Selectall(1000))
Assert.Greater(_crud.Selectall(1000).Count, 0)
Assert.AreEqual(1000, _crud.Selectall(1000).Count)
End Sub
<Test()> _
Public Sub Select_MSP_SQLClientProcedures_1000_1000()
Dim _crud As DAL.Interfaces.IMSPCoordinate = StructureMap.ObjectFactory.GetNamedInstance(Of DAL.Interfaces.IMSPCoordinate)("sqlclientprocedure")
For i As Integer = 0 To 999
Assert.IsNotNull(_crud.Selectall(1000))
Assert.Greater(_crud.Selectall(1000).Count, 0)
Assert.AreEqual(1000, _crud.Selectall(1000).Count)
Next
End Sub
End Class
End Namespace```
And here is the implementation
```vbnet
Imports StructureMap
Namespace DAL.CRUD.SQLClientTransaction
<Pluggable("sqlclientprocedure")> _
Public Class MSPCoordinate
Implements Interfaces.IMSPCoordinate
Public Function Selectall() As System.Collections.Generic.IList(Of Model.MspCoordinate) Implements Interfaces.IMSPCoordinate.Selectall
Dim _returnlist As New List(Of Model.MspCoordinate)
Dim c As New Data.SqlClient.SqlConnection("Data Source=incctex;Initial Catalog=testtexdatabase;Integrated Security=SSPI;")
Dim s As New Data.SqlClient.SqlCommand()
c.Open()
s.Connection = c
s.CommandType = CommandType.StoredProcedure
s.CommandText = "spo_getMspCoordinates"
Dim r As Data.SqlClient.SqlDataReader
r = s.ExecuteReader
While r.Read
_returnlist.Add(New Model.MspCoordinate(Convert.ToInt64(r.GetValue(0)), r.GetDecimal(1), r.GetDecimal(2)))
End While
s.Dispose()
r.Close()
c.Close()
c.Dispose()
Return _returnlist
End Function
Public Function Selectall1(ByVal top As Integer) As System.Collections.Generic.IList(Of Model.MspCoordinate) Implements Interfaces.IMSPCoordinate.Selectall
Dim _returnlist As New List(Of Model.MspCoordinate)
Dim c As New Data.SqlClient.SqlConnection("Data Source=incctex;Initial Catalog=testtexdatabase;Integrated Security=SSPI;")
Dim s As New Data.SqlClient.SqlCommand()
c.Open()
s.Connection = c
s.CommandType = CommandType.StoredProcedure
s.CommandText = "spo_getMspCoordinatesTop"
s.Parameters.Add(New Data.SqlClient.SqlParameter("top", SqlDbType.VarChar, 30))
s.Parameters(0).Value = top.ToString
Dim r As Data.SqlClient.SqlDataReader
r = s.ExecuteReader
While r.Read
_returnlist.Add(New Model.MspCoordinate(Convert.ToInt64(r.GetValue(0)), r.GetDecimal(1), r.GetDecimal(2)))
End While
s.Dispose()
r.Close()
c.Close()
c.Dispose()
Return _returnlist
End Function
End Class
End Namespace```
And here are the results.
<table border="1">
<tr>
<th width="400">
Test
</th>
<th width="100">
Time
</th>
</tr>
<tr>
<td>
Select_MSP_SQLClientTransactions_1000000
</td>
<td align="right">
7.53 s
</td>
</tr>
<tr>
<td>
Select_MSP_SQLClientTransactions_1000
</td>
<td align="right">
0.04 s
</td>
</tr>
<tr>
<td>
Select_MSP_SQLClientTransactions_1000_1000
</td>
<td align="right">
10.51 s
</td>
</tr>
</table>
Yes the Dynamic sql is killing it. But not more then the “inline” sql.
<span style="color:red;">Edit</span>
With the new Stored procedure, without dynamic sql.
```tsql
ALTER PROC spo_getMspCoordinatesTop
@TOP INT
AS
SET ROWCOUNT @TOP
SELECT id, a, WaveLenghtinnm FROM dbo.tbl_MSPCoordinate```
The numbers become this.
<table border="1">
<tr>
<th width="400">
Test
</th>
<th width="100">
Time
</th>
</tr>
<tr>
<td>
Select_MSP_SQLClientTransactions_1000000
</td>
<td align="right">
7.32 s
</td>
</tr>
<tr>
<td>
Select_MSP_SQLClientTransactions_1000
</td>
<td align="right">
0.09 s
</td>
</tr>
<tr>
<td>
Select_MSP_SQLClientTransactions_1000_1000
</td>
<td align="right">
9.39 s
</td>
</tr>
</table>
Not much of an improvement, but we take what we can get.
So dynamic sql isn’t all that bad after all :>
* * *
<font color="Red">Need help with VB.Net? Come and ask a question in our <a href="http://forum.lessthandot.com/viewforum.php?f=39">VB.Net Forum</a></font>
[1]: /index.php/DesktopDev/MSTech/nhibernate-performance-against-stored-pr
[2]: /index.php/DesktopDev/MSTech/nhibernate-performance-against-stored-pr-1
[3]: /index.php/DesktopDev/MSTech/nhibernate-performance-against-stored-pr-2
[4]: /index.php/DesktopDev/MSTech/nhibernate-performance-against-stored-pr-3
[5]: /index.php/DesktopDev/MSTech/nhibernate-performance-against-stored-pr-4