Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> Mysql dziwne zachowanie OR
skowron-line
post
Post #1





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

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


Wiam, mam takie 2 tabele
Kod
invoice
-buyer_id
-paid 0 - niezaplacone, 1 - zaplacone

companies
-id_companies

i zapytanie
  1. SELECT
  2. invoices.buyer_id, invoices.companies_id, companies.id_companies
  3. FROM (invoices, companies)
  4. WHERE invoices.buyer_id = companies.id_companies
  5. AND
  6. (
  7. MONTH(invoices.invoice_date) = '8'
  8. AND YEAR(invoices.invoice_date) = '2012'
  9. )
  10. OR
  11. (
  12. invoices.payment_date < '2012-8-01'
  13. AND invoices.paid = 0
  14. )
  15. AND invoices.companies_id = 1

i teraz tak
Jeżeli tylko 1 część jest zgodna to zwraca 2 rekordy z pominięciem ostatniego warunku
  1. invoices.companies_id = 1

Jeżęli w bazie są rekordy zgodne z drugim nawiasem to zapytanie zwraca mi tyle rekordów ile jest w tabeli companies.

Co tu jest nie tak (IMG:style_emoticons/default/questionmark.gif)
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
maly_swd
post
Post #2





Grupa: Zarejestrowani
Postów: 744
Pomógł: 118
Dołączył: 14.02.2009
Skąd: poziome

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


A nie powinno byc tak?

  1. SELECT
  2. invoices.buyer_id, invoices.companies_id, companies.id_companies
  3. FROM (invoices, companies)
  4. WHERE invoices.buyer_id = companies.id_companies
  5. AND (
  6. ( MONTH(invoices.invoice_date) = '8' AND YEAR(invoices.invoice_date) = '2012')
  7. OR
  8. ( invoices.payment_date < '2012-8-01' AND invoices.paid = 0)
  9. ) AND invoices.companies_id = 1


Ten post edytował maly_swd 27.06.2012, 20:24:30
Go to the top of the page
+Quote Post

Posty w temacie


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: 26.09.2025 - 00:56