[PGSQL] Ordered table

Overzicht Reageren

Sponsored by: Vacatures door Monsterboard

Software programmeur

Functieomschrijving Voor een erkende werkgever in de regio van Goes zijn wij op zoek naar een enthousiaste software programmeur met PHP/Symfony ervaring. Een gedreven persoon die het development team komt versterken met het aanpakken van complexe projecten. Ben jij op zoek naar een baan met veel uitdaging binnen een snelgroeiend e-commerce bedrijf, waar je de tijd en ruimte krijgt voor zowel professionele als persoonlijke groei? Lees dan snel verder! Dit ga je doen: Beheer en ontwikkeling van de serviceportal in Symfony en de webshops in de tweede versie van Magento; Testen en door ontwikkelen van software; Ontwikkelen van nieuwe functionaliteiten;

Bekijk vacature »

SQL database ontwikkelaar

Functie omschrijving Ben jij niet bang voor complexe algoritmes? Schikt het schrijven van procedures in T-SQL jouw niet af en heb jij al de nodige informatie in SQL, dan is functie precies wat voor jou! Jouw werkzaamheden gaan er als volgt uit zien: Je gaat werken aan de complexere projecten waar jij van A tot Z bij betrokken bent. Je gaat zorg dragen voor het ontwerp, de ontwikkeling en het updaten van SQL databases. Dit doe je op basis van T-SQL. Jij bent van start tot finish betrokken bij de projecten die jij leidt. Je houdt contact met klanten en

Bekijk vacature »

Senior, Medior and Junior SAP HANA Developer

Vacature details Vakgebied: Software/IT Opleiding: Medior Werklocatie: Veldhoven Vacature ID: 12696 Introductie Our client is the world's leading provider of lithography systems for the semiconductor industry, manufacturing complex machines that are critical to the production of integrated circuits or chips. Our purpose is “unlocking the potential of people and society by pushing technology to new limits”. We do this guided by the principles “Challenge”, “Collaborate” and “Care”. Wat verwachten we van jou? SAP Certified Application Associate - SAP HANA Cloud Modeling (training and/or certification) Bachelor degree or higher Excellent understanding of SAP HANA (2.0 / Cloud), Data Modelling and writing

Bekijk vacature »

Back-end ontwikkelaar

Functie omschrijving Wil jij meebouwen aan diverse databasesystemen in een klein bedrijf met een platte organisatie? In een team van ruim 10 ontwikkelaars wordt er aan diverse ICT oplossingen gewerkt. Jouw taken hierbij zullen bestaan uit: Het onderhouden en door-ontwikkelen van bestaande databases. Denk hierbij aan schema verbeteringen en performance-tuning. Bij nieuwe ontwikkelingen ga jij ook bezig met het bouwen van het databaseschema. Omdat je in een klein team werkt zal je ook de C# routine verder uitbouwen en ontwikkelen. Ook kan je meedraaien in algemene refactory-, ontwikkel- of testwerkzaamheden. Je zal voornamelijk gebruik maken van de volgende technieken: .NET

Bekijk vacature »

Teamlead PHP Developer

Functieomschrijving Voor een gewaardeerde werkgever in de buurt van Middelburg zijn wij op zoek naar een gemotiveerde teamlead PHP developer met affiniteit met Symfony/Laravel. Een enthousiast persoon die het ontwikkelteam komt versterken met het aanpakken van uitdagende projecten. Ben jij op zoek naar een uitdaging waar je de tijd en ruimte krijgt jezelf te ontwikkelen en je eigen IT-team aan te sturen? Lees dan snel verder! Die ga je doen: Bijdragen aan de implementatie van aanpassingen, verbeteringen en aanvullingen in de PHP based applicaties; Ontwikkeling en beheer van de serviceportal in Symfony en de webshops in de tweede versie van

Bekijk vacature »

Oracle APEX developer

Wat je gaat doen: Als Oracle APEX ontwikkelaar bij DPA werk je samen met collega’s aan de meest interessante opdrachten. Je zult je ervaring met SQL, PL/SQL, JavaScript, HTML en CSS inzetten om wensen van opdrachtgevers te vertalen naar technische oplossingen. Je werk is heel afwisselend, omdat DPA zich niet beperkt tot een specifieke branche. Zo ben je de ene keer bezig binnen de zorgsector, de andere keer is dit bij de overheid. Wat we vragen: Klinkt goed? Voor deze functie breng je het volgende mee: Je hebt een hbo- of universitaire opleiding afgerond Je hebt 2 tot 5 jaar

