Manejando llaves primarias en un DataSet
Supongamos que requerimos una tabla que tenga dos columnas: ID y Nombre. La primera columna (ID) deberá ser llave primaria y además será de tipo "UniqueIdentifier" de modo que nos permita almacenar valores alfanuméricos y que no se repitan.
Dim dsProcesadas As New DataSet("MiDataSet")
Dim newTable1 As New DataTable("MiTabla1")
dsProcesadas.Tables.Add(newTable1)
newTable1.Columns.Add("ID", Type.GetType("System.Guid"), "")
newTable1.Columns.Add("Nombre", Type.GetType("System.String"), "")
Dim key(0) As DataColumn
key(0) = newTable1.Columns("ID")
newTable1.PrimaryKey = key
¿Cómo añado registros?
Es muy fácil, podemos crear una rutina muy aparte que lo haga y que reciba como parámetros los valores de las columnas. No nos confundamos, veamos el ejemplo:
Sub CreaRegistro(ByVal GuidID As Guid,ByVal StrNombre As String, ByRef ds As DataSet)
Dim row As DataRow
row = ds.Tables("MiTabla1").NewRow
ds.Tables("MiTabla1").Rows.Add(row)
row("ID") = GuidID
row("Nombre") = StrNombre
End Sub
Juntemos todo el código en la siguiente función:
<script runat="server">
Sub Page_Load()
Dim ds As new DataSet
ds = GetDataSetPrincipal()
'# A PARTIR DE AQUI PODEMOS HACER Y DESHACER
'# EN EL DATASET
End Sub
Function GetDataSetPrincipal() As DataSet
Dim ds As New DataSet("MiDataSet")
Dim newTable1 As New DataTable("MiTabla1")
ds.Tables.Add(newTable1)
newTable1.Columns.Add("ID", Type.GetType("System.Guid"), "")
newTable1.Columns.Add("Nombre", Type.GetType("System.String"), "")
Dim key(0) As DataColumn
key(0) = newTable1.Columns("ID")
newTable1.PrimaryKey = key
Dim GuidJuan As Guid = New Guid("9CD8769C-7DEB-40A0-828E-DBB03556B451")
Dim GuidPedro As Guid = New Guid("9CD8769C-7DEB-40A0-828E-DBB03556B452")
Dim GuidAna As Guid = New Guid("9CD8769C-7DEB-40A0-828E-DBB03556B453")
CreaRegistro(GuidJuan, "Juan" , ds)
CreaRegistro(GuidPedro, "Pedro" , ds)
CreaRegistro(GuidAna, "Ana" , ds)
Return ds
End Function
Sub CreaRegistro(ByVal GuidID As Guid,ByVal StrNombre As String, ByRef ds As DataSet)
Dim row As DataRow
row = ds.Tables("MiTabla1").NewRow
ds.Tables("MiTabla1").Rows.Add(row)
row("ID") = GuidID
row("Nombre") = StrNombre
End Sub
</script>
Supongamos que requerimos una tabla que tenga dos columnas: ID y Nombre. La primera columna (ID) deberá ser llave primaria y además será de tipo "UniqueIdentifier" de modo que nos permita almacenar valores alfanuméricos y que no se repitan.
Dim dsProcesadas As New DataSet("MiDataSet")
Dim newTable1 As New DataTable("MiTabla1")
dsProcesadas.Tables.Add(newTable1)
newTable1.Columns.Add("ID", Type.GetType("System.Guid"), "")
newTable1.Columns.Add("Nombre", Type.GetType("System.String"), "")
Dim key(0) As DataColumn
key(0) = newTable1.Columns("ID")
newTable1.PrimaryKey = key
¿Cómo añado registros?
Es muy fácil, podemos crear una rutina muy aparte que lo haga y que reciba como parámetros los valores de las columnas. No nos confundamos, veamos el ejemplo:
Sub CreaRegistro(ByVal GuidID As Guid,ByVal StrNombre As String, ByRef ds As DataSet)
Dim row As DataRow
row = ds.Tables("MiTabla1").NewRow
ds.Tables("MiTabla1").Rows.Add(row)
row("ID") = GuidID
row("Nombre") = StrNombre
End Sub
Juntemos todo el código en la siguiente función:
<script runat="server">
Sub Page_Load()
Dim ds As new DataSet
ds = GetDataSetPrincipal()
'# A PARTIR DE AQUI PODEMOS HACER Y DESHACER
'# EN EL DATASET
End Sub
Function GetDataSetPrincipal() As DataSet
Dim ds As New DataSet("MiDataSet")
Dim newTable1 As New DataTable("MiTabla1")
ds.Tables.Add(newTable1)
newTable1.Columns.Add("ID", Type.GetType("System.Guid"), "")
newTable1.Columns.Add("Nombre", Type.GetType("System.String"), "")
Dim key(0) As DataColumn
key(0) = newTable1.Columns("ID")
newTable1.PrimaryKey = key
Dim GuidJuan As Guid = New Guid("9CD8769C-7DEB-40A0-828E-DBB03556B451")
Dim GuidPedro As Guid = New Guid("9CD8769C-7DEB-40A0-828E-DBB03556B452")
Dim GuidAna As Guid = New Guid("9CD8769C-7DEB-40A0-828E-DBB03556B453")
CreaRegistro(GuidJuan, "Juan" , ds)
CreaRegistro(GuidPedro, "Pedro" , ds)
CreaRegistro(GuidAna, "Ana" , ds)
Return ds
End Function
Sub CreaRegistro(ByVal GuidID As Guid,ByVal StrNombre As String, ByRef ds As DataSet)
Dim row As DataRow
row = ds.Tables("MiTabla1").NewRow
ds.Tables("MiTabla1").Rows.Add(row)
row("ID") = GuidID
row("Nombre") = StrNombre
End Sub
</script>
0 Comments:
Post a Comment
<< Home