Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> Rozbijanie danych z jednej kolumny na kilka
biz00n
post
Post #1





Grupa: Zarejestrowani
Postów: 9
Pomógł: 0
Dołączył: 29.12.2003

Ostrzeżenie: (0%)
-----


Witam

Mam w tabeli pole z wartoscią ;yyy ;zzz; jjj; fff

Chciałbym zrobic na podstawie tego tabele z wartościami

pole1 pole2 pole3 pole4
yyy zzz jjj fff

Ma ktos pomysł?

Z góry dzięki

P.S. chodzi o MSSQL 2000
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 6)
seaquest
post
Post #2





Grupa: Przyjaciele php.pl
Postów: 790
Pomógł: 7
Dołączył: 6.02.2003
Skąd: Polska

Ostrzeżenie: (0%)
-----


Wątek zamykam, póki nie dostanę na PW odpowiedniej nazwy tematu. Do PW proszę też dołączyć link do wątku.

Wątek został otwarty.

Ten post edytował seaquest 1.03.2006, 12:07:44
Go to the top of the page
+Quote Post
nameless
post
Post #3





Grupa: Zarejestrowani
Postów: 78
Pomógł: 0
Dołączył: 16.12.2003
Skąd: Tychy

Ostrzeżenie: (0%)
-----


  1. declare @i int
  2. declare @j int
  3. declare @Col nvarchar(255)
  4. declare @Col1 nvarchar(255)
  5. declare @Col2 nvarchar(255)
  6. declare @Col3 nvarchar(255)
  7. declare @Col4 nvarchar(255)
  8. declare Kursor scroll cursor
  9. FOR SELECT Col
  10. FROM Col
  11. open Kursor
  12. fetch next
  13. FROM Kursor
  14.  
  15. INTO @Col
  16. while @@fetch_status=0
  17. begin SET @Col1=''
  18. SET @Col2=''
  19. SET @Col3=''
  20. SET @Col4=''
  21. SET @i=1
  22. SET @j=charindex(';', @Col, @i)
  23. IF @j>0
  24. SET @Col1=substring(@Col, @i, @j-@i)
  25. else
  26. begin SET @j=len(@Col)
  27. SET @Col1=substring(@Col, @i, @j-@i+1)
  28. end
  29. SET @i=@j+1
  30. SET @j=charindex(';', @Col, @i)
  31. IF @j>0
  32. SET @Col2=substring(@Col, @i, @j-@i)
  33. else
  34. begin SET @j=len(@Col)
  35. SET @Col2=substring(@Col, @i, @j-@i+1)
  36. end
  37. SET @i=@j+1
  38. SET @j=charindex(';', @Col, @i)
  39. IF @j>0
  40. SET @Col3=substring(@Col, @i, @j-@i)
  41. else
  42. begin SET @j=len(@Col)
  43. SET @Col3=substring(@Col, @i, @j-@i+1)
  44. end
  45. SET @i=@j+1
  46. SET @j=len(@Col)
  47. SET @Col4=substring(@Col, @i, @j-@i+1)
  48. INSERT
  49. INTO Cols
  50. VALUES(@Col1, @Col2, @Col3, @Col4)
  51. fetch next
  52. FROM Kursor
  53.  
  54. INTO @Col
  55. end
  56. close Kursor
  57. deallocate Kursor
Go to the top of the page
+Quote Post
biz00n
post
Post #4





Grupa: Zarejestrowani
Postów: 9
Pomógł: 0
Dołączył: 29.12.2003

Ostrzeżenie: (0%)
-----


dzieki

rozumiem że robie z tego create procedure i co dalej mógłbys podpowiedziec (IMG:http://forum.php.pl/style_emoticons/default/biggrin.gif)
Go to the top of the page
+Quote Post
php programmer
post
Post #5





Grupa: Zarejestrowani
Postów: 1 045
Pomógł: 5
Dołączył: 8.11.2004
Skąd: trójmiasto

Ostrzeżenie: (0%)
-----


książkowy przypadek:
  1. <?php
  2.  
  3. $tablica = explode(';',$wiersz);
  4.  
  5. ?>


Ten post edytował php programmer 1.03.2006, 14:31:20
Go to the top of the page
+Quote Post
biz00n
post
Post #6





Grupa: Zarejestrowani
Postów: 9
Pomógł: 0
Dołączył: 29.12.2003

Ostrzeżenie: (0%)
-----


tak tylko że nie chce do tego zaprzegac php (IMG:http://forum.php.pl/style_emoticons/default/biggrin.gif)

chciałbym zrobic to odrazu na SQL'u (IMG:http://forum.php.pl/style_emoticons/default/biggrin.gif)
Go to the top of the page
+Quote Post
nameless
post
Post #7





Grupa: Zarejestrowani
Postów: 78
Pomógł: 0
Dołączył: 16.12.2003
Skąd: Tychy

Ostrzeżenie: (0%)
-----


uruchamiasz procedure albo wklejasz to co napisalem do query analizera i wykonujesz
oczywiscie najpierw musisz miec tabele z columna gdzie dane sa w postaci "aa;ss;dd"
i druga z odpowiednia iloscia kolmn
moj kawalek sqla to rozbije i przepisze do nowej tabeli
jesli potrzebujhesz to np uaktualniac za kazdym razem kiedy zmieneiaja sie dane w tabeli zrodlowej to zrob triggera
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 22.12.2025 - 00:36