Bekijk vacature »

Back End Developer

Als Back End developer bij KUBUS houd je je bezig met het ontwikkelen van de (web)applicatie en services van BIMcollab. Je hebt een focus op de back end van onze software, daarvoor werken wij hoofdzakelijk met C# en .NET. Wij hanteren een full-stack benadering, wat betekent dat je naast de back-end ook meehelpt bij andere onderdelen van de code. Als softwarebedrijf bevindt KUBUS zich in een unieke positie. We bouwen aan onze eigen producten die wereldwijd door tienduizenden gebruikers worden gebruikt. Ons bedrijf heeft precies de juiste grootte: groot genoeg om echt impact te maken in de markt, maar klein

Bekijk vacature »

C# Ontwikkelaar

Functieomschrijving Voor een software ontwikkelaar in de omgeving van Vught zijn we op zoek naar een gemotiveerde C# ontwikkelaar. Deel jij hun passie voor development en dan vooral in C#.NET? Dan kan dit wel eens jouw droombaan zijn! Jouw werkzaamheden zullen er ongeveer als volgt uit gaan zien Door de wensen van de klant goed te begrijpen ga jij aan de slag dit om te zetten naar passende oplossingen en werk je deze uit tot een sterk eindproduct. Je gaat je bezighouden met de ontwikkeling van webapplicaties en websites, dit doe je door middel van ASP.NET, MVC Frameworks en C#.

Bekijk vacature »

PHP developer (Symfony, Doctrine)

Functie Als PHP developer wordt er een hoge mate van zelfstandigheid verwacht, maar ook dat je goed opereert in een team waar kennis wordt gedeeld en dingen als codereviews erg veel voorkomen. Kwaliteit staat voorop, mede hierom werken ze bijvoorbeeld zonder echte deadlines in hun sprints. De SaaS-applicatie wordt volledig ontwikkeld in PHP en Symfony. De module bestaat uit een stuk informatie verrijking en intelligentie wat resulteert in een medische check. De logica wordt daarom in de code geïntrigeerd. Je bent onder andere bezig met complexe databases waar meer dan 80.000 medicijnen op verschillende niveaus in staan, die maandelijks worden

Bekijk vacature »

Junior Software Developer (HBO / WO)

Functie omschrijving Voor een leuke opdrachtgever zijn wij op zoek naar een Junior Software Developer! Sta jij aan het begin van je carrière en heb je net je HBO of WO-diploma in de richting van ICT of Techniek mogen ontvangen? En heb jij grote affiniteit met software development? Dan hebben wij bij Jelling IT Professionals de perfecte opdrachtgever in de omgeving van Hoofddorp. Binnen deze functie vervul je een onsite learning programma waarbij je aan de slag gaat met PHP en Laravel. Hierbij ben je voornamelijk werkzaam op verschillende klantlocaties en is het jouw taak om hun wensen en eisen

Bekijk vacature »

.NET Developer C#

Dit ga je doen Als developer nieuwe gave features implementeren; Werken met technieken als C# .NET en (REST) API's webservices; Ontwikkelen van koppelingen middels API's; Maken van technische keuzes en beslissingen over de architectuur; Junior collega's coachen; Initiatief nemen voor nieuwe technische mogelijkheden; Je bent een belangrijke schakel - en vindt het leuk - om te schakelen met de business. Hier ga je werken Als C# .NET Developer wordt je verantwoordelijk voor het ontwikkelen van applicaties voor belangrijkste product van deze organisatie. Dit product is een applicatie voor alles omtrent hypotheken. De programmeertaal die je hierbij beheerst is C#. Er

Bekijk vacature »

C++ Developer

Functieomschrijving Ben jij als software engineer toe aan een nieuwe uitdaging? Dan zijn wij op zoek naar jou! Voor het maken van de procesbesturingsoftware gebruiken onze projectteams een in C++ en C# geschreven tool. Dit is een gedistribueerd object framework wat alle kernfuncties biedt voor een procesautomatisering. Verder zullen jouw werkzaamheden o.a. bestaan uit: Analyseren van vragen en wensen van gebruikers en deze vertalen naar een functioneel ontwerp; Ontwerpen, programmeren en testen van productaanpassingen; Implementeren van nieuwe productreleases in de projectteams; Continu toetsen van het effect van nieuwe releases op andere tools en processen; Inzichtelijk maken van voortgang omtrent softwarewerkzaamheden,

