Ich habe eine Tabelle "Elemente" mit einer Spalte "Nummer", geben SMALLINT, die Zahlen von 1 bis 56 enthält. Wie kann ich eindeutige Sätze von 5 Zahlen von jeder möglichen Kombination von 1 bis 56, mit einer SQL-Anweisung?In SQL, Wie kann ich jede mögliche einzigartige Kombination von 5! 56 erzeugen?
In APL (Programmiersprache) funktioniert eine einfache dyadische Funktion 5! 56!
EDIT: In guten alten MS-DOS QBASIC, ich erreicht es wie folgt aus:
10 OPEN "C:\5NUMBERS.OUT" FOR OUTPUT ACCESS READ WRITE AS #1
12 LET SER = 0
15 LET E = 56
30 FOR B5 = 5 TO E
40 FOR B4 = 4 TO E
50 FOR B3 = 3 TO E
60 FOR B2 = 2 TO E
70 FOR B1 = 1 TO E
80
88 IF B5 = B1 THEN 190
89 IF B5 = B2 THEN 190
90 IF B5 = B3 THEN 190
91 IF B5 = B4 THEN 190
92 IF B4 = B1 THEN 180
93 IF B4 = B2 THEN 180
94 IF B4 = B3 THEN 180
95 IF B3 = B1 THEN 170
96 IF B3 = B2 THEN 170
97 IF B2 = B1 THEN 160
98 LET SER = SER + 1
100 PRINT #1, SER; "|";
130 PRINT #1, B1; "|";
131 PRINT #1, B2; "|";
132 PRINT #1, B3; "|";
133 PRINT #1, B4; "|";
134 PRINT #1, B5; "|";
140 PRINT #1, B1 + B2 + B3 + B4 + B5; "|"
150 NEXT B1
160 NEXT B2
170 NEXT B3
180 NEXT B4
190 NEXT B5
205 CLOSE
210 END
220 SYSTEM
Das, nebenbei gesagt, erstellt meine Last-Datei in eine Informix-SQL-Tabelle
TABLE combos
(
seq_id SERIAL,
ball_1 SMALLINT,
ball_2 SMALLINT,
ball_3 SMALLINT,
ball_4 SMALLINT,
ball_5 SMALLINT,
sum SMALLINT
);
Ich habe combos.sum verwendet, um ein Glockenkurven-Diagramm zu erstellen, das die Anzahl der Kombinationen mit der gleichen Summe jedes Elements zeigt.
nein, jede Zahl in der Menge muss eindeutig sein, wie in einem Lottospiel –