AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Datein in MS SQL speichern

Ein Thema von Andidreas · begonnen am 12. Sep 2013 · letzter Beitrag vom 13. Sep 2013
Antwort Antwort
Seite 2 von 2     12   
Furtbichler
(Gast)

n/a Beiträge
 
#11

AW: Datein in MS SQL speichern

  Alt 12. Sep 2013, 15:40
Der unterschied zwischen varchar und char ist nur das der String nicht mit leerzeichen gefüllt wird.
Das hier funktioniert aber:
Code:
create table foo(
   bar varchar(5000),
   bar1 varchar(5000),
   bar2 varchar(5000)
)
insert into foo select '1','2','3'
Der Unterschied zwischen CHAR und VARCHAR ist intern zudem viel großer, als nur die paar Leerzeichen.

Ich hab leider noch kein Beispiel gefunden das mir verständlich erklärt wie ich eine Datei in die MS SQL Spalte bekommen...
Google 2.Ergebnis

http://delphi.longzu.net/viewthread....xtra=page%3D58

Geändert von MrSpock (12. Sep 2013 um 15:46 Uhr) Grund: Beiträge zusammengefasst.
  Mit Zitat antworten Zitat
Alt 12. Sep 2013, 15:42     Erstellt von Furtbichler
Dieser Beitrag wurde von MrSpock gelöscht. - Grund: Beitrag zusammengefasst.
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.009 Beiträge
 
Delphi 12 Athens
 
#12

AW: Datein in MS SQL speichern

  Alt 12. Sep 2013, 15:46
Ich hab leider noch kein Beispiel gefunden das mir verständlich erklärt wie ich eine Datei in die MS SQL Spalte bekommen...
Google 2.Ergebnis

http://delphi.longzu.net/viewthread....xtra=page%3D58
Oder gleich in die Doku sehen: http://docwiki.embarcadero.com/VCL/X...d.LoadFromFile
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.171 Beiträge
 
Delphi 10.4 Sydney
 
#13

AW: Datein in MS SQL speichern

  Alt 12. Sep 2013, 16:34
Der unterschied zwischen varchar und char ist nur das der String nicht mit leerzeichen gefüllt wird.
Das hier funktioniert aber:
Code:
create table foo(
   bar varchar(5000),
   bar1 varchar(5000),
   bar2 varchar(5000)
)
insert into foo select '1','2','3'
Erzeugen kannst du so eine Tabelle problemlos. Füll sie aber mal mit der Maximalgröße. Sobald du auf 8060 Bytes kommst (z.B. bar mit 5000 Zeichen und bar3 mit 3060 Zeichen) kracht es erst. Mit den Mini-Einträge hat der Server kein Problem.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Furtbichler
(Gast)

n/a Beiträge
 
#14

AW: Datein in MS SQL speichern

  Alt 12. Sep 2013, 20:40
Erzeugen kannst du so eine Tabelle problemlos. Füll sie aber mal mit der Maximalgröße. Sobald du auf 8060 Bytes kommst (z.B. bar mit 5000 Zeichen und bar3 mit 3060 Zeichen) kracht es erst. Mit den Mini-Einträge hat der Server kein Problem.
Äh. Nö.
Code:
create table foo(
    bar varchar(5000),
    bar1 varchar(5000),
    bar2 varchar(5000)
 )
 insert into foo
 select
   replicate('1',5000),
   replicate('2',5000),
   replicate('3',5000)
Kein Fehler. Wo ist mein Fehler?
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.171 Beiträge
 
Delphi 10.4 Sydney
 
#15

AW: Datein in MS SQL speichern

  Alt 12. Sep 2013, 20:52
Kein Fehler. Wo ist mein Fehler?
Der Code geht jedenfalls mit 2012er DB.
Wenn ich den Beitrag unter "Row-Overflow Data Exceeding 8 KB" verstehe hat hier MS einen Automatismus implementiert der automatich varchars nur noch im 8060er-Bereich refernziert.
Da muss ich evtl. im Code prüfen ob ich hier unnötige Fehler/Warnmeldungen eingebaut habe die seit 2005er Version nicht mehr nötig sind.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Benutzerbild von Andidreas
Andidreas

Registriert seit: 27. Okt 2005
1.110 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#16

AW: Datein in MS SQL speichern

  Alt 13. Sep 2013, 09:15
Kennt jemand ein Tutorial wo das ganze gut erklärt wird? Also wie man Dateien in einer Datenbank speichert und wie man Sie wieder ausliest zum abspeichern?

Für mich ist das alles Neuland ()


Vergesst den Post hier... Ich hab paar Antworten übersehen!
Ein Programmierer Programmiert durchschnittlich 15 Code Zeilen pro Tag
Wir sind hier doch nicht bei SAP!!!

Aber wir habens bald
  Mit Zitat antworten Zitat
Benutzerbild von Andidreas
Andidreas

Registriert seit: 27. Okt 2005
1.110 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#17