Bekijk vacature »

C# .NET Backend Developer HBO Javascript

Samengevat: Deze werkgever is een professionele speler op gebied van IT en E-Commerce. Wil jij werken voor een e-commerce platform? Heb je ervaring met C#, Javascript en Scrum? Vaste baan: C# .NET Developer Backend E-Commerce 3.400 - 4.500 Backend Developer Wij ontwikkelen software voor E-Commerce toepassingen. Ons eigen Content Management systeem biedt een integrale oplossing met diverse ERP software. Onze systemen zijn vaak complex en omvangrijk en draaien bij grote organisaties. Maar ook kleine ondernemingen hebben steeds vaker behoefte aan een vlekkeloos werkende E-Commerce oplossing. Zij bieden een uitdagende werkomgeving met gezellige collega's. Je krijgt veel vrijheid en er is

Bekijk vacature »

Low Code Developer

Functie omschrijving Ben jij toe aan een nieuwe uitdaging en ben jij HBO afgestudeerd in de richting van IT? Heb jij verstand van datamodellering, NO CODE Platformen en kun jij het aan om projecten te leiden? Voor een leuke opdrachtgever in omgeving Capelle aan den IJssel zijn wij op zoek naar een No Code developer die zich bezig gaat houden met het optimaliseren van bedrijfsprocessen bij klanten in heel het land! Wat ga je hier zoal doen? Je gaat geen code kloppen maar bedenken hoe applicaties eruit moet komen te zien. Je gaat werken met een non code platform, je

Bekijk vacature »

Traineeship ICT regio Amsterdam/Utrecht

Wat ga je doen? Het traineeship begint met een fulltime maand cursussen en praktijkdagen, waarin je de basis van het IT-vak leert op de Shared Servicedesk (SSD). Daarnaast ga je meteen aan de slag voor je eerste certificering! (ITILv4). Je start in een groep met 4 tot 10 deelnemers, waarmee jij gedurende die maand optrekt en je kennis kunt delen. Na het voltooien van de eerste maand ga je direct voor een langere periode aan de slag bij één van onze klanten of blijf je intern bij ons op de Shared Servicedesk. Je bent het eerste aanspreekpunt van de eindgebruikers

Bekijk vacature »
Arend a

Arend a

01/12/2008 20:49:00
Quote Anchor link
Ik heb een dilemma voor een tabel waarbij de volgorde uitmaakt, elke rij heeft een precieze plek in de tabel. Hoe kan je die rijen zo goed mogelijk onderhouden en bijwerken? (Herorderen van de tabel?). Je wil namelijk natuurlijk het liefst de kolom 'order' (integer), op unique zetten, en het liefst dat de order precies van 0 tot x loopt zonder gaten er tussen, maar dit maakt mutaties in een tabel een lastige zaak.

Ik heb het nu redelijk werkend met procedures.

language_get_next_ordinal(): de volgende ordinal in een table. (wellicht enigzins gevaarlijk bij hoge volume inserts, maar dit is niet aan de orde).

language_move(id, x): Verplaats record met id id naar positie x

language_reorder(): Haal gaps uit de tabel. (Bijvoorbeeld na een delete of na een update).

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
CREATE FUNCTION language_get_next_ordinal() RETURNS integer
    AS $$
 DECLARE
    p_next_ordinal integer;
 BEGIN
     SELECT count(id)
       INTO p_next_ordinal
     FROM vdven.language;
     RETURN p_next_ordinal;
 END;
$$
    LANGUAGE plpgsql;



