Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [MYSQL] dodanie indexu
jancu
post
Post #1





Grupa: Zarejestrowani
Postów: 17
Pomógł: 0
Dołączył: 18.08.2007

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


witam.

mam tabele, ktora zostala utworzona nastepujacym poleceniem:

  1. CREATE TABLE `namemap` (
  2. `info_hash` varchar(40) NOT NULL DEFAULT '',
  3. `filename` varchar(250) NOT NULL DEFAULT '',
  4. `url` varchar(250) NOT NULL DEFAULT '',
  5. `info` varchar(250) NOT NULL DEFAULT '',
  6. `data` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
  7. `size` bigint(20) NOT NULL DEFAULT '0',
  8. `comment` text,
  9. `category` int(10) UNSIGNED NOT NULL DEFAULT '6',
  10. `external` enum('yes','no') NOT NULL DEFAULT 'no',
  11. `announce_url` varchar(100) NOT NULL DEFAULT '',
  12. `uploader` int(10) NOT NULL DEFAULT '1',
  13. `lastupdate` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
  14. `anonymous` enum('true','false') NOT NULL DEFAULT 'false',
  15. `lastsuccess` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
  16. PRIMARY KEY (`info_hash`),
  17. KEY `filename` (`filename`),
  18. KEY `category` (`category`),
  19. KEY `uploader` (`uploader`)
  20. ) TYPE=MyISAM;


ma ona juz wiele wpisow. jak teraz dodac do tej tabeli jakis index autoincrement?
Go to the top of the page
+Quote Post
Pawel_W
post
Post #2





Grupa: Zarejestrowani
Postów: 1 675
Pomógł: 286
Dołączył: 15.06.2009
Skąd: Wieliczka

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


auto increment
  1. <?php
  2. ALTER TABLE `namemap` CHANGE `nazwa_pola` `nazwa_pola` NOT NULL AUTO_INCREMENT
  3. ?>

primary key
  1. <?php
  2. ALTER TABLE `namemap` ADD PRIMARY KEY ( `info_hash` )
  3. ?>

i razem ( nie wiem czy zadziała ;o)
  1. <?php
  2. ALTER TABLE `namemap` CHANGE `nazwa_pola` `nazwa_pola` NOT NULL AUTO_INCREMENT, ADD PRIMARY KEY ( `info_hash` )
  3. ?>
Go to the top of the page
+Quote Post
jancu
post
Post #3





Grupa: Zarejestrowani
Postów: 17
Pomógł: 0
Dołączył: 18.08.2007

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


niestety, zaden z przykladow nie dziala.

Chcialem dodac do tej tabeli pole ID, przypominam, ze baza nie jest pusta.
Go to the top of the page
+Quote Post
melkorm
post
Post #4





Grupa: Zarejestrowani
Postów: 1 366
Pomógł: 261
Dołączył: 23.09.2008
Skąd: Bydgoszcz

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


  1. ALTER TABLE `namemap` ADD `pole_autoincrement` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY FIRST ;
Go to the top of the page
+Quote Post
jancu
post
Post #5





Grupa: Zarejestrowani
Postów: 17
Pomógł: 0
Dołączył: 18.08.2007

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


phpMyAdmin // //
Błąd
zapytanie SQL:

ALTER TABLE `namemap` ADD `pole_autoincrement` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY FIRST

MySQL zwrócił komunikat: http://dev.mysql.com/doc/refman/5.0/en/err...ges-server.html

#1068 - Zdefiniowano wiele kluczy podstawowych
Go to the top of the page
+Quote Post
melkorm
post
Post #6





Grupa: Zarejestrowani
Postów: 1 366
Pomógł: 261
Dołączył: 23.09.2008
Skąd: Bydgoszcz

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


Bo możesz mieć tylko 1 pole podstawowe,a pole auto_increment (jak sypie błędem mysql) musi być primary.
Go to the top of the page
+Quote Post
jancu
post
Post #7





Grupa: Zarejestrowani
Postów: 17
Pomógł: 0
Dołączył: 18.08.2007

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


czyli co zrobic z dotychczasowym: PRIMARY KEY (`info_hash`),
Go to the top of the page
+Quote Post
melkorm
post
Post #8





Grupa: Zarejestrowani
Postów: 1 366
Pomógł: 261
Dołączył: 23.09.2008
Skąd: Bydgoszcz

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


Zrób go jako 'unique' (jednoznaczny) i wtedy dodaj to zapyttanie które podalem wcześniej.
Go to the top of the page
+Quote Post
jancu
post
Post #9





Grupa: Zarejestrowani
Postów: 17
Pomógł: 0
Dołączył: 18.08.2007

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


dzieki wielkie stary, a tyle sie meczylem. wielkie piwo.

Bardzo mi pomogles, ale mam jeszcze jedno pytanie.

Mam jeszcze jedna tabele w tej samej bazie danych:

  1. CREATE TABLE `summary` (
  2. `info_hash` char(40) NOT NULL DEFAULT '',
  3. `dlbytes` bigint(20) UNSIGNED NOT NULL DEFAULT '0',
  4. `seeds` int(10) UNSIGNED NOT NULL DEFAULT '0',
  5. `leechers` int(10) UNSIGNED NOT NULL DEFAULT '0',
  6. `finished` int(10) UNSIGNED NOT NULL DEFAULT '0',
  7. `lastcycle` int(10) UNSIGNED NOT NULL DEFAULT '0',
  8. `lastSpeedCycle` int(10) UNSIGNED NOT NULL DEFAULT '0',
  9. `speed` bigint(20) UNSIGNED NOT NULL DEFAULT '0',
  10. PRIMARY KEY (`info_hash`)
  11. ) TYPE=MyISAM;


zawartosc pola info_hash jest identyczna jak w poprzedniej tabeli. Chce usunac ta tabele i dane z tej tabeli skopiowac do tej poprzedniej aby wszystko bylo w jednej i moje pytanie. Jak skopiowac wszystko z tej tabeli do tej poprzedniej?

Ten post edytował jancu 7.07.2009, 19:09:56
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: 24.08.2025 - 13:14