Bylo rozhodnuto, že nejnovější Linux 6.18 je jádrem s prodlouženou upstream podporou (LTS). Ta je aktuálně plánována do prosince 2027. LTS jader je aktuálně šest: 5.10, 5.15, 6.1, 6.6, 6.12 a 6.18.
Byla vydána nová stabilní verze 3.23.0, tj. první z nové řady 3.23, minimalistické linuxové distribuce zaměřené na bezpečnost Alpine Linux (Wikipedie) postavené na standardní knihovně jazyka C musl libc a BusyBoxu. Přehled novinek v poznámkách k vydání.
Byla vydána verze 6.0 webového aplikačního frameworku napsaného v Pythonu Django (Wikipedie). Přehled novinek v poznámkách k vydání.
Po více než 7 měsících vývoje od vydání verze 6.8 byla vydána nová verze 6.9 svobodného open source redakčního systému WordPress. Kódové jméno Gene bylo vybráno na počest amerického jazzového klavíristy Gene Harrise (Ray Brown Trio - Summertime).
Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za listopad (YouTube).
Google Chrome 143 byl prohlášen za stabilní. Nejnovější stabilní verze 143.0.7499.40 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 13 bezpečnostních chyb.
Společnost Valve aktualizovala přehled o hardwarovém a softwarovém vybavení uživatelů služby Steam. Podíl uživatelů Linuxu dosáhl 3,2 %. Nejčastěji používané linuxové distribuce jsou Arch Linux, Linux Mint a Ubuntu. Při výběru jenom Linuxu vede SteamOS Holo s 26,42 %. Procesor AMD používá 66,72 % hráčů na Linuxu.
Canonical oznámil (YouTube), že nově nabízí svou podporu Ubuntu Pro také pro instance Ubuntu na WSL (Windows Subsystem for Linux).
Samsung představil svůj nejnovější chytrý telefon Galaxy Z TriFold (YouTube). Skládačka se nerozkládá jednou, ale hned dvakrát, a nabízí displej s úhlopříčkou 10 palců. V České republice nebude tento model dostupný.
Armbian, tj. linuxová distribuce založená na Debianu a Ubuntu optimalizovaná pro jednodeskové počítače na platformě ARM a RISC-V, ke stažení ale také pro Intel a AMD, byl vydán ve verzi 25.11.1. Přehled novinek v Changelogu.
mám aplikaci, která pracuje s daty v MySQL. Jedna tabulka má kolem 100k záznamů a já bych rád tyto záznamy zobrazil postupně uživateli.
Mé řešení:
Po spuštění aplikace zobrazím prvních 500 záznamů. Když uživatel začne rolovat v gridu a dostane se na konec, načtu následujících 500 záznamů. Pokud se vrací zpět, načtu předchozí záznamy atd. Funguje to velice pěkně a rychle. Používám na to LIMIT a OFFSET. Je tu ale problém.
Tabulka je nějak setříděná. Uživatel chce editovat záznam. Pokud opraví položku, podle které se tabulka třídí, položka se posune na jinou pozici, takže se dostane mimo hranice stanovené LIMIT a OFFSET. Jak se mám na tento záznam po ukončení editace vrátit? Jak mám zjistit, kterou stránku mu mám pomocí LIMIT a OFFSET zobrazit (kurzor na záznam už pak přesunu pomocí sekvenčního vyhledání pod ID)? Máte, prosím, nějaký nápad?
Díky moc!Řešení dotazu:
select count(*) from table where sort_key < changed_keya mas pozici.
Díky za radu, pomohlo to. Bohužel pokud je uživatel někde na u konce tabulky, ten select dlouho trvá. Nakonec jsem to vyřešil jinak.
Mé řešení:
procedure TfrmMain.DBGrid1KeyDown(Sender: TObject; var Key: Word;
Shift: TShiftState);
var
id : Integer;
f1 : TDateTime;
f2 : String;
f3 : Integer;
begin
if (key = VK_END) and (Shift = [ssCtrl]) then
begin
if cDB_LIMIT > DbRecCount then
DbOffset := 0
else
DbOffset := DbRecCount - cDB_LIMIT;
try
Q.DisableControls;
trQ.Rollback;
Q.SQL.Text := 'select * from cqrlog_main order by qsodate DESC, time_on DESC LIMIT '+IntToStr(cDB_LIMIT)+' OFFSET '+IntToStr(DbOffset);
trQ.StartTransaction;
Q.Open;
Q.First
finally
Q.EnableControls
end
end;
if (key = VK_HOME) and (Shift = [ssCtrl]) then
begin
try
Q.DisableControls;
trQ.Rollback;
Q.SQL.Text := 'select * from cqrlog_main order by qsodate DESC, time_on DESC LIMIT '+IntToStr(cDB_LIMIT);
trQ.StartTransaction;
Q.Open
finally
Q.EnableControls
end
end;
if ((key = VK_UP) or (key = 33)) and Q.BOF then
begin
try
Q.DisableControls;
id := Q.Fields[0].AsInteger;
f2 := Q.Fields[2].AsString;
f1 := Q.Fields[1].AsDateTime;
Q1.SQL.Text := 'select id_cqrlog_main from cqrlog_main order by qsodate DESC, time_on DESC LIMIT 1';
trQ1.StartTransaction;
Q1.Open;
f3 := Q1.Fields[0].AsInteger;
trQ1.Rollback;
Q1.Close;
if f3=id then //we are on the begining of dataset
exit;
Q.Close;
Q.SQL.Text := 'select * from (select * from cqrlog_main where (qsodate = '+QuotedStr(DateToStr(f1))+
'and time_on >= '+QuotedStr(f2)+') or qsodate > '+QuotedStr(DateToStr(f1))+
' order by qsodate, time_on LIMIT '+IntToStr(cDB_LIMIT)+') as foo order by qsodate DESC,time_on DESC';
trQ.Rollback;
trQ.StartTransaction;
Q.Open;
Q.Last
finally
Q.EnableControls
end
end;
if ((key = VK_DOWN) or (key = 34)) and Q.EOF then
begin
try
Q.DisableControls;
id := Q.Fields[0].AsInteger;
f2 := Q.Fields[2].AsString;
f1 := Q.Fields[1].AsDateTime;
Q1.SQL.Text := 'select id_cqrlog_main from cqrlog_main order by qsodate,time_on LIMIT 1 OFFSET 0';
trQ1.StartTransaction;
Q1.Open;
f3 := Q1.Fields[0].AsInteger;
Q1.Close;
trQ1.Rollback;
if f3=id then //we are on the end of dataset
exit;
Q.Close;
Q.SQL.Text := 'select count(*) from cqrlog_main where (qsodate = '+QuotedStr(DateToStr(f1))+
'and time_on <= '+QuotedStr(f2)+') or qsodate < '+QuotedStr(DateToStr(f1))+
' order by qsodate DESC, time_on DESC LIMIT '+IntToStr(cDB_LIMIT);
Q.Open;
if Q.Fields[0].AsInteger < cDB_LIMIT then
begin
Q.Close;
Q.SQL.Text := 'select * from (select * from cqrlog_main order by qsodate, time_on LIMIT '+
IntToStr(cDB_LIMIT)+') as foo order by qsodate DESC,time_on DESC';
Q.Open;
Q.Locate('id_cqrlog_main',id,[])
end
else begin
Q.Close;
Q.SQL.Text := 'select * from cqrlog_main where (qsodate = '+QuotedStr(DateToStr(f1))+
'and time_on <= '+QuotedStr(f2)+') or qsodate < '+QuotedStr(DateToStr(f1))+
' order by qsodate DESC, time_on DESC LIMIT '+IntToStr(cDB_LIMIT);
Q.Open;
Q.Locate('id_cqrlog_main',id,[])
end
finally
Q.EnableControls
end
end
Tiskni
Sdílej: