Tema: Conexión a Base de Datos.

Anuncio
Sistemas Expertos e Inteligencia Artificial. Guía 6B
1
Facultad:
Ingeniería
Escuela:
Computación
Asignatura: Sistemas Expertos e
Inteligencia Artificial
Tema: Conexión a Base de Datos.
Objetivo
Específico


Crear una interfaz grafica con Visual C#.NET de manera básica
Utilizar las sentencias de DML de base de datos en Visual C#.NET
Materiales
Equipo
 Computadora con SQL Server 2008.
 Guía Número 6
 Bases de ejemplo.
Introducción
Teórica
Introducción
En la mayoría de aplicaciones incluidas en SQL Server, no todo el desarrollo se
realiza en el propio servidor. Ésa es la esencia de la informática cliente servidor; el
trabajo se distribuye entre un servidor central y clientes distribuidos.
Para poder ver y modificar datos del servidor desde una aplicación cliente, se
utiliza una biblioteca de acceso a datos.
A lo largo de los años, Microsoft ha presentado diversas bibliotecas de acceso a
datos del cliente que pueden usar los datos de SQL Server y la última tecnología
que Microsoft ha desarrollado es ADO.NET.
2
Sistemas Expertos e Inteligencia Artificial, Guía 6B
Espacios de nombres y clases básicas de ADO.NET
Hay seis espacios básicos de ADO.NET, pero solo veremos los concernientes a
SQL Server y se recogen en la siguiente tabla. Además de estos espacios de
nombres, cada nuevo proveedor de datos tiene su propio espacio de nombre.
Como ejemplo, el proveedor de datos Oracle .NET añade un espacio de nombre
de Microsoft.Data.OracleClient.
Espacio de Nombres
System.Data
Descripción
Este espacio de nombres es el principal
para ADO.NET. contiene las clases utilizadas por todos
los
proveedores
de
datos.
Contiene
clases
para
representar tablas, columnas, filas y el DataSet. También
contiene
diversas
interfaces
muyútiles,
como
IDbCommand, IDbConnection e IDbDataAdapter. Estas
interfaces
las
utilizan
todos
los
proveedores
administrados, permitiéndoles conectarse en el centro
deADO.NET
System.Data.sqlClient
Este espacio de nombres define un proveedor de datos
para una base de datos SQL Server 7.0 o superior, como
sqlConnection y sqlCommand.
Espacio de nombres Descripción
Sistemas Expertos e Inteligencia Artificial. Guía 6B
ADO.NET tiene tres tipos distintos de clases conocidas comúnmente como
Disconnected,
Shared
y
Data
Providers.
Las
clases
Disconnected
proporcionan la estructura básica de ADO.NET. Un buen ejemplo de este tipo de
clases es la clase DataTable. Los objetos de esta clase pueden guardar datos sin
ninguna dependencia de un proveedor de datos específicos. Las clases Shared
son las clases base para los proveedores de datos y se comparten entre todos los
proveedores de datos. Las clases Data Provider están diseñadas para trabajar
con distintos tipos de orígenes de datos. Se utilizan para ejecutar todas las
operaciones de administración de datos sobre bases de datos específicas. Por
ejemplo, el proveedor de datos sqlClient funciona sólo con la base de datos SQL
Server.
La figura.1 muestra un esquema de cómo encajan estos espacios de nombres
y algunas de sus clases.
3
4
Sistemas Expertos e Inteligencia Artificial, Guía 6B
Distintas versiones de ADO.NET
Se llama ADO.NET a todas las clases, interfaces, enumeradores y delegados que
se encuentran dentro de los espacios de nombres System.Data y System.xml del
.NET Framework de Microsoft. Por cada versión del .NET Framework existe una
versión de ADO.NET; dichas versiones van obteniendo mejoras desarrolladas por
Microsoft,
muchas de
ellas por pedido
de la
comunidad
mundial de
desarrolladores. Las versiones liberadas hasta este momento son las siguientes:
Versión
.NET Framework 1.1
.NET Framework 2.0
.NET Framework 4.0
Lanzamiento
2002
2003
2010
Herramienta
Visual Studio.NET
Visual Studio.NET 2005
Visual Studio.NET 2010
Conexión
A simple vista, las conexiones pueden parecer uno de los objetos más sencillos de
utilizar en ADO.NET. Sin embargo, tomar las decisiones correctas al momento de
su uso puede ser la diferencia entre una aplicación de altas prestaciones y otra de
bajas. Existe una serie de premisas fundamentales que servirán para favorecer un
rendimiento óptimo, las cuales se verán a lo largo de la guía de laboratorio.
En primer lugar, el objeto Connection es un .NET Data Provider, y nos permite
establecer la comunicación física entre nuestra aplicación y la base de datos. El
.NET Framework posee la interfaz IDBConnection, la cual es implementada por las
clases sqlConnection, oledbConnection y OracleConnection en sus versiones 1.x
(1.0 y 1.1), y en el caso de su versión 2.0, es implementada por la clase
DBConnection, que sirve como la base de los .NET Data Providers.
Cadena de conexión
Las conexiones establecen todos sus parámetros a través de la propiedad
ConnectionString, la cual debe ser establecida de un modo correcto previo a su
apertura. Esta propiedad es, en realidad, un conjunto de propiedades
Sistemas Expertos e Inteligencia Artificial. Guía 6B
concatenados en una sola cadena de texto, en el formato “Propiedad=Valor;”.
Muchas de estas propiedades que conforman la cadena son obligatorias, y otras
poseen valores por defecto si no se establecen.
Existen algunas propiedades bastantes específicas de cada proveedor de datos, y
otras que pueden resultar sinónimos. A continuación veremos en la siguiente tabla
las propiedades más comúnmente utilizadas en la cadena de conexión.
Comandos
Ya hemos visto que las conexiones nos brindan el vínculo entre las bases de
datos y las aplicaciones, pero para poder establecer y ejecutar instrucciones
necesitamos de los comandos, los cuales llamaremos indistintamente como
xxxCommand. Una de las propiedades fundamentales de los comandos es
CommandText que, como veremos más adelante, puede tener sentencias SQL o
nombres de objetos de las bases de datos. Otra propiedad fundamental es
Connection, a la cual le asignaremos una instancia de tipo xxxConnection. Las
clases xxxCommand tienen constructores sobrecargados que nos permiten
5
6
Sistemas Expertos e Inteligencia Artificial, Guía 6B
declarar, instancias e inicializar nuestros objetos en una sola línea de forma
alternativa.
Primero vamos a examinar algunas propiedades útiles de la clase sqlCommand
que incluye la siguiente tabla:
Sistemas Expertos e Inteligencia Artificial. Guía 6B
Ahora vamos a examinar los diversos métodos Execute que se pueden llamar en
un objeto Command.
SQL Native Client OLE DB Provider
El proveedor OLE DB de Microsoft SQL Native Client proporciona una interfaz OLE DB a
las bases de datos de Microsoft SQL Server 2008. Este proveedor permite que las
consultas distribuidas de SQL Server puedan consultar datos de instancias remotas de
SQL Server.
7
8
Sistemas Expertos e Inteligencia Artificial, Guía 6B
Sintaxis:
Provider=SQLOLEDB.1;Server=myServerName\theInstanceName; Database=myDataBase;
Uid=myUsername;Pwd=myPassword;
Dataset
Un DataSet representa un conjunto completo de datos, incluyendo las tablas que
contienen, ordenan y restringen los datos, así como las relaciones entre las tablas. Llenar
el DataSet con tablas de datos de un origen de datos relacional existente mediante
DataAdapter
DataAdapter (Clase)
Representa un conjunto de comandos SQL y una conexión de base de datos que se
utilizan para rellenar el objeto DataSet y actualizar el origen de datos.
OleDbCommand (Clase)
Representa una instrucción SQL o un procedimiento almacenado que se va a ejecutar en
un origen de datos.
DataGridView
El control DataGridView proporciona una forma eficaz y flexible de mostrar datos en
formato de tabla. Puede utilizar el control DataGridView para mostrar vistas de sólo
lectura de una cantidad pequeña de datos o puede ajustar su tamaño para mostrar vistas
modificables de conjuntos muy grandes de datos.
DataGridView.DataSource (Propiedad)
Obtiene o establece el origen de datos cuyos datos se están mostrando en el control
DataGridView.
Sintaxis:
DataGridView1.DataMember = "MiTabla"
Sistemas Expertos e Inteligencia Artificial. Guía 6B
Procedimiento
Ingrese a SQL Server 2008 y ejecute la siguiente consulta
Guía 3
create database BD_Sucarnet
GO
4
useGuía
BD_Sucarnet
GO
create table Participantes
fía varchar(25) ,
(Codigo
Nombres varchar(25),
Apellidos varchar(25),
Edad varchar(2))
GO
insert into Participantes values(1,'Alba','Castro Castro',26)
insert into Participantes values(2,'Mario','Cañas Abarca',25)
insert into Participantes values(3,'Alberto','Granados',30)
insert into Participantes values(4,'Itzel','Murphy Martinez',28)
GO
Trabajando con Visual Studio 2010
1. Creen un nuevo proyecto en Visual C# con el nombre de Practica 6
2. Crear el siguiente los siguientes formularios.
3.
En los elementos del Form1 hacer los siguientes cambios
Elemento
textBox1
textBox2
textBox3
Propiedades
Name
Visible
textcod1
true
textnom1
False
textapel1
False
9
10
Sistemas Expertos e Inteligencia Artificial, Guía 6B
textBox4
Button1
Button2
4.
textedad1
buscar1
modificar1
False
true
false
En los elementos del Form2 hacer los siguientes cambios:
Elemento
textBox1
textBox2
textBox3
textBox4
Button1
Button2
Propiedades
Name
Visible
textcod2
true
textnom2
true
textapel2
true
textedad2
true
insertar2
true
buscar2
true
5. Haremos dos tipos de conexión una haciendo uso de OLEDB y otra por
medio de SqlClient.
6. Ubícate en el Explorador de soluciones y dando clic derecho sobre el
proyecto Practica 6, selecciona la opción agregar y luego selecciona nuevo
elemento.
7. En cuadro de dialogo nuevo elemento selecciona Clase y colócale el
nombre de conexion.cs
8. Digita las siguientes líneas de código como se muestra a continuación:
using
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
System.Data.SqlClient;
namespace Practica62
{
class conexion
{
public string servidor, usuario, clave, db;//Para metros para la cadena
conexion
public string cadena;
public void conec() // funcion que tendra la cadena de conexion
servidor = "Localhost";
db = "BD_Sucarnet";
usuario = "sa";
clave = "123456";
cadena="server="+servidor+";uid="+usuario+";pwd="+clave+";database="+db;
}
}
}
Sistemas Expertos e Inteligencia Artificial. Guía 6B
9. En el código de la aplicación (hacer clic derecho sobre el Form2 y seleccionar la
opción Ver código) digitar lo siguiente:
using
using
using
using
using
using
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
System.Data.SqlClient;
namespace Practica6
{
public partial class Form2 : Form
{
private SqlConnection conn;
private SqlCommand insert1;
private string sCn;
public Form2()// inicio del constructor
{
InitializeComponent();
//usando la clase conexion
conexion cn= new conexion();// creo un nuevo objeto de tipo Conexion y
lo asigno a cn
cn.conec();//acceso a la guncion conec de la clase conexion
sCn = cn.cadena;//agrego la variable scn a la cadena conexion
conn = new SqlConnection(sCn);//creo la conexion pansandole como
argumento la cadena
conn.Open();//abro la conexion
}// fin del constructor
10. Damos doble clic sobre el botón Insertar y digitamos lo siguiente:
string inserparticipante;// creo la variable que contendra la consulta sql de
insercion
inserparticipante = "INSERT INTO Participantes(Codigo,Nombres,Apellidos,Edad)";
inserparticipante += "VALUES( @carnet,@nombre,@apellido,@edad)";
insert1 = new SqlCommand(inserparticipante, conn);
insert1.Parameters.Add(new SqlParameter("@carnet", SqlDbType.VarChar));
insert1.Parameters["@carnet"].Value = textcod2.Text;
insert1.Parameters.Add(new SqlParameter("@nombre", SqlDbType.VarChar));
insert1.Parameters["@nombre"].Value = textnom2.Text;
insert1.Parameters.Add(new SqlParameter("@apellido", SqlDbType.VarChar));
insert1.Parameters["@apellido"].Value = textnom2.Text;
insert1.Parameters.Add(new SqlParameter("@edad", SqlDbType.VarChar));
insert1.Parameters["@edad"].Value = textcod2.Text;
11
12
Sistemas Expertos e Inteligencia Artificial, Guía 6B
insert1.ExecuteNonQuery();
//Limpiamos los textBox
textcod2.Text = "";
textnom2.Text = "";
textapel2.Text = "";
textedad2.Text = "";
MessageBox.Show("Registro agregado");
conn.Close();
}
catch {
MessageBox.Show("Error");
}
11. Damos doble clic sobre el botón Buscar del Form2 y digitamos lo siguiente:
Form1 formu1 = new Form1();// instanciamos un objeto de tipo Form1
formu1.Show();// mostramos el Form1
this.Hide();// ocultamos el Form2
12. Ahora modificaremos el Form1, dar clic derecho sobre este y seleccionar la opción
ver código y digita las siguientes líneas antes de la namespace Practica6
using System.Data.OleDb;
using System.Data.SqlClient;
13. Declara las siguientes variables antes del constructor.
private SqlConnection conn1;//Defino una variable de tipo Connection
private SqlDataAdapter da1;//Defino una variable de tipo DataAdapter
private SqlDataReader dr1;//Defino una variable de tipo DataReader
private string sCn1;//define una variable que contendra la cadena de conexion
OleDbConnection cnn= new OleDbConnection();//instacio un variable
OleDbConection
14. Escriba el siguiente codigo despues del InitializeComponent():
//linea de conexion con el servido de base de datos SQL por OLEDB
cnn.ConnectionString =
@"PROVIDER=SQLOLEDB;Server=localhost;Database=BD_Sucarnet;Uid=sa;Pwd=123456";
modificar1.Visible = false;// ocultamos el botón modificar
//conexion por medio de SQLCLIENT
conexion cn1 = new conexion();
cn1.conec();
sCn1 = cn1.cadena;
conn1 = new SqlConnection(sCn1);
conn1.Open();
15. De clic en el botón buscar y digite el siguiente código:
// Mostramos los textbox ocultos
textedad1.Visible=true;
textnom1.Visible = true;
textapel1.Visible = true;
modificar1.Visible = true;
Sistemas Expertos e Inteligencia Artificial. Guía 6B
string seleccion;//variable que tendrá la consulta.
seleccion = "Select *From Participantes where Codigo= '" +
textcod1.Text + "'";
da1 = new SqlDataAdapter(seleccion, conn1);
SqlParameter prm = new SqlParameter("Codigo", SqlDbType.VarChar);
prm.Value = textcod1.Text;
da1.SelectCommand.Parameters.Add(prm);
dr1 = da1.SelectCommand.ExecuteReader();
while(dr1.Read()){
textnom1.Text = dr1["Nombres"].ToString().Trim();
textapel1.Text = dr1["Apellidos"].ToString().Trim();
textedad1.Text = dr1["Edad"].ToString().Trim();
}
if (dr1 != null)
{
MessageBox.Show("Datos Encontrados");
dr1.Close();
}
16. En el botón Modificar ingresa el siguiente código:
string actualizar;
actualizar = "update Participantes set ";
actualizar += " Nombres= '" + textnom1.Text + "', Apellidos= '" +
textapel1.Text;
actualizar += "', Edad=" + textedad1.Text + " where Codigo= '" +
textcod1.Text+"'";
OleDbCommand datos = new OleDbCommand(actualizar, cnn);
cnn.Open();
//mandando sql a base de datos
datos.ExecuteNonQuery();
cnn.Close();
MessageBox.Show("REGISTRO ACTUALIZADO");
Reset();
17. Declara una función Reset para limpiar los texbox :
private void Reset() {
textcod1.Text = "";
textnom1.Text = "";
textapel1.Text = "";
textedad1.Text = "";
textedad1.Visible = false;
textnom1.Visible = false;
textapel1.Visible = false;
modificar1.Visible = false;
Form2 formu2 = new Form2();
formu2.Show();//Mostramos el Form2
this.Hide();// ocultamos el Form1
}
13
14
Sistemas Expertos e Inteligencia Artificial, Guía 6B
18. Por último abre el archive Program.cs del proyecto y modifica la siguiente línea
para que cargue automáticamente el Form2.
Application.Run(new Form2());
19. Configure el botón eliminar que se pueda realizar el mantenimiento
Investigación
Complementaria

La tarea de esta práctica será asignada por el instructor.
Guía 3
Bibliografía
 Francisco Charte Ojeda, SQL Server 2008. Madrid, España : ANAYA,
Guía
4
3
2009 1era
fía
Guía 4
fía
edición
Sistemas Expertos e Inteligencia Artificial. Guía 6B
Hoja de cotejo:
Docente:
Guía 6:
Conexión a Base de
Máquina No:
dato
GL:
Alumno
:
Tema: Presentación
del programa
Máquina No:
a
Máquina No:
Alumno:
Docente:
GL:
Docente:
GL:
Fecha:
EVALUACION
%
CONOCIMIENTO
Del 20
al 30%
APLICACIÓN
DEL
CONOCIMIENTO
Del 40%
al 60%
1-4
5-7
8-10
Conocimie
nto
deficient
e de los
fundament
os
teóricos
Conocimiento
y explicación
incompleta de
los
fundamentos
teóricos
Conocimiento
completo y
explicación
clara de los
fundamentos
teóricos
No tiene
actitud
proactiva
.
Actitud
propositiva y
con
propuestas no
aplicables al
contenido de
la guía.
Tiene actitud
proactiva y sus
propuestas son
concretas.
ACTITUD
Del 15%
al 30%
TOTAL
100%
Nota
6
1
15
Descargar