Ver Mensaje Individual
  #1  
Antiguo 27-02-2018
NeWsP NeWsP is offline
Miembro
 
Registrado: oct 2003
Ubicación: Barcelona
Posts: 57
Reputación: 21
NeWsP Va por buen camino
Unhappy Problema generando Json

Buenos dias, estoy intentando generar un JSON con el siguiente formato:

Código:
{
    "result": [
        {
            "Lineas": [
                {
                    "Id": "8",
                    "codigo": "T00001",
                    "fecha": "26/02/2018 12:53:28",
                    "operacion": "Añadir",
                    "cantidad": "200",
                    "total": "400"
                },
                {
                    "Id": "8",
                    "codigo": "T00001",
                    "fecha": "26/02/2018 12:53:28",
                    "operacion": "Añadir",
                    "cantidad": "200",
                    "total": "400"
                },
                {
                    "Id": "8",
                    "codigo": "T00001",
                    "fecha": "26/02/2018 12:53:28",
                    "operacion": "Añadir",
                    "cantidad": "200",
                    "total": "400"
                }
            ]
        }
    ]
}
El problema que tengo es que si miro el Json como se genera con el PostMan en RAW se me forma este json:

Código:
{
	"result": [{
		"Lineas": [{
			"Id": "2",
			"codigo": "T00001",
			"fecha": "15\/02\/2018 12:50:47",
			"operacion": "A\u00F1adir",
			"cantidad": "0",
			"total": "0",
			"Id": "7",
			"codigo": "T00001",
			"fecha": "26\/02\/2018 12:53:04",
			"operacion": "A\u00F1adir",
			"cantidad": "200",
			"total": "200",
			"Id": "8",
			"codigo": "T00001",
			"fecha": "26\/02\/2018 12:53:28",
			"operacion": "A\u00F1adir",
			"cantidad": "200",
			"total": "400"
		}, {
			"Id": "2",
			"codigo": "T00001",
			"fecha": "15\/02\/2018 12:50:47",
			"operacion": "A\u00F1adir",
			"cantidad": "0",
			"total": "0",
			"Id": "7",
			"codigo": "T00001",
			"fecha": "26\/02\/2018 12:53:04",
			"operacion": "A\u00F1adir",
			"cantidad": "200",
			"total": "200",
			"Id": "8",
			"codigo": "T00001",
			"fecha": "26\/02\/2018 12:53:28",
			"operacion": "A\u00F1adir",
			"cantidad": "200",
			"total": "400"
		}, {
			"Id": "2",
			"codigo": "T00001",
			"fecha": "15\/02\/2018 12:50:47",
			"operacion": "A\u00F1adir",
			"cantidad": "0",
			"total": "0",
			"Id": "7",
			"codigo": "T00001",
			"fecha": "26\/02\/2018 12:53:04",
			"operacion": "A\u00F1adir",
			"cantidad": "200",
			"total": "200",
			"Id": "8",
			"codigo": "T00001",
			"fecha": "26\/02\/2018 12:53:28",
			"operacion": "A\u00F1adir",
			"cantidad": "200",
			"total": "400"
		}]
	}]
}
En la base de datos tengo 3 registros para ese codigo, pero en el Json final, me repite 3 veces el mismo registro, y en el Json en RAW me repite 3 veces los 3 registros, pero me mete los 3 registros cada uno en un array distinto.

Ahora pongo el codigo:
Código Delphi [-]
 With FormUnit1.Form1.QueHistoria do
  begin
    sql.Clear;
    sql.Add('SELECT * FROM historial WHERE codigo=:referencia');
    parambyname('referencia').Value:=referencia;
    execsql;
  end;

  Array_lineas:=TJsonArray.Create;
  Result:=TJsonObject.Create;
  obj_linea:=TJsonObject.Create;

  FormUnit1.Form1.QueHistoria.first;
  Result.AddPair(TJsonPair.Create('Lineas',Array_lineas));

   while (not FormUnit1.Form1.QueHistoria.EOF) do
      begin

            for I := 0 to FormUnit1.Form1.QueHistoria.FieldDefs.Count-1 do
            begin
              CollumnName  := FormUnit1.Form1.QueHistoria.FieldDefs[i].Name;
              Obj_Linea.AddPair(CollumnName,FormUnit1.form1.QueHistoria.Fields[i].Value);
              arr:=i;
            end;
            array_lineas.Add(obj_linea);
            FormUnit1.Form1.QueHistoria.next;

     end;

- Si creo distintos TJsonObject y los meto en el array_lineas funciona correctamente, pero no creo que sea la solucion, y tampoco consigo crearlos en ejecución.
- Si meto los datos en el TJsonObject, los añado al array, destruyo el TJsonObject, y lo vuelvo a crear, el resultado me sale con las llaves que necesito pero sin datos.

He estado mirando varios post del foro, pero no he encontrado ninguna solución, parte del codigo de un ejemplo sacado de una función en la que se habló en este post: https://www.clubdelphi.com/foros/showthread.php?t=88282

Si tuviera que cambiar el aspecto del json o algo, supongo que podria adaptarme, pero si puede ser ese formato mejor.

Muchas gracias, y espero que me podais echar un cable.
Saludos

Última edición por dec fecha: 27-02-2018 a las 10:48:30.
Responder Con Cita