AW: Datein in MS SQL speichern

  Alt 13. Sep 2013, 11:25
So... Ich habs jetzt hinbekommen...

Da das ganze wie gesagt Neuland ist für mich, würd mich Eure Meinung dazu (also zu meiner Lösung) interessieren:

MS SQL Tabelle (quick & dirty angelegt zum Testen):
Code:
Create Table [mailsolution].[dbo].[mailsolution.attachments]
(
AttachmentName varchar(255),
AttachmentExt varchar(25),
AttachmentBlob varbinary(max)
)

Upload in MS SQL Tabelle
Delphi-Quellcode:
//******************************************************************************
// OnClick btn_upload *
//******************************************************************************

procedure Tmain_form.btn_uploadClick(Sender: TObject);

var
ms : TMemoryStream;

begin

  Try
    ms := TMemoryStream.Create;
    ms.LoadFromFile(edt_attachmentpath.Text);

    Try
      With (dmunidb.UniDB_Query1) Do
      Begin
        Active := False;
        SQL.Clear;
        SQL.Add(' Insert Into "mailsolution.Attachments" ');
        SQL.Add(' (AttachmentName, AttachmentExt, AttachmentBlob) ');
        SQL.Add(' Values(:AttachmentName, :AttachmentExt, :AttachmentBlob) ');
        ParamByName('AttachmentName').AsString := 'Test';
        ParamByName('AttachmentExt').AsString := '.pdf';
        ParamByName('AttachmentBlob').SetBlobData(ms.Memory, ms.Size);
        ExecSQL;
      End;
    Except
      On E:Exception Do
      Begin
        MessageDlg(E.Message, mtError, [mbOK], 0);
      End;
    End;
  Finally
    ms.Free;
  End;

end;
Download aus MS SQL Tabelle:
Delphi-Quellcode:
//******************************************************************************
// OnClick btn_download *
//******************************************************************************

procedure Tmain_form.btn_downloadClick(Sender: TObject);

var
ts: TStream;
ms: TMemoryStream;

begin

  Try
    With (dmunidb.UniDB_Query1) Do
    Begin
      Active := False;
      SQL.Clear;
      SQL.Add(' Select * From "mailsolution.Attachments" ');
      ExecSQL;
    End;
  Except
    On E:Exception Do
    Begin
      MessageDlg(E.Message, mtError, [mbOK], 0);
    End;
  End;

   Try
     ts := TStream.Create;
     ts := dmunidb.UniDB_Query1.CreateBlobStream(dmunidb.UniDB_Query1.Fieldbyname('AttachmentBlob'),bmRead);
     ms := TMemoryStream.Create;
     ms.LoadFromStream(ts);
     ms.SaveToFile(edt_savepath.Text);
   Finally
     ts.Free;
     ms.Free;
   End;

end;
Ein Programmierer Programmiert durchschnittlich 15 Code Zeilen pro Tag
Wir sind hier doch nicht bei SAP!!!

Aber wir habens bald
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.171 Beiträge
 
Delphi 10.4 Sydney
 
#18

AW: Datein in MS SQL speichern

  Alt 13. Sep 2013, 12:03
Nimm auf jedenfall die n-Variante (nvarchar). In 2013 sollte man seine Anwendungen nicht nur für 80 Mio. Deutsche Entwickeln.

Übrigens gabs (gibts?) einige Performanceprobleme wenn man mit Unicode-Enabled Systemen (wie XE ja ist) auf eine DB mit ANSI-Feldern arbeitet.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Benutzerbild von Andidreas
Andidreas

Registriert seit: 27. Okt 2005
1.110 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#19

AW: Datein in MS SQL speichern

  Alt 13. Sep 2013, 12:15
Übrigens gabs (gibts?) einige Performanceprobleme wenn man mit Unicode-Enabled Systemen (wie XE ja ist) auf eine DB mit ANSI-Feldern arbeitet.
Inwiefern, bzw. wie kann ich die beheben?
Ich hab Performance Probleme wenn ich die ganze Tabelle selektier bzw. die Blob Felder...
Ein Programmierer Programmiert durchschnittlich 15 Code Zeilen pro Tag
Wir sind hier doch nicht bei SAP!!!

Aber wir habens bald
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.171 Beiträge
 
Delphi 10.4 Sydney
 
#20

AW: Datein in MS SQL speichern

  Alt 13. Sep 2013, 12:19
Übrigens gabs (gibts?) einige Performanceprobleme wenn man mit Unicode-Enabled Systemen (wie XE ja ist) auf eine DB mit ANSI-Feldern arbeitet.
Inwiefern, bzw. wie kann ich die beheben?
varchar -> nvarchar.

Ich hab Performance Probleme wenn ich die ganze Tabelle selektier bzw. die Blob Felder...
Dann mach halt sowas nicht
Ne. Ein Fehler ist wenn man beim MS SQL-Server mit serverseitigen Curser arbeitet. Schau mal in den Properties (CurserLocation oder Ähnlich) was du dort stehen hast.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 17:32 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz