Double C# y Double SQLITE (Separadores con Punto y Coma)

Iniciado por MauroMasciar, 6 Diciembre 2017, 18:13 PM

0 Miembros y 1 Visitante están viendo este tema.

MauroMasciar

Hola, quería pedir ayuda con este código.
Resulta que tengo una base de datos SQLite, en la cual guardo varios valores de tipo DOUBLE
Cuando yo inserto un dato mediante un cuadro de texto, tengo que poner el valor con coma para que lo guarde correctamente en la tabla, así lo hago.
El tema es cuando quiero recuperar ese dato, lo hago de la siguiente manera:

Código (csharp) [Seleccionar]

         public double Obtener_Horas_Aeronave(string ICAO) {
            double Horas = 0;
            conn.Open();
            string query = "select horas from aeronaves where icao = '" + ICAO + "'";
            try {
                SQLiteCommand command = new SQLiteCommand(query, conn);
                SQLiteDataReader dr = command.ExecuteReader();
                dr.Read();
                Horas = dr.GetDouble(0);
                dr.Close();
            } catch (SQLiteException ex) {
                System.Windows.Forms.MessageBox.Show(ex.ToString());
            }
            conn.Close();
            return Horas;
        }


Pero salta la excepción:
Excepción no controlada del tipo 'System.InvalidCastException' en System.Data.SQLite.dll
La conversión especificada no es válida.


Ahora, si entro a la base de datos y cambio por ejemplo "1,09" por "1.09", ahí lo lee y lo devuelve bien, lo devuelve como "1,09"
En la tabla, si esta separado con punto, lo devuelve, si es separado con coma, salta la excepción, pero al guardar solo lo guarda con coma, asi que puedo guardarlo pero no puedo recuperarlo.
¿Que estaré haciendo mal o que me faltará?

Gracias.
Tutto ha oceani da attraversare mentre hanno il coraggio di farlo Avventato? Ma sanno sogni di limiti

Twitter: @MauroMasciar

Eleкtro

#1
El problema parece ser evidente, parece ser un problema de lozalización/cultura del separador de decimales, debido a que la función SqliteDataReader.GetDouble() no es capaz de interpretar el separador de decimales coma (,) como un separador válido, y entonces genera una excepción por ese motivo... por que determina que el formato de la expresión no es válido al encontrar una coma en el string, en lugar de un punto.

Practicamente no domino nada el manejo con SQL, así que probablemente habrá una mejor solución (más directa) para esto, como por ejemplo podría ser que buscases el modo de formatear correctamente el separador de decimales al momento de generar la entrada en la tabla, pero me atrevería a decir que este otro tipo de solución podría funcionarte igual:

Código (csharp) [Seleccionar]
// ...
string str = dr.GetString(0);
double value;

if (str.Contains(",")) {
   double.TryParse(str, NumberStyles.Float, CultureInfo.GetCultureInfo("es-ES"), out value);

} else if (str.Contains(".")) {
   double.TryParse(str, NumberStyles.Float, CultureInfo.GetCultureInfo("en-US"), out value);

} else {
   double.TryParse(str, NumberStyles.Float, CultureInfo.InvariantCulture, out value);

}

if (value != 0) {
   Horas = value;

} else {
   throw new InvalidCastException();

}
// ...


Saludos.








MauroMasciar

Si, ese es el problema justamente. Convertir ese separador.
Este programa ya lo hice en Java y quería una versión en C#, y de repente salen estos fallos raros en cosas tan simples...
Tu solución lamentablemente no sirve, el tipo en la tabla es Double y no puedo obtener un String. Y pasarlo a String y convertirlo cada vez que tenga que usarlo debe ser algo engorroso, ya que ademas de recuperarlo, tengo que hacer operaciones y guardar el nuevo valor. Aparte de que la mayoría de los datos de la tabla es de tipo Double.
Estaba leyendo también que a las consultas en C# con SQLite había que hacerla por parámetros y convertirlos desde allí, ya que lo mismo pasa con Datetime.

Gracias por tomarte el tiempo de contestarme y escribir ese código.
Seguiré investigando a ver que encuentro.
Tutto ha oceani da attraversare mentre hanno il coraggio di farlo Avventato? Ma sanno sogni di limiti

Twitter: @MauroMasciar

Maurice_Lupin

Hola MauroMasciar, si el problema es el separador de decimales, puedes cambiarlo a tus necesidades.

En el FormMainLoad
Código (vbnet) [Seleccionar]

' requiere Imports System.Threading
Dim culInfo As CultureInfo
culInfo = New Globalization.CultureInfo("es-ES")
culInfo.NumberFormat.NumberDecimalSeparator = "."
culInfo.NumberFormat.CurrencyDecimalSeparator = "."
culInfo.NumberFormat.PercentDecimalSeparator = "."
culInfo.NumberFormat.CurrencyDecimalSeparator = "."
System.Threading.Thread.CurrentThread.CurrentCulture = culInfo


Saludos.
Un error se comete al equivocarse.