Archivo de la etiqueta: SQL Server

Posts sobre SQL Server, comandos de SQL, Management Studio, etc.

como conectar a una base de datos de MySQL en un servidor Web desde .NET

 

Pues eso… hace unos días he estado haciendo una pequeña aplicación para acceder a una base de datos de MySQL creada en un servidor web de Domitienda y voy a aprovechar para comentarte las cosillas que he hecho (como conectar a una BBDD de MySQL, enviar emails, obtener datos de tres tablas diferentes pero que había que relacionar para sacar lo que interesaba, etc.) y la primera fue lo más importante: Conectar con una base de datos de MySQL con Visual Basic .NET (o .NET en general).
Y esto es lo que te voy a contar en este "artículo" de hoy lunes 13 de abril de 2015.

Los requisitos

Lo primero que deberías hacer es descargarte la DLL (librería/biblioteca) de MySQL para usar con Visual Studio, bueno, en realidad lo que yo me iba a bajar el Connector .NET, concretamente la versión 6.9.6 porque decía que la versión 6.7 el Connector/Net no incluye el "MySQL for Visual Studio integration", así que ni me puse a "investigar" a qué se refería, por tanto me bajé el MySQL for Visual Studio, concretamente la versión web community 5.6.23.0 (a la hora de escribir esto está la versión 5.6.24.0).

Nota:
El descargar la versión "web community" es porque tenía conexión a internet y así solo tenía que descargar 1.6MB frente a los 286,7MB de la versión off-line.

Es un MSI installer y te da un montón (o dos o tres o cuatro, pal caso es lo mismo) de opciones, pero solo usé la del Connector o lo que pusiera en las opciones de instalación.

 

Añadir la referencia de MySql.Data al proyecto

Una vez instalado, en el proyecto desde el que quieras acceder a la base de datos de MySQL le agregas la referencia correspondiente.
En mi caso usé la versión 4.5 ya que el proyecto también usaba el .NET Framework 4.5 (ver la figura 1).

MySqlData referencia
Figura 1. Referencia al ensamblado de MySql.Data versión 6.9.5

Y una vez que hemos agregado la referencia al ensamblado MySql.Data ya podemos acceder a las clases de conexión y demás, que están en el espacio de nombres MySql.Data.MySqlClient.

