• Hallo liebe Userinnen und User,

    nach bereits längeren Planungen und Vorbereitungen sind wir nun von vBulletin auf Xenforo umgestiegen. Die Umstellung musste leider aufgrund der Serverprobleme der letzten Tage notgedrungen vorverlegt werden. Das neue Forum ist soweit voll funktionsfähig, allerdings sind noch nicht alle der gewohnten Funktionen vorhanden. Nach Möglichkeit werden wir sie in den nächsten Wochen nachrüsten. Dafür sollte es nun einige der Probleme lösen, die wir in den letzten Tagen, Wochen und Monaten hatten. Auch der Server ist nun potenter als bei unserem alten Hoster, wodurch wir nun langfristig den Tank mit Bytes vollgetankt haben.

    Anfangs mag die neue Boardsoftware etwas ungewohnt sein, aber man findet sich recht schnell ein. Wir wissen, dass ihr alle Gewohnheitstiere seid, aber gebt dem neuen Board eine Chance.
    Sollte etwas der neuen oder auch gewohnten Funktionen unklar sein, könnt ihr den "Wo issn da der Button zu"-Thread im Feedback nutzen. Bugs meldet ihr bitte im Bugtracker, es wird sicher welche geben die uns noch nicht aufgefallen sind. Ich werde das dann versuchen, halbwegs im Startbeitrag übersichtlich zu halten, was an Arbeit noch aussteht.

    Neu ist, dass die Boardsoftware deutlich besser für Mobiltelefone und diverse Endgeräte geeignet ist und nun auch im mobilen Style alle Funktionen verfügbar sind. Am Desktop findet ihr oben rechts sowohl den Umschalter zwischen hellem und dunklem Style. Am Handy ist der Hell-/Dunkelschalter am Ende der Seite. Damit sollte zukünftig jeder sein Board so konfigurieren können, wie es ihm am liebsten ist.


    Die restlichen Funktionen sollten eigentlich soweit wie gewohnt funktionieren. Einfach mal ein wenig damit spielen oder bei Unklarheiten im Thread nachfragen. Viel Spaß im ngb 2.0.

SQL Frage

Steeve

Vereinsheimer
Barkeeper

Registriert
15 Juli 2013
Beiträge
41.121
Hi, gehört SQL hier auch in das Forum?

Wenn ich letztlich so eine Tabelle habe (mit Union Befehl)

[src=text]+-------+----------+----------+------------+-----------+----------+-----------+
| re_id | kunde_id | name | Anz. Fzg. | RB netto | USt | RB brutto |
+-------+----------+----------+------------+-----------+----------+-----------+
| 1 | 2 | Meier | 1 | 5714.29 | 1085.71 | 6800.00 |
| 2 | 3 | von Burg | 3 | 158613.45 | 30136.55 | 188750.00 |
| 3 | 1 | Schmidt | 2 | 25629.41 | 4869.59 | 30499.00 |
| 4 | 2 | Meier | 1 | 8403.36 | 1596.64 | 10000.00 |
| 5 | 3 | von Burg | 1 | 18907.56 | 3592.44 | 22500.00 |
| 6 | 5 | Kaiser | 2 | 43949.58 | 8350.42 | 52300.00 |
| | | | | 261217.65 | 49631.35 | 310849.00 |
+-------+----------+----------+------------+-----------+----------+-----------+[/src]

mit diesem Befehl erstellt
Code:
SELECT rechnungen.re_id, kunden.kunde_id, kunden.name, count(re_positionen.re_pos_id) AS "Anz.  Fzg.", round((sum(re_positionen.vk_brutto) / 119 * 100), 2) AS "RB netto", round(sum(re_positionen.vk_brutto / 119 * 19), 2)  AS "USt", sum(re_positionen.vk_brutto) AS "RB brutto" FROM kunden
JOIN Rechnungen ON kunden.kunde_id=rechnungen.kunde_id 
JOIN re_positionen ON re_positionen.re_id=rechnungen.re_id GROUP BY rechnungen.re_id 
UNION SELECT "", "", "", "",  round((sum(re_positionen.vk_brutto) / 119 * 100), 2) AS "RB netto", round(sum(re_positionen.vk_brutto / 119 * 19), 2)  AS "USt", sum(re_positionen.vk_brutto) AS "RB brutto" from re_positionen;
kann man in SQL so einen Tabellen Unterstrich erzeugen, so dass es am Ende so aussieht?

