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 / Forum översikt / inlägg

Posta nytt inlägg


Uppdatera befintlig databas.

Postades av 2005-01-23 17:08:41 - Jesper Alvermark, i forum php, Tråden har 9 Kommentarer och lästs av 730 personer

Tjena, håller på att bli galen snart! Lyckas inte komma fram till hur jag ska lösa ett problem.

Jag har ett befintligt forum, Inläggen får ett ID och ett P_ID (parent_ID) för att hålla ordning på tråden. Nu vill jag lägga till en kolumn med T_ID (top_ID eller Topic_ID om man så vill.)

Det jag behöver är alltså ett engångs-script som går igenom alla inlägg och uppdaterar kolumnen T_ID där det behövs.

Jag vet vilka alla huvudinlägg är eftersom de har P_ID = 0

I ett exempel på en "rak" tråd vill jag göra såhär:

ID 1 P_ID 0
ID 2 P_ID 1
ID 3 P_ID 2

Vill jag ska bli

ID 1 P_ID 0 T_ID 0
ID 2 P_ID 1 T_ID 1
ID 3 P_ID 2 T_ID 1

Hur kan man lösa det? Tacksam för all hjälp!


Svara

Sv: Uppdatera befintlig databas.

Postades av 2005-01-23 18:10:33 - Per Persson

Vad använder du för databas?


Svara

Sv: Uppdatera befintlig databas.

Postades av 2005-01-23 18:15:10 - Johan Djupmarker

Detta är skrivet ur huvudet, så du bör definitivt testa på en kopia av databasen först (om det nu är rätt syntax till en början...).

Kör först:
UPDATE tabell SET T_ID = P_ID

Kör sedan denna så många gånger som djupet på den längsta tråden:
UPDATE tabell a INNER JOIN tabell b ON a.T_ID = b.ID SET a.T_ID = b.P_ID WHERE b.P_ID > 0

Om jag inte har tänkt fel kommer denna uppdatering flytta T_ID upp en nivå i "trädet" för varje gång den körs.

För att sedan få rätt på "huvudinläggen" behöver du köra:
UPDATE tabell SET T_ID = ID WHERE P_ID = 0

/Johan


Svara

Sv:Uppdatera befintlig databas.

Postades av 2005-01-23 18:29:51 - Jesper Alvermark

Sorry glömde, det är en MySQL-databas.


Svara

Sv:Uppdatera befintlig databas.

Postades av 2005-01-23 19:04:34 - Per Persson

Om du har MySQL 4.0 eller senare, kan Johans lösning vara värd att pröva. För tidigare versioner fungerar inte UPDATE ... INNER JOIN ...


Svara

Sv: Uppdatera befintlig databas.

Postades av 2005-01-23 19:06:19 - Jesper Alvermark

Johans lösning verkar fungera faktiskt! (Jag kör MySQL 4.0.16)

Tusen tack!


Svara

Sv:Uppdatera befintlig databas.

Postades av 2005-01-23 19:08:31 - Per Persson

Fast jag undrar om det inte skall vara <b>SET a.T_ID = b.T_ID</b> i stället för <b>SET a.T_ID = b.P_ID</b>. Jag förstår nämligen inte hur värdet på T_ID skulle kunna vandra ut i trädet annars...


Svara

Sv: Uppdatera befintlig databas.

Postades av 2005-01-23 19:50:08 - Johan Djupmarker

> Fast jag undrar om det inte skall vara <b>SET a.T_ID = b.T_ID</b> i stället för <b>SET a.T_ID = b.P_ID</b>.

Vet inte om jag har detta helt klart för mig själv än, men jag TROR att mitt förslag vandrar en nivå i taget medans din "samlar ihop" inläggen och troligtvis inte kräver lika många "körningar". Men jag orkar inte sätt mig in i detta helt nu :)

Min tanke var i alla fall att man skulle "peka" på inlägge ovanför, sedan på inlägget ovanför det osv.

/Johan


Svara

Sv:Uppdatera befintlig databas.

Postades av 2005-01-23 21:59:18 - Jesper Alvermark

Insåg just att det hela är gjort i onödan. I och med att jag redan har koll på vilka huvudinläggen är så är en extra kolumn överflödig. Det var det jag ville åstadkomma och det hade jag i princip redan färdigt i mina funktioner utan att veta om det.

Men det var ju intressant att se hur man kunde lösa det i alla fall. Nu vet jag lite mer om hur man kan uppdatera en databas. :-)


Svara

Sv: Uppdatera befintlig databas.

Postades av 2005-01-23 22:49:27 - Per Persson

Jag trodde att du ville göra detta av prestandaskäl...


Svara

Nyligen

  • 14:24 CBD regelbundet?
  • 14:23 CBD regelbundet?
  • 14:22 Har du märkt några verkliga fördel
  • 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

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 615
27 953
271 709
518
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