Fetstil Fetstil Kursiv Understrykning linje färgläggning tabellverk Punktlista Nummerlista Vänster Centrerat högerställt Utfyllt Länk Bild htmlmode
  • Forum & Blog
    • Forum - översikt
      • .Net
        • asp.net generellt
        • c#
        • vb.net
        • f#
        • silverlight
        • microsoft surface
        • visual studio .net
      • databaser
        • sql-server
        • databaser
        • access
        • mysql
      • mjukvara klient
        • datorer och komponenter
        • nätverk, lan/wan
        • operativsystem
        • programvaror
        • säkerhet, inställningar
        • windows server
        • allmänt
        • crystal reports
        • exchange/outlook
        • microsoft office
      • mjukvara server
        • active directory
        • biztalk
        • exchange
        • linux
        • sharepoint
        • webbservers
        • sql server
      • appar (win/mobil)
      • programspråk
        • c++
        • delphi
        • java
        • quick basic
        • visual basic
      • scripting
        • asp 3.0
        • flash actionscript
        • html css
        • javascript
        • php
        • regular expresssion
        • xml
      • spel och grafik
        • DirectX
        • Spel och grafik
      • ledning
        • Arkitektur
        • Systemutveckling
        • krav och test
        • projektledning
        • ledningsfrågor
      • vb-sektioner
        • activeX
        • windows api
        • elektronik
        • internet
        • komponenter
        • nätverk
        • operativsystem
      • övriga forum
        • arbete karriär
        • erbjuda uppdrag och tjänster
        • juridiska frågor
        • köp och sälj
        • matematik och fysik
        • intern information
        • skrivklåda
        • webb-operatörer
    • Posta inlägg i forumet
    • Chatta med andra
  • Konto
    • Medlemssida
    • Byta lösenord
    • Bli bonsumedlem
    • iMail
  • Material
    • Tips & tricks
    • Artiklar
    • Programarkiv
  • JOBB
  • Student
    • Studentlicenser
  • KONTAKT
    • Om pellesoft
    • Grundare
    • Kontakta oss
    • Annonsering
    • Partners
    • Felanmälan
  • Logga in

Hem / Tips & tricks

#1072 - Räknare i Oracle - en annan variant

Postat 2002-05-07 13:19:07 av Patrik Roos i Kategori Programmering, C#, Kommandon med 0 Kommentarer

Testtabell för exemplet
KUND
kundid number(5)
kundnamn varchar(25)

Tabellen CG_CODE_CONTROLS skapas enligt följande

CREATE TABLE CG_CODE_CONTROLS (
cc_domain varchar2(30) PRIMARY KEY,
cc_comment varchar2(240),
cc_next_value number(15) NOT NULL,
cc_increment number(15) NOT NULL);

där cc_domain är namnet på räknare, t.ex. "Kundid", cc_comment är en kommentar, cc_next_value är nästa värde för räknaren (första gången = startvärdet) och cc_increment är hur mycket som räknaren skall räknas upp med varje gång.

Därefter kan räknarna läggas in i tabellen t.ex enligt följande
INSERT INTO CG_CODE_CONTROLS VALUES ('Kundid', 'Räknare för kundid. Startvärde 1 och ökas med 1 för varje ny kund', 1,1);

Skapa triggern för räknaren
CREATE OR REPLACE TRIGGER KUND_COUNTER
BEFORE INSERT ON KUND FOR EACH ROW

DECLARE
next_value NUMBER;
increment NUMBER;

BEGIN
SELECT cc_next_value, cc_increment
INTO next_value, increment
FROM CG_CODE_CONTROLS
WHERE cc_domain = 'Kundid';

:new.kundid := next_value;

UPDATE CG_CODE_CONTROLS
SET cc_next_value = next_value + increment
WHERE cc_domain = 'Kundid';
END;

Därefter kan vi lägga till en post i tabellen kund
INSERT INTO KUND VALUES (Null, 'Kalle Anka');

posten kommer nu "automatiskt" att få ett nummer från CG_CODE_CONTROLS.

Sample:
Size:

Nyligen

  • 09:09 Vill du köpa medicinska tester?
  • 12:47 Vem beviljar assistansen – kommune
  • 14:17 Någon med erfarenhet av hemstädnin
  • 14:14 Bör man använda sig av en båtförme
  • 14:12 Finns det någon intressant hundblo
  • 14:25 Tips på verktyg för att skapa QR-k
  • 14:23 Tips på verktyg för att skapa QR-k
  • 20:52 Fungerer innskuddsbonuser egentlig

Sidor

  • Hem
  • Bli bonusmedlem
  • Läs artiklar
  • Chatta med andra
  • Sök och erbjud jobb
  • Kontakta oss
  • Studentlicenser
  • Skriv en artikel

Statistik

Antal besökare:
Antal medlemmar:
Antal inlägg:
Online:
På chatten:
4 569 153
27 952
271 704
1 182
0

Kontakta oss

Frågor runt konsultation, rådgivning, uppdrag, rekrytering, annonsering och övriga ärenden. Ring: 0730-88 22 24 | pelle@pellesoft.se

© 1986-2013 PelleSoft AB. Last Build 4.1.7169.18070 (2019-08-18 10:02:21) 4.0.30319.42000
  • Om
  • Kontakta
  • Regler
  • Cookies