[src=text]+-------+----------+----------+------------+-----------+----------+-----------+
| re_id | kunde_id | name | Anz. Fzg. | RB netto | USt | RB brutto |
+-------+----------+----------+------------+-----------+----------+-----------+
| 1 | 2 | Meier | 1 | 5714.29 | 1085.71 | 6800.00 |
| 2 | 3 | von Burg | 3 | 158613.45 | 30136.55 | 188750.00 |
| 3 | 1 | Schmidt | 2 | 25629.41 | 4869.59 | 30499.00 |
| 4 | 2 | Meier | 1 | 8403.36 | 1596.64 | 10000.00 |
| 5 | 3 | von Burg | 1 | 18907.56 | 3592.44 | 22500.00 |
| 6 | 5 | Kaiser | 2 | 43949.58 | 8350.42 | 52300.00 |
+-------+----------+----------+------------+-----------+----------+-----------+
| | | | | 261217.65 | 49631.35 | 310849.00 |
+-------+----------+----------+------------+-----------+----------+-----------+[/src]

Im Anhang die Datenbank (alle Inhalte frei erfunden)
 

Anhänge

  • autohaus.txt
    2,6 KB · Aufrufe: 162
Zuletzt bearbeitet:

BurnerR

Bot #0384479

Registriert
20 Juli 2013
Beiträge
5.504
SQL gehört definitiv hier rein :T.
Das was du fragst, davon hab ich noch nicht gehört. Am besten du spezifiziert, welches DBMS du verwendest.
Normalerweise trennt man SQL und Darstellung des Ergebnisses, das solltest du auch machen. Also irgendein SQL-Workbench / WebApp / Phpmydamin / ... irgendwas. Zu versuchen SQL an sich zu formatieren, damit wirst du vermutlich nicht glücklich.
Deinen SQL Query solltest du so weder abspeichern noch hat da jemand Lust drauf den so zu lesen. Füge Zeilenumbrüche ein.
 

Steeve

Vereinsheimer
Barkeeper

Registriert
15 Juli 2013
Beiträge
41.121
  • Thread Starter Thread Starter
  • #3
DBMS ist mir ein neuer Begriff, bin noch SQL Anfänger.
Ich nutze MariaDB über xampp falls du das meinst. Ja mir gehts erstmal nur um die Tabellenansicht in der Kommandozeile.
Habe mal den Query angepasst, vllt ist es etwas besser.
 

BurnerR

Bot #0384479

Registriert
20 Juli 2013
Beiträge
5.504
Hoffe die Einrückung ist so korrekt, richtiges SQL ohne Abstraktion ist schon wieder eine Weile her :D.
So formatiert man jdfs einen komplexeren SQl Query, nicht so wie du das gemacht hast ;).
Bei XAMPP Stack lieferst du ja HTML aus am Ende. Konzentrier dich darauf, dass das dann korrekt aussieht. Die reine Konsolenausgabe detailliert zu formatieren ist Zeitverschwendung und die Möglichkeiten dazu sind soweit ich weiß stark begrenzt.
[src=mysql]
SELECT
rechnungen.re_id,
kunden.kunde_id,
kunden.name,
count(re_positionen.re_pos_id) AS "Anz. Fzg.",
round((sum(re_positionen.vk_brutto) / 119 * 100), 2) AS "RB netto",
round(sum(re_positionen.vk_brutto / 119 * 19), 2) AS "USt",
sum(re_positionen.vk_brutto) AS "RB brutto"
FROM kunden
JOIN Rechnungen
ON kunden.kunde_id = rechnungen.kunde_id
JOIN re_positionen
ON re_positionen.re_id = rechnungen.re_id
GROUP BY rechnungen.re_id
UNION SELECT
"",
"",
"",
"",
round((sum(re_positionen.vk_brutto) / 119 * 100), 2) AS "RB netto",
round(sum(re_positionen.vk_brutto / 119 * 19), 2) AS "USt",
sum(re_positionen.vk_brutto) AS "RB brutto"
FROM re_positionen;
[/src]
 

Steeve

Vereinsheimer
Barkeeper

Registriert
15 Juli 2013
Beiträge
41.121
  • Thread Starter Thread Starter
  • #5
Ja, Danke für die richtige Darstellung
Die reine Konsolenausgabe detailliert zu formatieren ist Zeitverschwendung und die Möglichkeiten dazu sind soweit ich weiß stark begrenzt.
Ja ok, ich dachte es geht vllt mit einem Befehl, da ich aber nichts hier auf meiner Befehlsliste habe, geht es wohl nicht.
 
Oben