CREATE FUNCTION language_move(f_id integer, f_new_pos integer) RETURNS integer
    AS $$
 DECLARE
     p_rec record;
     p_old_pos integer;
     p_max_pos integer;
     p_done integer := 0;
 BEGIN
     SELECT ordinal
     INTO p_old_pos
     FROM vdven.language
     WHERE id = f_id;
     
     SELECT COUNT(id)-1
     INTO p_max_pos
     FROM vdven.language;
     
     IF p_old_pos = f_new_pos THEN
        RETURN 0;
    END IF;

     IF p_max_pos < f_new_pos THEN
         RETURN -1;
     END IF;
    
     UPDATE vdven.language
     SET ordinal = p_max_pos+1
     WHERE id = f_id;
     
     IF p_old_pos > f_new_pos THEN
        FOR p_rec IN
                SELECT id,ordinal
                FROM vdven.language
                WHERE ordinal >= f_new_pos  
                AND ordinal < p_old_pos
                ORDER BY ordinal DESC
                LOOP
            UPDATE vdven.language
            SET ordinal = ordinal+1
            WHERE id = p_rec.id;
            p_done := p_done+1;
        END LOOP;
    ELSEIF p_old_pos < f_new_pos THEN
        FOR p_rec IN SELECT id,ordinal FROM vdven.language WHERE ordinal <= f_new_pos  AND ordinal > p_old_pos ORDER BY ordinal ASC LOOP
            UPDATE vdven.language
            SET ordinal = ordinal-1
            WHERE id = p_rec.id;
            p_done := p_done+1;
        END LOOP;
    ELSE
        RETURN -1;
    END IF;
    
    UPDATE vdven.language
        SET ordinal = f_new_pos
        WHERE id = f_id;
    RETURN p_done;
END;
$$
    LANGUAGE plpgsql;


CREATE FUNCTION language_reorder() RETURNS integer
    AS $$
 DECLARE
     p_rec record;
     p_int integer := 0;
     p_done integer :=  0;
 BEGIN
    FOR p_rec IN SELECT id,ordinal FROM vdven.language ORDER BY ordinal ASC LOOP
        IF p_int <> p_rec.ordinal THEN
            UPDATE vdven.language
            SET ordinal = p_int
            WHERE id = p_rec.id;
            p_done := p_done+1;
        END IF;
        p_int := p_int+1;
    END LOOP;
    RETURN p_done;
END;
$$
    LANGUAGE plpgsql;


Dit is een realtief complexe oplossing voor een simpel probleem, weet iemand in postgres of sql wellicht een simpelere oplossing?
Gewijzigd op 01/01/1970 01:00:00 door Arend a
 
PHP hulp

PHP hulp

29/01/2025 01:46:21
 
Frank -

Frank -

01/12/2008 21:10:00
Quote Anchor link
Quote:
Ik heb een dilemma voor een tabel waarbij de volgorde uitmaakt
De volgorde is het gevolg van een sortering die je opgeeft in een SELECT-query. Jouw dilema kun je dus schrappen, deze bestaat niet.
Quote:
Je wil namelijk natuurlijk het liefst de kolom 'order' (integer), op unique zetten
Dan doe je dat toch? Niets of niemand die je tegen houdt.
Quote:
en het liefst dat de order precies van 0 tot x loopt zonder gaten er tussen
Voor een sortering maakt het niet uit of je nu 1,2,3 of 1,8, 25 hebt, 1 is altijd de kleinste waarde en 2 is altijd kleiner dan 3, net zoals 8 kleiner dan 25 is. Voor een sortering bestaan er geen gaten.

Kortom, ik plaats hele grote vraagtekens bij bovenstaande "oplossingen", ik zie namelijk zelfs geen probleem. Leg eens uit wat nu het echte probleem is, dan kunnen we daar mee helpen.
 
PHP Newbie

PHP Newbie

01/12/2008 23:16:00
 
Arend a

Arend a

01/12/2008 23:31:00
Quote Anchor link
De sortering zelf is niet het probleem zoals ik aangaf, maar het hele herordenen is het probleem.

Ik post dit omdat ik zelf ook mijn twijfels heb bij dit systeem maar, mijn redenering is als volgt:

1. De waarde van order moet unique zijn, want de order van de tabel is bepaald en ondubbelzinnig.
2. Je zal ook bij een systeem met gaps problemen tegenkomen, want er zullen niet altijd gaps zijn, en dan moet je alsnog gaan hernummeren in de order. Mijn conclusie hieruit is dat een systeem met gaps geen voordeel bied tov een systeem zonder gaps.

Er zijn een paar algemene problemen met een ordered structuur:
1. Product X staat op positie 10, en moet naar 14, en de waarden 10 t/m 20 zijn bezet (ook met een systeem met gaps mogelijk). Dit houd in dat alles met waarde 11 t/m 14 wordt verplaatst naar 10 t/m 13, en product x komt op 14. Echter, product x moet eerst naar een tijdelijke waarde, want waarde 14 is op dat moment bezet, en dubbele waarden zijn niet mogelijk

2. Het verwisselen van twee items:
Bij een unique column levert dit ook hersenkrakers op, immers je kan niet in een transactie order 1 naar order 2 hernoemen en order 2 naar order 1, omdat je de twee niet tegelijkertijd kan uitvoeren en er dan een unique constrain in werking treed, kortom, je moet eerst eentje naar een tijdelijke waarde hernoemen en dan pas kan de andere terug.

