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

        C# Using tabs

        To use tabs in C# use the TabContainer element from AjaxControlToolkit Include AjaxControlToolkit  Include in the Web.config file, inside the tag <system.web> the following code  <pages>       <controls>         <add tagPrefix="ajaxCTK" namespace="AjaxControlToolkit" assembly="AjaxControlToolkit"/>       </controls>     </pages>   Include TabContainer element First  include TabContainer element that is the section where all the tabs will be displayed. <ajaxCTK:TabContainer ID="TabContainerUpdate" runat="server"                 Height="800"                 CssClass="ajax__tab_style"> </ajaxCTK:TabContainer> Second per each tab include the following code corresponding to each ...

        Rails - Basic Steps III

        pValidations Validations are a type of ActiveRecord Validations are defined in our models Implement Validations Go to   root_app/app/models Open files  *.rb for each model Mandatory field validates_presence_of   :field Ex:   validates_presence_of    :title Classes The basic syntax is class MyClass        @global_variable                def my_method              @method_variable        end end Create an instance myInstance = MyClass.new Invoke a mehod mc.my_method class() method returns the type of the object In Ruby, last character of method define the behavior If ends with a question -> return a boolean value If ends with an exclamation -> change the state of the object Getter / Setter method def global_variable       return @global_variable end ...

        Python create package

        Create a root folder Create a sub-folder "example_pkg" that contains the funtionallity packaging_tutorial/ example_pkg/ __init__.py In the root folder create the following structure  packaging_tutorial/ example_pkg/ __init__.py tests/ setup.py LICENSE README.md in the setup.py contains the configuration of the packages your package is found by find_packages() import setuptools with open ( "README.md" , "r" ) as fh : long_description = fh . read () setuptools . setup ( name = "example-pkg-YOUR-USERNAME-HERE" , # Replace with your own username version = "0.0.1" , author = "Example Author" , author_email = "author@example.com" , description = "A small example package" , long_description = long_description , long_description_content_type = "text/markdown" , url = "https://github.com/pypa/sam...