30 de enero de 2012

DGV - C#

se cargara el formulario con los datos, se podrá insertar, modificar y eliminar registros a una base de datos en SQL Express utilizando C# con Visual Studio 2010, asi que para empezar utilizamos el SQL Server Management Studio 2008, abrimos y luego click derecho en databases y seleccionar new database



se crea una base de datos a la cual se va acceder, en este ejemplo se llamara empleado y a la vez se creara una tabla para guardar los datos, así que en la nueva base de datos creada, extender el contenido y click derecho en tables, luego seleccionar new Table...


aquí están los campos de la tabla y el nombre que utilizare, se llamara datos y tendrá cuatro campos, luego presionamos OK para guardar y abrimos el Visual Studio, en mi caso utilizo el VS 2010.


Creamos un nuevo proyecto en C# para empezar a trabajar sobre el, en este ejemplo el nombre que le puse fue C - SQL


lo primero va ser crear un nuevo archivo app.config para recuperar la cadena de conexion para conectarse a la base de datos, para eso click derecho en el proyecto que se acaba de crear y seleccionar properties.


luego en settings cambiamos los valores de Name y Type tal como aparecen en la imagen, en el caso de Scope, este cambia automáticamente al cambiar el Type y el value debe buscarse, para eso se da click en el botón al final, el que tiene los tres puntos, luego en la pantalla que te aparecerá buscas tu servidor de base de datos y tu base.




ahora que se tiene la conexión se deberá añadir la referencia System.Configuration, para eso click derecho en  el proyecto dentro del Solution Explorer y seleccionar Add Reference 



Ahora creamos una nueva clase en el proyecto donde se realizaran las operaciones importantes del proyecto, para este caso se llamara ACME


y dentro de esta clase se deberán añadir estas referencias:

using System.Data.SqlClient;
using System.Configuration;
using System.Windows.Forms;
using System.Data;

  
y luego copiar este código:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.SqlClient;
using System.Configuration;
using System.Windows.Forms;
using System.Data;

namespace C___SQL
{
    class ACME
    {
        SqlDataAdapter da;
        DataTable dt;
        SqlConnection cnn;
        SqlCommand cmd;
        string conex = ConfigurationManager.ConnectionStrings["con"].ConnectionString;
        string select = "select * from datos";

        public DataTable cargarDatos()
        {
            using (cnn = new SqlConnection(conex))
            {
                cnn.Open();
                da = new SqlDataAdapter(select, conex);
                dt = new DataTable();
                da.Fill(dt);
                return dt;
            }
        }

        public void InsertarDatos(string val1, string val2, string val3)
        {
            using (cnn = new SqlConnection(conex))
            {
                cnn.Open();
                cmd = new SqlCommand();
                cmd.Connection = cnn;
                cmd.CommandText = "insert into datos values(@nombre, @cargo, @dpto)";
                cmd.Parameters.AddWithValue("@nombre", val1);
                cmd.Parameters.AddWithValue("@cargo", val2);
                cmd.Parameters.AddWithValue("@dpto", val3);
                cmd.ExecuteNonQuery();
                MessageBox.Show("Datos ingresados correctamente");
                cmd.Dispose();   
            }
        }

        public void ModificarDatos(string val1, string val2, string val3, string val4)
        {
            using (cnn = new SqlConnection(conex))
            {
                cnn.Open();
                cmd = new SqlCommand();
                cmd.Connection = cnn;
                cmd.CommandText = "update datos set nombre=@nombre, cargo=@cargo, departamento=@departamento where id=@id";
                cmd.Parameters.AddWithValue("@nombre", val1);
                cmd.Parameters.AddWithValue("@cargo", val2);
                cmd.Parameters.AddWithValue("@departamento", val3);
                cmd.Parameters.AddWithValue("@id", val4);
                cmd.ExecuteNonQuery();
                cmd.Dispose();
                MessageBox.Show("datos modificados exitosamente");
            }
       
        }

        public void eliminardatos(string val1)
        {
            using (cnn = new SqlConnection(conex))
            {
                cnn.Open();
                cmd = new SqlCommand();
                cmd.Connection = cnn;
                cmd.CommandText = "delete from datos where id=@id";
                cmd.Parameters.AddWithValue("@id", val1);
                cmd.ExecuteNonQuery();
                MessageBox.Show("Datos eliminados correctamente");
                cmd.Dispose();
            }
        }

    }

}

por ultimo, el formulario a utilizar queda de la siguiente manera, utilizando un BindingNavigator y un DataGridView


Por ultimo dentro del form colocar este código:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;

namespace C___SQL
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
           
           
        }
        ACME ejemplo = new ACME();
        BindingSource bs;
        private void Form1_Load(object sender, EventArgs e)
        {
            Mostrar();
                  
        }

        private void Mostrar()
        {
            bs = new BindingSource();
            bs.DataSource = ejemplo.cargarDatos();
            bindingNavigator1.BindingSource = bs;
            dataGridView1.DataSource = bs;
            textBox1.DataBindings.Clear();
            textBox2.DataBindings.Clear();
            textBox3.DataBindings.Clear();
            textBox4.DataBindings.Clear();
            textBox1.DataBindings.Add("text", bs, "nombre");
            textBox2.DataBindings.Add("text", bs, "cargo");
            textBox3.DataBindings.Add("text", bs, "departamento");
            textBox4.DataBindings.Add("text", bs, "id");
        }

        private void Insertar_Click(object sender, EventArgs e)
        {
            ejemplo.InsertarDatos(textBox1.Text, textBox2.Text, textBox3.Text);
            Mostrar();
        }

        private void Modificar_Click(object sender, EventArgs e)
        {
            ejemplo.ModificarDatos(textBox1.Text, textBox2.Text, textBox3.Text, textBox4.Text);
                Mostrar();
        }

        private void Eliminar_Click(object sender, EventArgs e)
        {
            ejemplo.eliminardatos(textBox4.Text);
                Mostrar();
        }

        private void Cerrar_Click(object sender, EventArgs e)
        {
            this.Close();
        }
      
    }

}

Compilamos, ejecutamos y ya esta.