Menú

Mostrar Mensajes

Esta sección te permite ver todos los mensajes escritos por este usuario. Ten en cuenta que sólo puedes ver los mensajes escritos en zonas a las que tienes acceso en este momento.

Mostrar Mensajes Menú

Mensajes - dr4

#1
Muy buenas, espero conseguir explicar mi problema porque ya van 2 días trabajando con esto y no consigo entenderlo:



tengo un dataset que recoge los datos de una base de datos, ese dataset lo convierto en un datatable y se lo paso a un gridview



pass = pasarTabla1.Tables[0];



dataListado.DataSource = OShare.pass;





bien, ahora según entiendo ahí creo una conexión entre los dos ¿no? si cambio algo en el datagridview pasarTabla1 recibira el cambio y si cambio algo en pasarTabla1 el datagridview recibe el cambio aunque yo no ponga nada por ningún lado (al menos es lo que yo entiendo que está ocurriendo ya que solo le asigno "pasarTabla1" a "Pass" al principio pero cada vez que algo cambia este cambia en mi datagridview).







después necesito agregar a esa base de datos cosas de otra base de datos, probé a usar ".merge" pero lo único que consigo es que se agregue todo lo de la segunda base de datos a la primera de manera infinita cada vez que le doy al botón, se supone que es porque el número de columnas de la segunda tabla no coincide con el de la primera, así que probe a hacer esto:





DataSet copy = new DataSet();          
copy = pasarTabla1;      
     copy.Merge(pasarTabla2, false, MissingSchemaAction.Ignore);          

copy.AcceptChanges();    
       pasarTabla1.Merge(copy,false);







primero comparo copy con pasarTabla2 que es la que tiene los datos que quiero agregar, (en ese punto se agregan los datos directamente a mi datagridview y no entiendo porqué ya que según había entendido datagridview estaba conectado con pasarTabla1 y eso es una copia!), después aprovechando que ahora copy y pasarTabla1 tienen el mismo formato los vuelvo a comparar para descartar las  igualdades pero lejos de darme las diferencias solo me agrega a la tabla lo que tiene "pasarTabla2" esté repetido o no, y una vez mas no consigo entender porqué , os pongo unas imaganes:

ya he cogido los datos de la segunda base de datos y la he guardado en la primera(son los 4 ultimos):



http://s23.postimg.org/vzkb3yk0b/image.jpg



si le vuelvo a dar al boton ese merge me devuelve solo los datos de la segunda tabla, estén ya en la primera o no, y lo hace de manera infinita:



http://s18.postimg.org/q1ynm2c9l/image.jpg





y al hacer el update de la base de datos esta intenta actualizar TODOS los datos (incluidos los que están repetidos varias veces, me guarda los que no,pero es un proceso lento en el que pierde el tiempo tratando de meter muchos datos que ya tiene)



try      {     cmdBuilder = new SqlCommandBuilder(adapter);      

                 cmdBuilder.GetUpdateCommand();                

      changes = ds.GetChanges();                    

  if (changes != null)                        {  

                        try                          

 {                                adapter.ContinueUpdateOnError = true;

                              adapter.Update(changes);                

              Console.WriteLine("Changes DoOoOoOoOoOoOoOOOOOOOOOOOOOOOOOOOOOOOONE");  

                        }                            catch (Exception ex)                            {

                              Console.WriteLine(ex.ToString());                            }                        }                    }                    catch (Exception ex)                    {                                   }






ya no sé que mas hacer,llevo 2 días rompiendome la cabeza con esto y he llegado a la tercera pagina de google, espero que alguien pueda ayudarme a entender y solucionarlo
#2
Buenas chavales, he hecho un programa con una base de datos en sql server, a través del cual se puede actualizar el contenido de la base de datos añadiendo o modificando lo que ya tiene,el problema es que me gustaría que mi programa funcionará en cualquier base de datos.Tal y como lo tengo ahora he predefinido las variables tanto en el servidor como en el programa así que solo podré manipular una base de datos que tenga esas variables.

¿Hay alguna manera de leer la base de datos y crear sus respectivas variables en el programa automaticamente? ni siquiera sé si es posible
#3
Muy buenas! tengo una cosa que me está dando mucho quebradero de cabeza, os comento:

