List all sql server 2005 with SMO

  • Hello,

    how can I list all sql server instances SQL server 2005 local and the network usind SMO (from vb.net all vs2005).

     

    Thank

  • Use This code !

    ----------------------------------------------------------

    Imports Microsoft.SqlServer.Management.Smo

    Imports Microsoft.SqlServer.Management.Common

    Dim dts As DataTable = SmoApplication.EnumAvailableSqlServers(False)

    cmbSServers.DataSource = dts

    cmbSServers.ValueMember = "Name"

    -----------------------------------------------

    Matt

  • I am pretty new to this - what references do I need?

    -- Cory

  • You'll need references to Microsoft.SqlServer.SMO and (usually) Microsoft.SqlServer.ConnectionInfo.

    hth,

    Tim

  • Hey Tim,

    Maybe you know how to get a list of databases on a particular server?

    Regards

    Leonard

  • Hi,

    Its very simple!

    Reference the following;

    Imports Microsoft.SqlServer.Management.Smo

    Imports Microsoft.SqlServer.Management.Common

    ---------------------------------------------------------------------------

    I'm getting all SQL server instances on the network;

    'Getting all Servers on network and fill DataTable

    Dim dt As DataTable = SmoApplication.EnumAvailableSqlServers(False)

    ' Databinding combobox

    cmbSServers.DataSource = dt

    cmbSServers.ValueMember = "Name"

    If cmbSServers.Items.Count < 1 Then

    cmbSServers.Text = " no servers found "

    Else

    cmbSServers.SelectedItem = 1

    End If

    -------------------------------------------------------

    ' Now im connecting to the selected Server as chosen by the user

    Dim conSrc as ServerConnection = New ServerConnection(cmbSServers.Text)

    'if you know from before hand what instance you want to connect to then instead use;

    Dim conSrc as ServerConnection = New ServerConnection(InstanceName)

    ' if connecting to the selected instance requires a username and password then use

    conSrc.Login = txtsuser.Text

    conSrc.Password = txtspassword.Text

    'if using windows integrated security use

    conSrc.LoginSecure = True

    'Connect to the instance

    conSrc.Connect()

    Dim svr as Server = New Server(conSrc)

    'For all the databases found in the connected Server displayed them in combobox

    For Each db As Database In svr.Databases

    cmbDatabases.Items.Add(db.Name)

    Next

    If cmbDatabases.Items.Count < 1 Then

    cmbDatabases.Text = "no databases found"

    Else

    cmbDatabases.SelectedItem = 1

    End If

    -----------------------------------------------------------------

    Hope this help!

    Regards,

    Matt

  • HI Tim,

    Thanks for your help. It works great. Now for my next question:

    I see that the datareader cannot get a recordcount. Although I could use the old ADODB.Recordset object, I would really like to use ADO.NET, so is there any way to use a datareader object or another ADO.Net cursor, and have the luxury of a recordcount? I would really like to have an accurate progressbar in my app, but without a recordcount to set the maximum value, its looking a bit tricky.

    Regards

    Leonard

  • Hi,

    I wouldn't use the datareader of ADO.NET to get the record count!

    If you want to get the number of found servers use;

    // this continues from the code of the previous post

    Dim dt As DataTable = SmoApplication.EnumAvailableSqlServers(False)

    dt.Rows.Count

    If you want to find the number of found databases on the server istance use;

    // this continues from the code of the previous post

    srv.Databases.Count

    once you retrieve the count set the progress bar max value to the count value.

    Regards,

    Matt

  • Hi Matt,

    Thanks for the reply. I am not trying to count the number of databases. I am fine with that part of the application.

    What I was actually trying to do is to use a progressbar, to show the progress of retrieving data (not databases).

    So I want to move through a recordset of data that has been returned by a stored procedure, and I need to get a recordcount (how many rows are in the recordset of data), to set the maximum value for my progressbar.

    In ADODB, there was a recordcount property for the recordset object, I am looking for the equivalent thing in ADO.NET.

    Regards

    Leonard

  • Hi,

    You want to execute a stored procedure and return the number of rows returned by the sp using ADO.NET?

    If so then I created this function that generates the sp script and right after it executes the script storing the results (recordSet) in a DataSet;

    Private Function GetStoreProcedures(ByVal db As Database) As ArrayList

    Dim script As System.Collections.Specialized.StringCollection

    Try

    Dim sp As StoredProcedure = New StoredProcedure(db, "Your SP Name")

    script = sp.Script()

    Dim ds As New DataSet("Results")

    ds = dbSobjects.ExecuteWithResults(script)

    ' Get Row count = ds.Tables(0).Rows.Count

    Catch ex As FailedOperationException

    Throw ex

    End Try

    End Function

    If the code fails execution please let me know.

    Regards,

    Matt

  • Hi Matt,

    Thanks for all you help, considering that you don't even know me. I am sure that this code will work, however (and not to sound ungrateful, which I probably do...), my need is a bit more complex than just a simple scripting action.

    My stored procedures have many parameters, and some of them are optional, which means that depending on how you call the proc, the rowcount will differ every time.

    As well as that, I am actually trying to get the rowcount from the same object that returns the data (as you can in ADODB). I don't want the additional overhead of two calls to the database (one for data and one for a row count), as this seems totaly illogical to me.

    Regards

    Leonard

  • Hi,

    Ok, if I understood you correctly you want to execute a stored procedure depending on certain parameters and then return the data + rowcount?

    IF so there is no need of SMO.

    I'm going to use instead ADO.NET objects instead;

    Dim conn As New SqlConnection("Insert connection string")

    conn.Open()

    'Use sqlCommand to get the data

    Dim myCommand As New SqlCommand("sp name", conn)

    myCommand.CommandType = CommandType.StoredProcedure

    'Define the parameters

    myCommand.Parameters.Add("@para", SqlDbType.Int).Value = 10

    myCommand.Parameters.Add("@para2",SqlDbType.Int).Value = 32

    'Create a Datatable that stores the data from the executed sp

    Dim dt as new Datatable("Results")

    dt.Load(myCommand.ExecuteReader())

    'For Row count

    dt.Rows.Count

    Hope to have understood you now

    Regards,

    Matt

  • Hi Matt,

    It's looking better now. Here is what I was trying to do:

    The SMO stuff is for the login part of the app, so I want to give a list of servers on the network, and when a server is selected, then a dropdown for databases on that server, and then the login process.

    Then I am also building a framework, with a central point for all data access in the application, so once the user is logged in the recordcount is required for each and every data call that needs to update a listview & a progressbar, so this is where I needed ADO.NET

    So that is all working now. Then next part is to upgrade the old VB6 Crystal Report Engine to get the same functionality in VB.NET.

    Thanks for all your help.

    Regards

    Leonard

  • Hi Matt,

    I have another question for you:

    In ADODB, when you loop through a recordset, you would use the movenext method of the recordset, and you could access the data like this:

    with rs

    txtperson_name = rs!person_name

    rs.movenext

    end with

    How do you achieve the same effect in ADO.NET with a DataTable?

    Regards

    Leonard

  • Sample code:

    For Each row As DataRow In myDataTable.Rows

    txtperson_name = row!person_name.ToString()

    Next

Viewing 15 posts - 1 through 15 (of 15 total)

You must be logged in to reply to this topic. Login to reply