לוגו אתר Fresh          
 
 
  אפשרות תפריט  ראשי     אפשרות תפריט  צ'אט     אפשרות תפריט  מבזקים     אפשרות תפריט  צור קשר     חץ שמאלה ‎print ‎"Hello World!"; if‎ ‎not rules.‎know ‎then rules.‎read(); חץ ימינה  

לך אחורה   לובי הפורומים > מחשבים > תכנות ובניית אתרים
שמור לעצמך קישור לדף זה באתרי שמירת קישורים חברתיים
תגובה
 
כלי אשכול חפש באשכול זה



  #1  
ישן 11-11-2005, 06:33
  ישראל K ישראל K אינו מחובר  
 
חבר מתאריך: 25.08.03
הודעות: 9,114
נסיון לשרשר שאילתות מוביל לשגיאה

כדי לחסוך במשתנים, יצירת טבלה וירטואלית, או כל טכניקה אחרת שמצריכה מספר העברות בין המסד לשפת התסריט, כשבעצם הגורם הוא שבהתאם לשאילתה אחתשפת התסריט נותן תוצאה המשפיע על שאילתה אחרת וכו'.
נסיתי לשרשר את כל השאילתות יחד, אך אני מקבל הודעת שגיאה.

לנוחיותכם אני מציג את השאילתות במספר צורות:
1. השאילתה כפי שהיא בקוד, מחרוזת ארוכה הנשלחת למסד נתונים.
קוד:
SELECT * FROM popups WHERE ok=1 AND (`count_times` = NULL or `count_times` < `times`) LIMIT FLOOR(1+(RAND()*((count(ok) FROM popups WHERE ok=1 AND (`count_times` = NULL or `count_times` < `times`))-1+1))) 1;

2. השאילתה במספר שורות, בדומה להזחות ש-phpmyadmin יוצר.
קוד PHP:
 SELECT *
FROM popups
WHERE ok 
=1
AND (
    `
count_times` = NULL
    
OR `count_times` < `times`
LIMIT FLOOR+ ( RAND( ) * ( (
    
countok FROM popups WHERE ok =AND (
    `
count_times` = NULL OR `count_times` < `times`
    ) ) -
+) )
)


3. כל חלק בשאילתה בנפרד, כדי שתבינו "מה פה קורה פה", ו"מי נגד מי".
a. השאילתה מחזירה את מספר הרשומות העומדים בקריטריונים בהתאם לתנאי ב-WHERE.
קוד:
SELECT count(ok) as meter FROM popups WHERE ok=1 AND (`count_times` = NULL or `count_times` < `times`);


b. השאילתה מחזירה מספר אקראי בין 1 ל-a, כש-a הוא התוצאה שהתקבלה בשאילתה הקודמת.
קוד:
SELECT FLOOR(1+(RAND()*(a-1+1)));


c. השאילתה שולפת שורה אחת ! אקראית כשהערך הראשון של ה-LIMIT קובע איזו שורה לשלוף. b זה התוצאה של שאילתה b.
קוד:
SELECT * FROM popups WHERE ok=1 AND (`count_times` = NULL or `count_times` < `times`) LIMIT b 1;


השגיאה:
קוד:
#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'FLOOR(1+(RAND()*((count(ok) FROM popups WHERE ok=1 AND (`count_times` = NULL or ' at line 1

מידע טכני: מסד נתונים mysql, שפת התסריט PHP.

תודה מראש לכל העוזרים

נערך לאחרונה ע"י ישראל K בתאריך 11-11-2005 בשעה 06:35.
תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
תגובה

כלי אשכול חפש באשכול זה
חפש באשכול זה:

חיפוש מתקדם
מצבי תצוגה דרג אשכול זה
דרג אשכול זה:

מזער את תיבת המידע אפשרויות משלוח הודעות
אתה לא יכול לפתוח אשכולות חדשים
אתה לא יכול להגיב לאשכולות
אתה לא יכול לצרף קבצים
אתה לא יכול לערוך את ההודעות שלך

קוד vB פעיל
קוד [IMG] פעיל
קוד HTML כבוי
מעבר לפורום



כל הזמנים המוצגים בדף זה הם לפי איזור זמן GMT +2. השעה כעת היא 06:16

הדף נוצר ב 0.03 שניות עם 12 שאילתות

הפורום מבוסס על vBulletin, גירסא 3.0.6
כל הזכויות לתוכנת הפורומים שמורות © 2024 - 2000 לחברת Jelsoft Enterprises.
כל הזכויות שמורות ל Fresh.co.il ©

צור קשר | תקנון האתר