Byl vydán Nextcloud Hub 8. Představení novinek tohoto open source cloudového řešení také na YouTube. Vypíchnout lze Nextcloud AI Assistant 2.0.
Vyšlo Pharo 12.0, programovací jazyk a vývojové prostředí s řadou pokročilých vlastností. Krom tradiční nadílky oprav přináší nový systém správy ladících bodů, nový způsob definice tříd, prostor pro objekty, které nemusí procházet GC a mnoho dalšího.
Microsoft zveřejnil na GitHubu zdrojové kódy MS-DOSu 4.0 pod licencí MIT. Ve stejném repozitáři se nacházejí i před lety zveřejněné zdrojové k kódy MS-DOSu 1.25 a 2.0.
Canonical vydal (email, blog, YouTube) Ubuntu 24.04 LTS Noble Numbat. Přehled novinek v poznámkách k vydání a také příspěvcích na blogu: novinky v desktopu a novinky v bezpečnosti. Vydány byly také oficiální deriváty Edubuntu, Kubuntu, Lubuntu, Ubuntu Budgie, Ubuntu Cinnamon, Ubuntu Kylin, Ubuntu MATE, Ubuntu Studio, Ubuntu Unity a Xubuntu. Jedná se o 10. LTS verzi.
Na YouTube je k dispozici videozáznam z včerejšího Czech Open Source Policy Forum 2024.
Fossil (Wikipedie) byl vydán ve verzi 2.24. Jedná se o distribuovaný systém správy verzí propojený se správou chyb, wiki stránek a blogů s integrovaným webovým rozhraním. Vše běží z jednoho jediného spustitelného souboru a uloženo je v SQLite databázi.
Byla vydána nová stabilní verze 6.7 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 124. Přehled novinek i s náhledy v příspěvku na blogu. Vypíchnout lze Spořič paměti (Memory Saver) automaticky hibernující karty, které nebyly nějakou dobu používány nebo vylepšené Odběry (Feed Reader).
OpenJS Foundation, oficiální projekt konsorcia Linux Foundation, oznámila vydání verze 22 otevřeného multiplatformního prostředí pro vývoj a běh síťových aplikací napsaných v JavaScriptu Node.js (Wikipedie). V říjnu se verze 22 stane novou aktivní LTS verzí. Podpora je plánována do dubna 2027.
Byla vydána verze 8.2 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a v informačním videu. Zdůrazněn je průvodce migrací hostů z VMware ESXi do Proxmoxu.
R (Wikipedie), programovací jazyk a prostředí určené pro statistickou analýzu dat a jejich grafické zobrazení, bylo vydáno ve verzi 4.4.0. Její kódové jméno je Puppy Cup.
CREATE OR REPLACE FUNCTION accounting.fu_getflags_10( indoc ismaster."T_DocumentId") RETURNS ismaster."T_DocumentFlags" LANGUAGE 'plpgsql' COST 100 VOLATILE PARALLEL UNSAFE AS $BODY$ DECLARE flags ismaster."T_DocumentFlags"; BEGIN IF EXISTS (SELECT FROM accounting.accdocheader WHERE "docId" = indoc) THEN SELECT "docFlags" INTO flags FROM accounting.accdocheader WHERE "docId" = indoc; ELSE flags := ismaster.fu_default_document_flags(); END IF; RETURN flags; END; $BODY$;
CREATE TYPE ismaster."T_DocumentFlags" AS ( "dateNew" ismaster."D_DateNew", "dateUpdate" timestamp without time zone, "dateOwner" timestamp without time zone, "userNew" ismaster."D_IsUserId", "userUpdate" ismaster."D_IsUserId", "userOwner" ismaster."D_IsUserId", "onlyAuthor" boolean, "isAccount" boolean, "isFinality" boolean, "isArch" boolean, "noStorno" boolean, "noDelete" boolean );ZAH
Řešení dotazu:
Po jejím nastavení server vyhodí chybu ERRORA mohl bych to nastaveni(kde a jak) videt?
("2023-06-24 13:51:48.405636","2023-06-24 18:58:39.991784",,"zah ","zah ",,,,,,,)Před nastavením hodnoty projde OK.
("2023-06-24 13:50:42.806875",,,"zah ",,,,,,,,)Nastavení se provede v trigru pomoci now() po změně řádku.
....... ..... NEW."docFlags"."dateUpdate" := now(); return NEW;
"dateUpdate" timestamp without time zoneale, now() vraci timestamp with time zone ?
CREATE OR REPLACE FUNCTION accounting.fu_getflags_10( indoc ismaster."T_DocumentId") RETURNS ismaster."T_DocumentFlags" LANGUAGE 'sql' COST 100 VOLATILE PARALLEL UNSAFE AS $BODY$ SELECT "docFlags" FROM accounting.accdocheader WHERE "docId" = indoc ; $BODY$;Problémová část kódu po změně (místo INTO přiřazení)
flags := accounting.fu_getflags_10(NEW."docId"); -- pro vlozeni radku musi hlavicka povolit update IF NOT ismaster.fu_docflags_can_update(flags) THEN RETURN null; END IF;Čím dál více se přikláním k tomu, že v pgplsql dělám/je nějaká chyba při přiřazování komplexních typů. Objevil se další problém s podobným kódem . Zde vyhodí chybu ERROR" Invalid input syntax for type double precission
DECLARE flags ismaster."T_DocumentFlags"; debcr ismaster."T_DebitCredit"; begin ..... ..... IF NEW."rowNum" = 1 AND NEW.debitcredit IS null THEN SELECT debitcredit INTO debcr FROM accounting.accdocheader WHERE "docId" = NEW."docId"; NEW.debitcredit := ismaster.fu_change_debitcredit(debcr); END IF; ..... .....Definice typu
CREATE TYPE ismaster."T_DebitCredit" AS ( debit ismaster."D_AccountValue", credit ismaster."D_AccountValue" );
(2023-06-25 23:51:46) postgres=# \d foot Composite type "public.foot" ┌────────┬───────────────────┬───────────┬──────────┬─────────┐ │ Column │ Type │ Collation │ Nullable │ Default │ ╞════════╪═══════════════════╪═══════════╪══════════╪═════════╡ │ a │ date │ │ │ │ │ b │ character varying │ │ │ │ │ c │ date │ │ │ │ └────────┴───────────────────┴───────────┴──────────┴─────────┘ (2023-06-25 23:51:57) postgres=# \d xx Table "public.xx" ┌────────┬───────────────────┬───────────┬──────────┬─────────┐ │ Column │ Type │ Collation │ Nullable │ Default │ ╞════════╪═══════════════════╪═══════════╪══════════╪═════════╡ │ id │ integer │ │ │ │ │ f │ foot │ │ │ │ │ d │ character varying │ │ │ │ └────────┴───────────────────┴───────────┴──────────┴─────────┘ (2023-06-25 23:52:01) postgres=# do $$ declare x xx; begin x := (1, null, 'ahoj'); x.f.a := now(); x.f.b := 'nazdar'; x.f.c := current_date; raise notice '% %', x.f, (x.f).c; end; $$; NOTICE: (2023-06-25,nazdar,2023-06-25) 2023-06-25 DO
ERROR: invalid input syntax for type date: "(2023-01-01,Test,2022-11-11)" CONTEXT: PL/pgSQL funkce test() řádek 3 na SQL příkaz SQL stav: 22007
record
a zobrazíte.
CREATE OR REPLACE FUNCTION public.test() RETURNS boolean LANGUAGE plpgsql AS $function$ DECLARE r record; BEGIN SELECT fx INTO r FROM table1 WHERE id = 5; RAISE NOTICE '% %', r, row_to_json(r); RETURN true; END;$function$; CREATE FUNCTION (2023-06-27 16:11:42) postgres=# SELECT public.test(); NOTICE: ("(2023-01-01,Test,2022-11-11)") {"fx":{"a":"2023-01-01","b":"Test","c":"2022-11-11"}} ┌──────┐ │ test │ ╞══════╡ │ t │ └──────┘ (1 row)Jde o to, že výsledkem dotazu je n-tice hodnot, která se uloží do jiné n-tice proměnných nebo kompozitu (což je dnes už něco jiného, ale dříve to byla zase n-tice proměnných) tj (c1,c2,c3) -> (var1,var2,var3), (c1,c2,c3)->(f1,f2,f3). Interně výsledkem každého dotazu je kompozit. Pokud je nějaký sloupec v dotazu kompozit, pak je ten kompozit zanořený, a tudíž vy jej nemůžete přiřadit proměnné kompozitního typu, která nečeká ještě další úroveň. Ve vašem případě se Postgres snaží přiřadit první sloupec výsledku první položce kompozitu - z čehož pak plyne ta zmatečná hláška. Co můžete udělat? a) Před přiřazením zdrojový kompozit rozbalit. Pak výsledek bude sedět cíli.
CREATE OR REPLACE FUNCTION public.test() RETURNS boolean LANGUAGE plpgsql AS $function$ DECLARE ff foot; BEGIN -- SELECT (fx).a, (fx).b, (fx).c INTO ff FROM table WHERE id = 5 -- je taky ok SELECT (fx).* INTO ff FROM table1 WHERE id = 5; RETURN true; END;$function$;b) Použít přiřazovací příkaz a ANSI zápis
CREATE OR REPLACE FUNCTION public.test() RETURNS boolean LANGUAGE plpgsql AS $function$ DECLARE ff foot; BEGIN ff := (SELECT fx FROM table1 WHERE id = 5); RETURN true; END;$function$;Jádro pudla je v designu SQL, které s kompozitními typy vůbec nepočítá (alespoň v těch nejstarších variantách), a ve chvíli, kdy se do tabulek ukládají kompozitní hodnoty, tak některé syntaxe jsou v kolizi. Navíc PL/pgSQL je mix dvou absolutně rozdílných jazyků - SQL a ADA (pro PL/pgSQL hodně redukovaná ADA). Není to jeden jazyk. A občas někde ty švy (kolize) jsou vidět.
Tiskni Sdílej: