Ir al contenido principal

SQL - User-Defined Type (DataTable)

How to create a User-Defined in your database and use it in C# like DataTable

Create the data type and refresh the DB

    [type_name] - The name for the new data type
    [parameter] - The name of your paramenter
    int - The data type
    NULL - Declare if the parameter has to be null or not

     CREATE TYPE [relProjectDS] AS TABLE(
     

        [idProject]
    int NOT NULL ,
        [idCatDomain] int NULL,
        [catSubdomain] [nvarchar]  (50) NULL

    )

      Create the Store procedure

        CREATE PROCEDURE  [dbo].[insertProject]
            @myDataType relProjectDS readonly
        AS
        BEGIN
              insert into [dbo].[Table] select * from @myDataType
        END

        Create and fill the DataTable in C#

        idProject- Name of the parameter according with data type from the DB
        typeof(int) - The type definition according with the DB
        Rows.Add(param1, param2) - The method to add each row to the DataTable

        DataTable projectsTable = new DataTable();
        projectsTable.Columns.Add("
        idProject", typeof(int));
        projectsTable.Columns.Add("idCatDomain", typeof(int));
        projectsTable.Columns.Add("idCatSubdomain", typeof(int));


        projectsTable.Rows.Add(1,2,3,4,5);



        Pass dataTable as parameter

        using (var command = new SqlCommand("InsertTable") {CommandType = CommandType.StoredProcedure})
        {
        var dt = new DataTable(); //create your own data table
        command
        .Parameters.Add(new SqlParameter("
        @myDataType", dt));
        SqlHelper.Exec(command);
        }

        Update dataTable in Store Procedure

        In the store procedure our dataType is readonly so to modify it we can pass to a temporally table and then update the data.

        In the following steps after insert in another table we get the ID and the update the ID in the temporally table.

        Finally we insert the teporally table in the DB. 
        1.  SET @idProject = (SELECT SCOPE_IDENTITY()) 
        2.  INSERT INTO #temp_table SELECT * FROM @relProjectDS
        3. UPDATE #temp_table SET idProject = @idProject 
        4. INSERT INTO [dbo].[relProjectDomainSubdomain] (idProject, idCatDomain, idCatSubdomain) SELECT idProject, idCatDomain, idCatSubdomain FROM  #temp_table

         

        Tips:

        How to create a temporal table

        create table #temp_table
            (
                [idProjectDomainSubdomain] [int] IDENTITY(1,1) NOT NULL,
                [idProject] [int] NULL,
                [idCatDomain] [int] NOT NULL,
                [idCatSubdomain] [int] NULL,
            )










        Comentarios

        Entradas populares de este blog

        Android - Basic Steps (Service)

        Service Run in the main thread of the hosting application Android can kill the Service if need the resources Purpose Supporting inter-application method execution Performing background processing Start a Service Call Context.startService(Intent intent)\ To call from a Fragment use getActivity().getApplicationContext().startService( intentService); Executing the service After call startService(...)  In the Service is executed the method onStartCommand(...) If the method returns the constant START_NOT_STICKY then Android will not restart the service automatically if the the process is killedp Foreground To execute the service foreground call the method startForeground() Use this if the user is aware of the process Bind to a Service Call the method Context.bindService( Intent service ServiceConnection con int flags ) Send Toast from the Service On the method onStartCommand receive the message   ...

        Android - Basic Steps (Location & Maps)

        Location Is composed by Latitude Longitude Time-stamp Accuracy Altitude Speed Bearing LocationProvider Types: Network  Wifi access points Cell phone towers GPS Passive Piggyback on the readings requested by other application Permissions Network  android.permission.ACCESS_COARSE_LOCATION android.permission.ACCESS_FINE_LOCATION GPS android.permission.ACCESS_FINE_LOCATION Passive Provider android.permission.ACCESS_FINE_LOCATION LocationManager System service for accessing location data getSystemService( Context.LOCATION_SERVICE ) Functions Determine the last known user location Register for location update Register to receive intents when the device nears or move away from a given geographic area LocationListener Defines callbacks methods that are called when Location or LocationProvider status change. Methods onLocationChanged(...) onProviderDisabled(...) onProviderEnabled(...) onStatusChan...

        IIS - Permisions

        IIS Permissions To enable the Active Directory connection in the IIS, follow the next steps: Go to IIS Go to Application Pool Select your App Pool Select Advanced Settings in the right side In the section Process Model Select in Identity value the property " NetworkService " You don´t need to restart your application