Y el resto… como de costumbre… pero no te preocupes te voy a poner el código (primero para VB y después para C#) de cómo usar la conexión y acceder a una tabla y demás, pero eso será… ¡ma-ña-na! 🙂

Bueno, vale, al menos te pondré el código de cómo conectar a la base de datos.

 

Conectar a la base de datos de MySQL desde Visual Basic .NET

Yo suelo usar un método en una clase con métodos compartidos (en VB puedes usar un módulo, pero yo uso una clase para después convertir fácilmente el código a C#), el método es una función llamada CadenaConexion que devuelve una cadena con la cadena de conexión generada por la clase ConnectionStringBuilder, en realidad la clase se llama MySqlConnectionStringBuilder, pero si has usado conexión a SQL Server sabrás que en ese caso el nombre es SqlConnectionStringBuilder.

Para poder acceder a las clases de MySql.Data debes añadir una importación de espacios de nombres a MySql.Data.MySqlClient:

' Para Visual Basic:
Imports MySql.Data.MySqlClient

// Para C#:
using MySql.Data.MySqlClient;

Y esta es la definición del método que está en una clase (class) de VB y por eso el método lo he definido como Shared (static en C#) para que lo puedas usar simplemente anteponiendo el nombre de la clase y sin necesidad de crear nuevas instancias ni nada de eso:

El código del método CadenaConexion para Visual Basic:

''' <summary>
''' La cadena de conexión a la base de datos
''' </summary>
Public Shared Function CadenaConexion() As String
    Dim csb As New MySqlConnectionStringBuilder
    csb.Server = "mysql3.servidoreswindows.net"
    csb.Database = "nombre_Base_Datos"
    csb.UserID = "nombre_usuario_de_la_base"
    csb.Password = "la_clave_del_usuario_de_la_base"
    csb.IntegratedSecurity = False

    Return csb.ConnectionString
End Function

El método CadenaConexion para C#:

/// <summary>
/// La cadena de conexión a la base de datos
/// </summary>
public static string CadenaConexion()
{
    MySqlConnectionStringBuilder csb = new MySqlConnectionStringBuilder();
    csb.Server = "mysql3.servidoreswindows.net";
    csb.Database = "nombre_Base_Datos";
    csb.UserID = "nombre_usuario_de_la_base";
    csb.Password = "la_clave_del_usuario_de_la_base";
    csb.IntegratedSecurity = false;

    return csb.ConnectionString;
}

 

Y esto es todo por hoy… mañana (seguramente)… más… 😉

 

Nos vemos.

Guillermo

Este artículo también está publicado en mi sitio:

http://www.elguille.info/NET/ADONET/MySQL_CadenaConexion.aspx

( En realidad obtiene el contenido desde aquí, de mi blog 🙂 )

Instalar SQL Server 2012 Management Studio Express

 

Pues eso… aunque esto mismo ya me pasó con la versión de SQL Server 2008 Express, volvemos a lo mismo… sobre todo por mi falta de memoria, y como sabía que tenía algo escrito en mi blog, lo he buscado, pero como en realidad era una de esas batallitas del agüelo y además la respuesta apuntaba a otro blog que ya no tiene esos pasos, pues… he decidido escribir esto y explicar los pasos a seguir para tener el Management Studio de SQL Server 2012 Express.

 

Nota:
Los pasos que te voy a explicar aquí seguramente serán los mismos para la versión 2008 de SQL Server Express

 

Estos links seguro que te pueden ser de utilidad:

 

La descarga del SQL Server Management Studio la puedes hacer de forma independiente del resto, de hecho cuando pulsas en el botón de descargar te muestra una ventana con estas opciones (ver figura 1, aunque la forma de seleccionar lo que quieres descargar puede ser diferente a lo mostrado en esa figura), con idea de que descargues sólo lo que necesites, ya que, por ejemplo, si tienes instalado el Visual Studio 2012 ya tendrás algunas cosas que no necesitas reinstalar.

 

descargas_sql_server_express_2012_01
Figura 1. Las opciones de descarga de SQL Server Express 2012

 

Si te sale el error de la figura 2, (a mí me ha salido), es posible que la instalación de SQL Server que ya tengas esté mal… o eso es lo que he encontrado buscando en los foros de Microsoft, aunque en ellos se refería a otras versiones diferentes a la EXPRESS y la recomendación es desinstalar SQL Server y volver a instalarlo… 🙁

 

sql_server_express_2012_management_studio_01
Figura 2. Error de que no existe SQLEXPRESS (el acuerdo de licencia)
(The SQL Server license agreement cannot be located for the selected edition, EXPRESS.)

 

El problema es que en la instalación que hay hecho el Visual Studio 2012 hay nosecuantamilcosas instaladas (ver figura 3) y… pues… si hay que ir desinstalando todas, no sé yo… :-/

 

sql_server_express_2012_03
Figura 3. Las cosas de SQL server 2012 instaladas en mi Windows 8

 

Pues NO, la solución (al menos en mi caso) ha sido descargar nuevamente el instalador, pero esta vez elegí la versión en inglés (las anteriores eran es español y puede que hubiese conflicto con lo que ya tengo instalado… la verdad es que no lo sé, pero al descargarlo de la página que te he indicado arriba (el primer enlace) y usando el idioma inglés, me ha funcionado o al menos ya no me da ese error (aún estoy instalando).

 

Una vez descargado el programa de instalación, debes proceder a la instalación y cuando lo pongas a funcionar te mostrará una pantalla como la de la figura 4.

 

sql_server_express_2012_management_studio_02
Figura 4. Las opciones de SQL Server Installation Center

 

Pulsa en la primera opción (como puedes comprobar lo tengo en inglés): New SQL Server stand-alone installation or add features to an existing installation que viene a significar: Nueva instalación o añadir características a una instalación existente.

Al pulsar en esa opción me ha salido una ventana para aceptar los términos de licencia (License Terms). Después de aceptarlos, me ha mostrado una ventana indicando que hay actualizaciones disponibles (ver la figura 5). En este caso es el SP1 de SQL Server 2012.

 

sql_server_express_2012_instalar_05
Figura 5. Product Updates

 

Me avisa de que necesitará reiniciar el equipo al finalizar la instalación, lo aceptamos y seguimos.

En la figura 6 vemos que están seleccionadas todas las opciones, pero hay algunas que no se pueden cambiar, supongo que serán de una instalación anterior.

 

sql_server_express_2012_instalar_06
Figura 6. Selección de características a instalar

 

Fíjate en la opción "Management Tools" esa es la que permite instalar, entre otras cosas, el Management Studio. Pulsamos en siguiente.

Ahora nos pregunta el nombre de la instancia (ver figura 7), dejamos los valores indicados.
(Es posible que estos pasos no los veas porque ya tengas esto instalado)

 

sql_server_express_2012_instalar_07
Figura 7. Instance Configuration

 

Pulsamos en siguiente y nos pide que configuremos el servidor (figura 8), yo lo he dejado como está. Pulsa en Siguiente.

 

sql_server_express_2012_instalar_08
Figura 8. Server Configuration

 

En el siguiente paso (ver figura 9) nos pide que configuremos el motor de bases de datos, principalmente la configuración del servidor, con idea de saber cómo nos "autenticaremos", yo he elegido el modo mixto (por defecto está la autenticación de Windows). Ahí indica el password (contraseña) del administrador de SQL Server (sa) además de que puedes añadir algún otro usuario de Windows.

 

sql_server_express_2012_instalar_09
Figura 9. Database Engine Configuration > Server Configuration

 

Después de indicar la clave (no lo dejes en blanco, porque seguramente no te lo permitirá) le he dado a siguiente dejando los valores predeterminados de las otras pestañas.

El siguiente paso es indicar los reportes de error (Error Reporting) a mandar a Microsoft, selecciona lo que quieras o te muestre (si quieres) y pulsa en siguiente.

Ya no tienes que hacer nada más, salvo esperar a que se instalen las cosas y te pida reiniciar el equipo (figura 10).

 

sql_server_express_2012_instalar_10
Figura 10. Complete > Computer restart required

 

Pulsa en OK (aceptar) y después tendrás que cerrar la ventana del instalador de SQL Server 2012 y la de la configuración.

A mí no me ha pedido reiniciar, pero… las costumbres son las costumbres y yo después de instalar cosas como estas, si no se reinicia, lo reinicio yo 😉

 

 

Después de reiniciar… ya está funcionando el SQL Server Management Studio 2012.

 

Nota:
Si quieres añadir nuevas características a la instalación de SQL Server 2012 Express, si abres el SQL Server Installation Center (desde el acceso que te crea la instalación) te mostrará algo parecido a lo mostrado en la figura 4, pero con más opciones, pero si eliges la primera opción te pedirá que indiques el directorio de instalación… en mi caso, lo ha eliminado después de hacer la instalación, así que… supongo que habrá que usar nuevamente el instalador y agregar lo que necesitemos…

 

 

Espero que te sea de utilidad.

 

Nos vemos.
Guillermo

El número de decimales del tipo decimal de SQL Server

Pues eso… últimamente estoy «trasteando» en un programa (hecho con Visual Basic 2010) que accede a una base de datos de SQL Server Express 2005 y quisiera ir poniendo por aquí las cosillas que me voy encontrando mientras «tecleo» en ese programa, y lo último que he modificado es esto que te muestro, que no es que no lo hubiera detectado antes, pero haciendo pruebas hoy he visto que me había dejado «sin optimizar» un campo de una de las tablas.

El tema es el siguiente:

Cuando añades un campo a una tabla de SQL Server (en mi caso con el SQL Server Management Studio 2008 (Express)) y le indicas que es de tipo decimal, automáticamente te lo pone de esta forma:

decimal(18, 0)

El 18 es la precisión, o número de dígitos que puede tener este número, y el 0 es la «escala» o número de decimales que puede tener este número.

Como verás cero decimales no es algo que sea demasiado aceptable en valores de tipo moneda, que sí, que podía haber elegido el tipo «money» y me hubiese quitado de problemas, pero de haberlo hecho no te estaría contando esto y… puede que un día te diera por usar el tipo «decimal» por aquello de que es el más parecido al tipo «moneda» que tiene el punto net y lo mismo te preguntarías por qué narices me redondea el número cuando lo guarda en la base de datos… sí, podría ocurrirte esto… como le ocurrió a uno que me conozco…

La cuestión es que si quieres usar el tipo «decimal» de SQL Server para que acepte un número de decimales (por ejemplo cuatro decimales) tendrías que declararlo de esta otra forma:

decimal(18, 4)

 

Y debido a que a la hora de usar este valor desde la base de datos el número de dígitos decimales siempre se guarda (aunque sean todos ceros), me he creado una función que recibe un valor de tipo Object y lo convierte en cadena (String), pero quitando los ceros extras que tenga y en el caso de que el valor «total» sea cero, al menos deje un cero (pero siempre que esté a la izquierda del decimal).

 

Esta función para quitar los ceros extras que añade el SQL Server:

''' <summary>
''' Convierte un tipo Object en un valor Decimal,
''' pero se devuelve como cadena.
''' Ese objeto es el valor leído de la base de datos
''' Si el contenido es válido se devuelve el valor
''' si no, se devuelve una cadena vacía.
''' Se quitan los ceros que haya después del signo decimal,
''' si no tiene decimales, no se muestran los ceros.
''' </summary>
Friend Function dataDecimal(ByVal obj As Object) As String
    If obj Is Nothing OrElse obj.Equals(DBNull.Value) Then
        Return ""
    Else
        ' Conversión extra para evitar "sustos"                 (06/Oct/11)
        Dim d As Decimal = 0
        Decimal.TryParse(obj.ToString, d)
        Return d.ToString.TrimEnd("0"c).TrimEnd({"."c, ","c})

        'Return CDec(obj).ToString.TrimEnd("0"c).TrimEnd({"."c, ","c})

    End If
End Function

 

Como ves, no me fio de que el valor recibido sea un valor decimal válido, por eso hago algunas comprobaciones.

La primera es saber si el valor pasado como argumento a la función es un valor nulo, ya sea «nulo de punto net» o nulo de base de datos (DBNull.Value), en ese caso, la función devuelve una cadena vacía.

La segunda es usar TryParse para no producir una excepción (o error) en el caso de que el valor de ese objeto no sea «convertible» a un tipo Decimal.

La función TryParse recibe un valor de tipo cadena que será el valor a convertir (en este caso a un tipo Decimal) y en el segundo parámetro le indicamos un valor (por referencia) del mismo tipo al que queremos convertir, de forma que si la conversión falla, se utilice el valor que previamente tenga dicha variable.

En el caso de que la conversión NO falle, se asignará a la variable de ese segundo argumento el valor que de como resultado la conversión. Por eso debe ser por referencia, para que la variable se pueda modificar dentro de la función.

 

Como queremos quitar todos los ceros que «sobren» por el final, utilizo la función TrimEnd al valor convertido (el que tiene la variable d) indicándole el carácter que quiero quitar, esa función recibe como parámetro un valor de tipo Char indicando qué carácter queremos quitar del final, y como Visual Basic permite indicar los caracteres en la forma «cadena» seguida de la letra c, pues… eso es lo que he hecho, por tanto «0»c significa que es el carácter CERO (o valor 48).

Esto seguramente ya lo sabías, pero… no está de más una aclaración.

 

Si el valor almacenado en la base de datos no tiene decimales (por ejemplo el número 205) con el TrimEnd que hemos hecho se nos quedaría la coma (o el punto) que indica que hay decimales, por tanto volvemos a hacer un TrimEnd al resultado del TrimEnd anterior, pero en este caso queremos quitar tanto las comas como los puntos, es decir, queremos quitar «dos tipos de caracteres», en estos casos, la función TrimEnd permite indicar un array (o arreglo o matriz) de caracteres con cada uno de los caracteres a quitar del final de la cadena.

Los caracteres individuales ya sabes cómo indicarlos, y si lo que quieres indicar es un array, esos caracteres individuales los separas con comas y los incluyes entre llaves: {«.»c, «,»c}.

 

Y esto es todo.

 

Sólo me queda decirte cómo lo utilizo:

En mi caso (en este programa que estoy haciendo) lo hago de dos formas:

En una leo el valor de la tabla en un DataTable y accedo a cada valor por medio de un objeto que representa a la fila (DataRow) a la que estoy accediendo:

 

For Each r As DataRow In dt.Rows
    Dim lvi As New ListViewItem

...

lvi.SubItems.Add(dataDecimal(r("Importe")))

...

 

En la otra accedo a los valores por medio de un objeto SqlDataReader y básicamente hago lo mismo:

 

Dim re As SqlDataReader = cmd.ExecuteReader()

...

ImporteTextBox.Text = dataDecimal(re("Importe"))

...

 

Espero que te sea de utilidad.

 

Nos vemos.
Guillermo

P.S. (08/Dic/18)
Creo que esto también te interesará:
Error al guardar datos decimales: El valor del parámetro ‘xxx’ está fuera del intervalo

Instalar SQL Server Express 2008 Management Studio… con lo fácil que es hacer las cosas simples…

… se complican la vida más de la cuenta… si es que… en fin…

Pues eso… que tenía que modificar unas cosillas en la base de datos de usuarios de mis foros y esas cosas siempre las he hecho con el Management Studio (el entorno integrado de SQL Server), de ese administrador existe una versión para la edición Express de SQL Server (SSMSE), así que… busco en internet, lo localizo y me lo descargo (tanto en inglés como en español) desde esta página.

Al ejecutar el .exe que me bajo, el Windows 7 me dice que hay problemas conocidos con ese programa y que lo solucione antes, pulso en el botón ese que te muestra en el aviso y me dice (después de un buen rato) que hay una solución al problema, el link me lleva a la página de descarga de Microsoft® SQL Server® 2008 Express Edition Service Pack 1, por tanto, voy a esa página y me lo bajo por si las moscas, antes había intentado instalar el SP1 directamente, pero nones, además me dio problemas también a la hora de instalar, desapareciendo el instalador (sin avisar) y funcionando al ejecutarlo por segunda vez.

Si te preguntas por qué no me bastó con las instalación del SP1, decirte que instalé el SQL Server 2008 Express con el SP1 porque no estaba seguro de tenerlo instalado, ya que el Visual Studio 2008 lo que instala es el SQL Server 2005 Express.

Una vez instalado todo esto, que por cierto, vaya peñazo de instalador… sí, un rollo, pero bueno… no es ese el problema, el problema es que… ¡no veo por ningún lado cómo instalar el Management Studio Express! llámame torpe, porque seguramente lo seré, pero… ¡no veo cómo instalar el dichoso IDE del SQL Express!

El SQL Server Installation Center (que es el programilla que usa el instalador) es mu bonico, con muchas cosas y mu majas todas ellas, pero no veo dónde está la opción para instalar el Management Studio… no… ¿será porque está en inglés?
En fin… voy a probar a instalar el SQL Server Express 2008 with Advanced Services a ver si así la cosa va mejor (es que el SQL Server 2008 Express with advanced services incluye el management studio).

Como tengo la versión en español, he usado esa aunque creo que no tiene el SP1, lo digo porque la que yo tengo no es la que está en la URL que te he puesto arriba, ya que el nombre del ejecutable que yo tengo es: es_sql_server_2008_express_with_advanced_services_x86.exe.

Me dice que hay issues de compatibility, vamos que instale el SP1 en cuanto pueda… le digo que lo instale (Run program), total…

Nada, el mismo programilla de opciones de configuración… tendré que desistalar el SQL Server 2008 Setup Support Files a ver si… (ahora vuelvo)

Na, me dice que de esos ficheros dependen más cosas (ver la figura 1), así que… o lo quito todo o lo dejo como está y me instalo el Management Studio de la versión 2005 que seguro que funciona… y como no tengo bases de datos de la versión 2008, pues… no creo que tenga problemas…

Figura 1. Dependencias entre las cosas instaladas

Algo así es como debería haber sido para la versión 2008… (ver figura 2)

Figura 2. Instalar el Management Studio 2005

Lo mismo después de que reinicie, (porque reiniciaré el equipo), lo probaré de nuevo a ver…

En cualquier caso, el Management Studio 2005 SP2 se ha instalado correctamente, funciona a las mil maravillas y he podido hacer lo que quería hacer… y de paso he agregado algunas de las bases de datos para pruebas que tengo y que aún no había puesto a funcionar… por cierto, tengo que crear también la de Northwind y pubs que uso en los ejemplos de las charlas…

Nos vemos.
Guillermo
http://www.elguille.info/

(este post lo publiqué originalmente en elguillemola.blogspot.com)