Utilizamos cookies propias y de terceros. [Más información sobre las cookies].
Política de cookies
Proyecto AjpdSoft

· Inicio
· Buscar
· Contactar
· Cookies
· Descargas
· Foros
· Historia
· Nosotros
· Temas
· Top 10
· Trucos
· Tutoriales
· Wiki
Proyecto AjpdSoft: Foros

AjpdSoft :: Ver tema - Error Unable convert MySQL date System.Date C#
Foros de discusión Buscar Perfil FAQ Iniciar sesión
Information Error Unable convert MySQL date System.Date C#

Publicar nuevo tema Responder al tema
Foros de discusión » VB.Net, C# .Net, Visual Studio .Net   
Ver tema anterior :: Ver tema siguiente
AutorMensaje
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Error Unable convert MySQL date System.Date C# Responder citando

Estoy desarrollando una aplicación con Visual Studio .Net 2010, en concreto con Visual C# (CSharp), la aplicación conecta con un servidor de bases de datos MySQL Server 5, realizo la conexión mediante ADO.NET Driver for MySQL (Connector/NET), todos los select SQL que realizo me funcionan bien, pero algunos con campos de tipo datetime en la tabla MySQL me muestran este error:

Unable to convert MySQL date/time value to System.DateTime

¿A qué puede ser debido?

Para la conexión de C# con MySQL usando ADO.NET he seguido las instrucciones de vuestro tutorial:

http://www.ajpdsoft.com/modules.php?name=News&file=article&sid=629
MensajePublicado:
Dom Dic 02, 2012 11:51 am
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Error Unable convert MySQL date System.Date C# Responder citando



Anuncios



varios escribió:
Estoy desarrollando una aplicación con Visual Studio .Net 2010, en concreto con Visual C# (CSharp), la aplicación conecta con un servidor de bases de datos MySQL Server 5, realizo la conexión mediante ADO.NET Driver for MySQL (Connector/NET), todos los select SQL que realizo me funcionan bien, pero algunos con campos de tipo datetime en la tabla MySQL me muestran este error:

Unable to convert MySQL date/time value to System.DateTime

¿A qué puede ser debido?

Para la conexión de C# con MySQL usando ADO.NET he seguido las instrucciones de vuestro tutorial:

http://www.ajpdsoft.com/modules.php?name=News&file=article&sid=629



¿Qué string de conexión usas para el MySqlConnection de C# con MySQL?
MensajePublicado:
Dom Dic 02, 2012 11:58 am
Top of PageVer perfil de usuario
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Re: Error Unable convert MySQL date System.Date C# Responder citando



Anuncios



alonsojpd escribió:
¿Qué string de conexión usas para el MySqlConnection de C# con MySQL?


Utilizo:

Código:

  MySqlConnection conexionBD;
  string connStr =
      String.Format("server={0};user id={1}; password={2}; database=mysql; pooling=false",
                txtServidor.Text, txtUsuario.Text, txtContrasena.Text);
  try
  {
    conexionBD = new MySqlConnection(connStr);
    conexionBD.Open();
  }
  catch (MySqlException ex)
  {
    MessageBox.Show("Error al conectar al servidor de MySQL: " + ex.Message,
        "Error al conectar", MessageBoxButtons.OK, MessageBoxIcon.Error);
  }
MensajePublicado:
Dom Dic 02, 2012 12:02 pm
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Error Unable convert MySQL date System.Date C# Responder citando



Anuncios



varios escribió:
Utilizo:

Código:

  MySqlConnection conexionBD;
  string connStr =
      String.Format("server={0};user id={1}; password={2}; database=mysql; pooling=false",
                txtServidor.Text, txtUsuario.Text, txtContrasena.Text);
  try
  {
    conexionBD = new MySqlConnection(connStr);
    conexionBD.Open();
  }
  catch (MySqlException ex)
  {
    MessageBox.Show("Error al conectar al servidor de MySQL: " + ex.Message,
        "Error al conectar", MessageBoxButtons.OK, MessageBoxIcon.Error);
  }


Prueba a cambiar:


Código:

  string connStr =
      String.Format("server={0};user id={1}; password={2}; database=mysql; pooling=false",
                txtServidor.Text, txtUsuario.Text, txtContrasena.Text);


Por:

Código:

  string connStr =
      String.Format("server={0};user id={1}; password={2}; database=mysql; pooling=false;Allow Zero Datetime=True;Convert Zero Datetime=True",
      txtServidor.Text, txtUsuario.Text, txtContrasena.Text);


El error se debe al tratamiento de las fechas "vacías" de MySQL.
MensajePublicado:
Dom Dic 02, 2012 12:10 pm
Top of PageVer perfil de usuario
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Re: Error Unable convert MySQL date System.Date C# Responder citando



Anuncios



alonsojpd escribió:

Prueba a cambiar:


Código:

  string connStr =
      String.Format("server={0};user id={1}; password={2}; database=mysql; pooling=false",
                txtServidor.Text, txtUsuario.Text, txtContrasena.Text);


Por:

Código:

  string connStr =
      String.Format("server={0};user id={1}; password={2}; database=mysql; pooling=false;Allow Zero Datetime=True;Convert Zero Datetime=True",
      txtServidor.Text, txtUsuario.Text, txtContrasena.Text);


El error se debe al tratamiento de las fechas "vacías" de MySQL.


He cambiado lo que has dicho en el código C# y ahora se produce este error:

El tipo de valor no coincide con el tipo de columna. No se puede almacenar <01/01/0001 0:00:00> en la columna hora. El tipo esperado es MySqlDateTime.
MensajePublicado:
Dom Dic 02, 2012 12:18 pm
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Error Unable convert MySQL date System.Date C# Responder citando



Anuncios



varios escribió:
He cambiado lo que has dicho en el código C# y ahora se produce este error:

El tipo de valor no coincide con el tipo de columna. No se puede almacenar <01/01/0001 0:00:00> en la columna hora. El tipo esperado es MySqlDateTime.


Cambia el valor de "Allow Zero Datetime=True" por "Allow Zero Datetime=False" y prueba.
MensajePublicado:
Dom Dic 02, 2012 12:22 pm
Top of PageVer perfil de usuario
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: [RESUELTO] Error Unable convert MySQL date System.Date C# Responder citando



Anuncios



alonsojpd escribió:
varios escribió:
He cambiado lo que has dicho en el código C# y ahora se produce este error:

El tipo de valor no coincide con el tipo de columna. No se puede almacenar <01/01/0001 0:00:00> en la columna hora. El tipo esperado es MySqlDateTime.


Cambia el valor de "Allow Zero Datetime=True" por "Allow Zero Datetime=False" y prueba.


Muchísimas gracias!!!! ahora sí me funciona perfectamente.
MensajePublicado:
Dom Dic 02, 2012 12:25 pm
Top of PageVer perfil de usuario
Mostrar mensajes de anteriores:   
Todas las horas son GMT - 1 Horas
Publicar nuevo tema Responder al tema
Foros de discusión » VB.Net, C# .Net, Visual Studio .Net  

Cambiar a:  
Key
  Puede publicar nuevos temas en este foro
No puede responder a temas en este foro
No puede editar sus mensajes en este foro
No puede borrar sus mensajes en este foro
No puede votar en encuestas en este foro
Visita nuestro nuevo sitio web con programas y contenidos actualizados: Proyecto A