Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [php] sprawdzanie istnienia danych w bazie przed ich dodaniem
mpps
post 17.02.2007, 00:18:38
Post #1





Grupa: Zarejestrowani
Postów: 242
Pomógł: 0
Dołączył: 14.03.2003
Skąd: Szczecin

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


witam,
próbuję sprawdzić istnienie dodawanych danych w bazie i wyświetlić informację jeśli dane już istnieją lub dodać dane, jeśli ich w bazie nie ma.
mam coś takiego:
  1. <?php
  2. $sql_query = ("select * from tabela");
  3. $row = mysql_query($sql_query);
  4. while($dane_w_bazie = mysql_fetch_array($row)){
  5. $dane=$dane_w_bazie[1];
  6. if($add_dane==$dane){ //pobierane metodą $_POST
  7. echo(' dane są w bazie');
  8. }
  9. else{
  10. echo(' można dodać dane');
  11. }
  12. }
  13. ?>

skrypt skróciłem, bo chodzi mi o samą konstrukcję zapytania - reszta działa.
problem w tym, że w ten sposób skonstruowane zapytanie powoduje, że przy znalezieniu takich samych danych jak dodawane, wykonana zostaje zarówno instrukcja if jak i else i otrzymuję info:
'Duplicate entry 'aaa' for key 1' ('aaa' wpisuję w pole formularza).
oczywiście, jeśli danych w bazie nie ma, to dodają się bez problemu.
może 'while' nie jest tutaj najszczęśliwsze?

pozdrawiam


--------------------
www.mpps.pl
park maszynowy: apache 2.2.22 | php 5.4.0 | MySQL 5.0.10 | phpMyAdmin 3.5.0 | notepad ++ | pilsner urquell
Go to the top of the page
+Quote Post
skowron-line
post 17.02.2007, 10:29:04
Post #2





Grupa: Zarejestrowani
Postów: 4 340
Pomógł: 542
Dołączył: 15.01.2006
Skąd: Olsztyn/Warszawa

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


a nie lepiej tak

  1. <?php
  2. select * from tabela where nazwa = $nazwa and nazwa2 = $nazwa2
  3. ?>

i sprawdzasz mysql_num_rows ile zwroci zapytanie rekordow i jezeli wiecej niz 0 to znaczy ze istnieje taki rekord w bazie


--------------------
I'm so fast that last night I turned off the light switch in my hotel room and was in bed before the room was dark - Muhammad Ali.
Peg jeżeli chcesz uprawiać sex to dzieci muszą wyjść, a jeżeli chcesz żeby był dobry ty też musisz wyjść - Al Bundy.

QueryBuilder, Mootools.net, bbcradio1::MistaJam
http://www.phpbench.com/
Go to the top of the page
+Quote Post

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

 



RSS Wersja Lo-Fi Aktualny czas: 14.07.2025 - 14:46