Resumerend:
Een tabel die een unique order colum heeft levert nogal wat problemen op bij het aanpassen van de order, is het nog de moeite waard deze integriteit in de database te willen afdwingen of ziet iemand snellere of slimmere manieren om deze problemen te ondervangen?
Gewijzigd op 01/01/1970 01:00:00 door Arend a
 
Frank -

Frank -

02/12/2008 17:55:00
Quote Anchor link
1) nr. 10 moet naar nr. 14: Alles groter dan 13 schuift 1 op, +1 en nr 10 krijgt dan nr 14 als nieuw nummer. Dat nr. 10 leeg blijft, is geen enkel probleem, niemand die daar ooit last van zal hebben.

2) Het verwisselen van twee items wanneer je met een UNIQUE zit: Iets lastiger, maar met een work-around binnen een transactie geen enkel probleem:
1: start transaction;
2: record A geef je een oneindig grote waarde om zo ruimte te maken voor record B
3: record B krijgt de waarde van record A, die is tenslotte vrij gekomen
4: record A krijgt de waarde van record B, die is nu ook vrij.
5: commit

Stap 2 is de workaround, gebruik hier wel een random waarde voor. Dan is de kans wel heel erg klein dat er gelijktijdig iemand anders dezelfde waarde gebruikt.

Tip: Zet dit stuk in een stored procedure, dan kun je nooit de transactie vergeten. Zorg wel voor een goede rollback en test dit ook.

Edit: In het ergste geval zul een rollback moeten doen, wat in SQL de gewoonste zaak van de wereld is. Met een EXCEPTION in je stored procedure kun je dit eenvoudig afhandelen en een fraaie foutmelding richting de applicatie gooien.
Gewijzigd op 01/01/1970 01:00:00 door Frank -
 
Klaasjan Boven

Klaasjan Boven

02/12/2008 18:47:00
Quote Anchor link
Arend,

Je maakt me wel nieuwsgierig naar wat je aan het doen bent. Ik kan niks voorstellen bij een tabel waarin de volgorde zo exact bepaald moet zijn
 
PHP Newbie

PHP Newbie

02/12/2008 19:22:00
Quote Anchor link
Arend,

In dat voorbeeld leg ik niet alleen uit hoe je kan sorteren maar ook hoe ik daarbij de database update.

I.c.m. een transaction kan er niets mis gaan...
 
Arend a

Arend a

03/12/2008 02:17:00
Quote Anchor link
Bedankt voor de input, morgen een uitgebreidere reactie.

Over transacties, misschien doe ik iets verkeerd maar de volgende transactie werkt niet op een unique colom:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
BEGIN;
UPDATE public.test_unique
SET "unique"=2 WHERE id=1;
UPDATE public.test_unique
SET "unique"=1 WHERE id=2;
COMMIT;
 
Frank -

Frank -

03/12/2008 08:58:00
Quote Anchor link
Dat klopt helemaal, zie mijn reactie van 02.12.2008 17:55.

Je moet eerst record 1 een dummy-waarde geven, dan record 2 de gewenste waarde geven en vervolgens record 1 alsnog de juiste waarde geven.

Door dit in een transactie te doen, kun je nooit een corrupte database oplopen. Mits je de juiste beslissing neemt bij een COMMIT of ROLLBACK. Dit is dus een typisch voorbeeld van een set queries die je heel graag in een stored procedure zet. Dan hoef je de boel maar 1x te programmeren en kun je onmogelijk nog ergens in je PHP-code iets verkeerd doen.

Jouw probleem heeft niets met een transactie te maken, maar met een unique-constraint die wordt overtreden. Vandaar de dummy-waarde. Als dummy-waarde zou je bv. een sequence kunnen gebruiken die begint bij de waarde 1.000.000.000. Al heb je duizenden gebruikers per seconde, iedereen gebruikt zijn eigen dummy-waarde die door de sequence wordt uitgedeeld. De transactie is uitsluitend bedoelt om de boel veilig af te handelen. Je hebt toch wel ervaring met transacties?
 
Frank -

Frank -

03/12/2008 22:55:00
Quote Anchor link
Hier een voorbeeldje hoe je met een stored procedure 2 records van plaats kunt laten wisselen waarbij hun plekje in de sortering uniek moet zijn.