Tengo un programilla en visual studio funcionando que coge datos de 2 bases de datos,las convierte en archivos en xml,las compara y por ultimo las sincroniza, funciona perfectamente pero ahora quisiera hacer lo mismo pero sin crear ningún archivo, que todo el proceso ocurra internamente en el programa, os paso el código que tengo del programa funcionando (del método que hace todo el proceso de xml), y el código del nuevo, el problema ahora mismo me salta a la hora de comparar los dos strings y no descarto que lo que viene luego tampoco vaya a funcionar:



PROGRAMA FUNCIONANDO:

Código (csharp) [Seleccionar]



   


       public static void CompareXml()
       {


           XmlWriter writexml;

           

               writexml = XmlWriter.Create("C:\\sharecompare.xml");
           

           string xmlString1 = "C:\\share2Copy.xml";
           string xmlString2 = "C:\\share1.xml";
           string xmlString3 = "C:\\sharecomparefinal.xml";
           string xmlString4 = "C:\\sharecompare.xml";
           

           
           XmlDiff xmldiff = new XmlDiff(XmlDiffOptions.IgnoreChildOrder |
                                            XmlDiffOptions.IgnoreNamespaces |
                                            XmlDiffOptions.IgnorePrefixes);
           bool bIdentical = xmldiff.Compare(xmlString2, xmlString1, false, writexml);


           writexml.Close();

           FileStream patchedFile = new FileStream(xmlString3, FileMode.Create, FileAccess.Write);

           XmlPatch xmlPatch = new XmlPatch();


           try
           {
             //  XmlTextReader diffgramReader = new XmlTextReader("C:\\sharecompare.xml");
              // xmlpatch.Patch(sourceDoc, diffgramReader);
               xmlPatch.Patch(new XmlTextReader(xmlString2), patchedFile, new XmlTextReader(xmlString4));
               
             
           }
           catch (Exception ex)
           {
               Console.WriteLine("HA habido un ERROR: "+ex.Message);
               
           }

           patchedFile.Close();
           Console.WriteLine("The patched document or fragment has been saved to " + xmlString3);

       }

     







INTENTO CONVERTIRLO EN UN PROGRAMA QUE FUNCIONE SIN CREAR ARCHIVOS. xml1 y xml2 son strings y cogen bien el xml de las bases de datos,el problema viene a la hora de intentar comparar los dos strings y sacar un tercer string con el resultado en formato xml:




Código (csharp) [Seleccionar]

public static void CompareXml()
       {
           DShare Obj=new DShare();

           XmlWriter writexml;

           StringWriter sw = new StringWriter();
           
         
         

           writexml = XmlWriter.Create(sw);


           string xmlString1 = Obj.Xml2;
           string xmlString2 = Obj.Xml1;
           string xmlString3 = Obj.Xmlfinal;
           string xmlString4 = sw.ToString();
         

           string str = sw.ToString();//

         

           XmlDiff xmldiff = new XmlDiff(XmlDiffOptions.IgnoreChildOrder |
                                            XmlDiffOptions.IgnoreNamespaces |
                                            XmlDiffOptions.IgnorePrefixes);
           bool bIdentical = xmldiff.Compare(xmlString2, xmlString1, false, writexml);


           writexml.Close();

           MemoryStream ms = new MemoryStream(System.Text.Encoding.ASCII.GetBytes(xmlString3));
           //FileStream patchedFile = new FileStream(xmlString3, FileMode.Create, FileAccess.Write);

           XmlPatch xmlPatch = new XmlPatch();


           try
           {
               //  XmlTextReader diffgramReader = new XmlTextReader("C:\\sharecompare.xml");
               // xmlpatch.Patch(sourceDoc, diffgramReader);
               xmlPatch.Patch(new XmlTextReader(xmlString2), ms, new XmlTextReader(xmlString4));


           }
           catch (Exception ex)
           {
               Console.WriteLine("HA habido un ERROR: " + ex.Message);

           }

           ms.Close();
          // patchedFile.Close();

           Console.WriteLine("The patched document or fragment has been saved to " + xmlString3);
       }