Foros del Web » Programando para Internet » ASPX (.net) »

Base de datos asp.net

Estas en el tema de Base de datos asp.net en el foro de ASPX (.net) en Foros del Web. ESTE CODIGO ME GENERA UNA TABLA CON LA BUSQUEDA DESEADA, PERO LO QUE QUEIRO REALIZAR ESQUE ME AGREGE UN TERCER CAMPO QUE DIGA GENERAR Y ...
  #1 (permalink)  
Antiguo 02/06/2011, 11:56
 
Fecha de Ingreso: febrero-2011
Mensajes: 41
Antigüedad: 13 años, 2 meses
Puntos: 1
Base de datos asp.net

ESTE CODIGO ME GENERA UNA TABLA CON LA BUSQUEDA DESEADA, PERO LO QUE QUEIRO REALIZAR ESQUE ME AGREGE UN TERCER CAMPO QUE DIGA GENERAR Y QUE AL DARLE UN CLICK SE REDIRECCIONE A OTRA PAGINA DONDE TOME LOS VALORES DE LOS CAMPOS DONDE SE ENCUENTRA LA OPCION DE GENERAR, ESTE ME SERVIRIA PARA LA OPCION DE GENERAR UN REPORTE. POR EJEMPLO

RESULTADO DE LA BUSQUEDA

CODIGO APELLIDOS NOMBRE CREAR
1 LARIOS PEPE GENERAR

Y AL PULSAR GENERAR ME MANDE A OTRA PAGINA DONDE TOME LOS VALORES QUE CONTIENE ESA FILA O ME BASTARÍA CON TAN SOLO QUE ME REDIRECCIONE A OTRA PAGINA AQUIE LES PONGO EL CODIGO QUE TENGO


<%@ Page Title="Página principal" Language="C#" MasterPageFile="~/Site.master" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="RLs._Default" %>
<%@ Import Namespace="System.Data" %>
<%@ Import Namespace="System.Data.OleDb" %>
<script runat="server" language="c#" >
/*Variables utilizadas
----------------------------------------------------------------------------------------------------------------------------------------------------*/
String selectOpcion, textboxBusqueda, espacioBlanco, radioCheck, errorMensajeBlanco,errorMensajeExpresion;

void Page_Load(Object sender, EventArgs e) {
/*RadioButton seleccionados por tipos de busqueda
----------------------------------------------------------------------------------------------------------------------------------------*/
radioCheck = check.SelectedItem.Text;
if (radioCheck == "Codigo")
{
selectOpcion = "CODIGO";
textboxBusqueda = codigo.Text;
validarExpresion.ValidationExpression = "\\d+";
errorMensajeExpresion = "Valor Invalido";
errorMensajeBlanco = "Ingresa un Codigo";
}
else if (radioCheck == "Nombre")
{
selectOpcion = "NOMBRE";
textboxBusqueda = "'%" + codigo.Text + "%'";
validarExpresion.ValidationExpression = "[a-zA-ZñÑ ]{3,}";
errorMensajeExpresion = "Valor Invalido";

}
else if (radioCheck == "Apellido")
{
espacioBlanco = codigo.Text.Replace(" ", "");
selectOpcion = "APEPAT & APEPAT & APEMAT";
textboxBusqueda = "'%" + espacioBlanco + "%'";
validarExpresion.ValidationExpression = "[a-zA-ZñÑ ]{3,}";
errorMensajeExpresion = "Valor Invalido";
}
}
/*Funcion de boton que realiza la busqueda en la base de datos
---------------------------------------------------------------------------------------------------------------------------------------------------*/
void Busqueda(object sender, EventArgs args)
{
Int64 totalConteo;

/*CONEXION CON LA BASE DE DATOS
---------------------------------------------------------------------------------------------------------------------------------------*/
//Variable que utiliza para realizar la conexion
String conexionCadena = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=D:\\RLs.mdb";

/*Crear un objeto OleDbConnection y pasar la ConnectionString al construtor.
---------------------------------------------------------------------------------------------------------------------------------------*/
OleDbConnection conexion = new OleDbConnection(conexionCadena);

/*Abrir la conexion
---------------------------------------------------------------------------------------------------------------------------------------*/
conexion.Open();

/*Consulta que cuenta todos los trabajadores en la tabla de TRABAJADOR
---------------------------------------------------------------------------------------------------------------------------------------*/
OleDbCommand totalRegistros = new OleDbCommand ("SELECT COUNT(*) FROM TRABAJADOR",conexion);
OleDbDataReader readerTotal = totalRegistros.ExecuteReader();
readerTotal.Read();
/*Consulta que cuenta todos los trabajadores por el metodo de busqueda ingresado
---------------------------------------------------------------------------------------------------------------------------------------*/
OleDbCommand totalBusqueda = new OleDbCommand ("SELECT COUNT(*) FROM TRABAJADOR WHERE (" + selectOpcion + " LIKE " + textboxBusqueda + ")", conexion);
OleDbDataReader reader = totalBusqueda.ExecuteReader();
reader.Read();
totalConteo = Convert.ToInt64(reader[0].ToString());

resultadoBusqueda.Text = "El resultado de la busqueda es "+reader[0].ToString()+"-"+readerTotal[0].ToString();
/*Crear un objeto OleDbCommand para llevar acabo la consulta
---------------------------------------------------------------------------------------------------------------------------------------*/
OleDbDataAdapter consulta = new OleDbDataAdapter("SELECT NOMBRE,APEPAT,APEMAT,CODIGO FROM TRABAJADOR WHERE (" + selectOpcion + " LIKE " + textboxBusqueda + ")", conexion);
DataSet ds = new DataSet();

try
{
if (totalConteo > 0) {
consulta.Fill(ds, "TRABAJADOR");
repiteDatos.DataSource = ds.Tables["TRABAJADOR"].DefaultView;
repiteDatos.DataBind();
}
}
catch {
}
}
</script>