De tabel:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
CREATE TABLE test
(
  id serial NOT NULL,
  naam character varying(29),
  sort integer NOT NULL,
  CONSTRAINT pk_test PRIMARY KEY (id)
);

De UNIQUE constraint (met voorwaarde!!!):
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
CREATE UNIQUE INDEX u_sort
  ON test
  USING btree
  (sort)
  WHERE sort <> 0;

En dan de stored procedure:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
CREATE OR REPLACE FUNCTION switch(IN a INT, IN b INT) RETURNS bool AS
$BODY$
DECLARE
    new_a    INT;
    new_b    INT;
    ok        BOOL    := true;
BEGIN
    -- ophalen huidige sort-waarde van records a en b
    SELECT sort INTO new_b FROM test WHERE id = a;
    SELECT sort INTO new_a FROM test WHERE id = b;
    
    -- record a de sort-waarde 0 geven:
    BEGIN
        UPDATE test SET sort = 0 WHERE id = a;
        IF  NOT FOUND THEN
            RAISE EXCEPTION 'record met id % niet gevonden', a;
        END IF;
    
        -- record b de oude sort-waarde van a geven:
        UPDATE test SET sort = new_b WHERE id = b;
        IF  NOT FOUND THEN
            RAISE EXCEPTION 'record met id % niet gevonden', b;
        END IF;

        -- record a de oude sort-waarde van b geven:
        UPDATE test SET sort = new_a WHERE id = a;
        IF  NOT FOUND THEN
            RAISE EXCEPTION 'record met id % niet gevonden', a;
        END IF;

        EXCEPTION
            WHEN unique_violation THEN
                ok := false;
            WHEN not_null_violation THEN
                ok := false;
    END;

    RETURN ok;
END;
$BODY$
language plpgsql;

En de query om hem aan te roepen:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
SELECT switch(3,1);


Een heel verhaal, maar nu kun je records in de sortering van plaats laten wisselen. Mocht er wat fout gaan, krijg je een dikke error of een false retour, afhankelijk van wat er fout gaat. Dit mag je verder zelf uitwerken, je wilt uiteraard maar 1 soort foutmelding retour krijgen. Nu heb je alle mogelijkheden, dat laat zien wat er mogelijk is.

De index is een beetje bijzonder, voor de waarde 0 geldt geen UNIQUE, deze kun je dus gebruiken voor de noodzakelijke workaround. In voorgaande reacties zei ik nog dat je een hele hoge waarde kunt nemen, maar 0 is eigenlijk veel handiger. Dus even een UNIQUE met een uitzondering. Dat kan in PostgreSQL, dus maak je er ook gebruik van ;)

De transactie gaat nu ook goed, een sp werkt altijd transactioneel. En doordat de query bij een mislukking keihard op zijn muil gaat, wordt er door de sp een rollback uitgevoerd. Werkt dus uitstekend.

Wat kan SQL toch mooi zijn.
 
Arend a

Arend a

08/12/2008 01:14:00
Quote Anchor link
Hoi Frank,

Bedankt voor je uigebreide antwoord!

Ik heb het nog niet getest, inderdaad slim om de waarde 0 als tijdelijke waarde te reserveren. De reden om de tabel opeenvolgend te houden is omdat het dan voorspelbaar is in programmatuur dat nummer 4 degene is na nummer 3 en positie 5 degene 6 posities na nummer 4. Dit is met name handig als je niet wil wisselen, maar wil verplaatsen, (zie de move procedure die ik eerder geschreven heb.)

Nog even een andere vraag: is het mogelijk een procedure te herschrijven zodat het simpel op meerdere tabellen te gebruiken is? (ik heb nu steeds te tabel hardcoded in de procedure, maar het zou makkelijker zijn als het op meerdere tabellen toe te passen is zonder te gehele procedure te hoeven herschrijven.)
 
Frank -

Frank -

08/12/2008 13:06:00
Quote Anchor link
Ja hoor, kan prima, je moet alleen zorgen voor wat extra foutafhandeling in de sp omdat er meer fout kan gaan. Uurtje werk en je kunt er jaren plezier aan beleven.
 



Overzicht Reageren

 
 

Om de gebruiksvriendelijkheid van onze website en diensten te optimaliseren maken wij gebruik van cookies. Deze cookies gebruiken wij voor functionaliteiten, analytische gegevens en marketing doeleinden. U vindt meer informatie in onze privacy statement.