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

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



  #4  
ישן 07-07-2010, 12:01
  ישראל K ישראל K אינו מחובר  
 
חבר מתאריך: 25.08.03
הודעות: 9,114
בתגובה להודעה מספר 1 שנכתבה על ידי CallMeYossi שמתחילה ב "הגבלת תוצאות ה-JOIN"

מס' פתרונות לא נוחים ולא יעילים במיוחד:

1. להשתמש בתת שאילתה ובשרשור מחרוזות (כדוגמת: CONCAT_GROUP, || או פונקציית/תחביר שרשור אחרת).
לדוגמה:
קוד:
SELECT (SELECT c.id || "\n" || c.name || "\n" || i.id || "\n" || i.title FROM categories c JOIN items i ON c.id=i.category WHERE c.id=1) AS C1, (SELECT c.id || "\n" || c.name || "\n" || i.id || "\n" || i.title FROM categories c JOIN items i ON c.id=i.category WHERE c.id=2) AS C2, (SELECT c.id || "\n" || c.name || "\n" || i.id || "\n" || i.title FROM categories c JOIN items i ON c.id=i.category WHERE c.id=2) AS C3 LIMIT 4

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

2. שימוש במספר שאילתות נפרדות וחיבורם באמצעות UNION.
קוד:
SELECT c.id AS catid, c.name AS catname, i.id, i.title FROM categories c JOIN items i ON c.id=i.category WHERE c.id=1 LIMIT 4 ORDER BY c.displayorder DESC UNION SELECT c.id AS catid, c.name AS catname, i.id, i.title FROM categories c JOIN items i ON c.id=i.category WHERE c.id=2 LIMIT 4 ORDER BY c.displayorder DESC UNION SELECT c.id AS catid, c.name AS catname, i.id, i.title FROM categories c JOIN items i ON c.id=i.category WHERE c.id=3 LIMIT 4 ORDER BY c.displayorder DESC


3. שימוש בתהליך פנימי/מאוחסן.
מישהו מוזמן לכתוב פורצדורה, אשמח אם היא תתאים ל-MySQL ו-SQLiteת בהם נכון להיום עיקר השימוש שלי
תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
תגובה

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

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

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

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



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

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

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

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