<asp:Content ID="HeaderContent" runat="server" ContentPlaceHolderID="HeadContent">
</asp:Content>
<asp:Content ID="BodyContent" runat="server" ContentPlaceHolderID="MainContent">
<h2>
Busqueda
</h2>

<asp:RadioButtonList ID="check" runat="server" RepeatDirection="Horizontal" AutoPostBack="true" >
<asp:ListItem Text="Codigo" Selected="True" Value="GreaterThan"/>
<asp:ListItem Text="Nombre" />
<asp:ListItem Text="Apellido" />
</asp:RadioButtonList>

<!--Textbox utilizado para ingresar la busqueda en la BD-->
<asp:TextBox ID="codigo" runat="server" onkeyup="this.value=this.value.toUpperCase()" />
<asp:Button ID="codigoBoton" runat="server" Text="Buscar" OnClick="Busqueda" />

<!--Validador del textbox para que solo se ingresen numeros cuando se seleccione el radiobutton de codigo-->
<asp:RegularExpressionValidator ID="validarExpresion" runat="server" ControlToValidate="codigo" Display="Dynamic"
ForeColor="Red" Font-Size="8" Font-Bold="true" Font-Italic="true">
<%= errorMensajeExpresion %>
</asp:RegularExpressionValidator>

<asp:RequiredFieldValidator ID="validarBlanco" runat="server" ControlToValidate="codigo" Display="Dynamic"
ForeColor="Red" Font-Size="8" Font-Bold="true" Font-Italic="true" >
<%= errorMensajeBlanco %>
</asp:RequiredFieldValidator>

<br />
<!--Label que muestra el resultado de la busqueda-->
<asp:Label ID="resultadoBusqueda" runat="server" />


<asp:Repeater ID="repiteDatos" runat="server">
<HeaderTemplate>
<table width="30%" style="font: 8pt verdana">
<tr bgcolor="ff00d8">
<th>Codigo</th>
<th>Apellido Paterno</th>
<th>Apellido Materno</th>
<th>Nombre(s)</th>
</tr>
</HeaderTemplate>
<ItemTemplate>
<tr bgcolor="FFECD8">
<td align="right"><%# DataBinder.Eval(Container.DataItem, "CODIGO") %></td>
<td align="right"><%# DataBinder.Eval(Container.DataItem,"APEPAT") %></td>
<td align="right"><%# DataBinder.Eval(Container.DataItem,"APEMAT") %></td>
<td align="right"><%# DataBinder.Eval(Container.DataItem,"NOMBRE") %></td>
</tr>
</ItemTemplate>
<FooterTemplate>
</table>
</FooterTemplate>
</asp:Repeater>


</asp:Content>

Etiquetas: aspx
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 08:01.