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

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



  #1  
ישן 09-01-2012, 02:55
  משתמש זכר Espires Espires אינו מחובר  
 
חבר מתאריך: 21.11.06
הודעות: 3,992
הרג אותי הoop הזה, צריך עזרה במערך :)

אז כמו שראיתם בפוסט הקודם, התחלתי ללמוד קצת oop בימים האחרונים, וזה אחד הדברים שסיבכו אותי לגמרי, אבל אני לא רוצה לעצור, זה נראה מעניין והרבה יותר נוח.
אז הבעיה עכשיו היא שהפונקציה getposts מחזירה לי משום מה מערך "דפוק", מה זאת אומרת? אני יסביר אחרי הקוד:
קוד PHP:
 class userInfo extends DBConnect {
    private 
$id;

    
    function 
__construct($id) {
        
parent::__construct();
        
$this->id $id;
    }
    
    public function 
getPosts() {
        
$q mysql_query("SELECT * FROM codes WHERE user_id = '$this->id'");
        
$q mysql_fetch_array($q);
        return 
$this->query $q;
    }
    
}

$db = new userInfo(1);
$db->getPosts();
print_r($db->query); 


אז מה שבעצם קורה זה שחוזר לי מערך כזה:
קוד PHP:
 Array
(
    [
0] => 1
    
[id] => 1
    
[1] => 1
    
[user_id] => 1
    
[2] => 1325790769
    
[created_at] => 1325790769



של key יוצא לי משום מה כפול... ובאמת שחיפשתי הרבה (הרבהה) את הבעיה ועדיין לא הבנתי אותה...
אשמח לעזרה שלכם!
[אה כן, ולילה טוב לכל השועלים]
תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
  #2  
ישן 09-01-2012, 06:33
  שימיadmin שימי אינו מחובר  
מנהל פורומי "תכנות ובניית אתרים" ו"חומרה ורשתות"
 
חבר מתאריך: 25.10.01
הודעות: 42,775
בתגובה להודעה מספר 1 שנכתבה על ידי Espires שמתחילה ב "הרג אותי הoop הזה, צריך עזרה במערך :)"

אין שום קשר ל OOP, אלא לכך שאתה לא קורא את דפי ההסבר של הפונקציות שבהן אתה משתמש...

תחליף את mysql_fetch_array עם mysql_fetch_assoc, וראה איזה פלא...

נ.ב. קונספט מעניין, ביצוע הצבות במהלך return. אני לא הייתי עושה את זה.

נ.ב.2. הקוד שלך מושך רק רשומה אחת. אם יש יותר, לא תקבל את כולן. עכשיו תראה איך עושים את כל זה בלי OOP, מקבלים קוד קצר בהרבה, שאפילו מושך יותר מרשומה אחת:

קוד PHP:
 function dbconnect() { } # תעשה את זה גם פונקציה במקום קלאס

function getPosts($id)
 {
  
$q mysql_query("SELECT * FROM codes WHERE user_id = '$id'");
  while (
$r mysql_fetch_assoc($q))
   
$arr[] = $r;
  return 
$arr;
 }

dbconnect();
print_r(getPosts(1)); 


בהחלט, אין ספק, OOP זה "הרבה יותר נוח"
_____________________________________
תמונה שהועלתה על ידי גולש באתר ולכן אין אנו יכולים לדעת מה היא מכילה
נמאס לכם לזכור סיסמאות? לחצו כאן!

תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
  #5  
ישן 09-01-2012, 21:10
  שימיadmin שימי אינו מחובר  
מנהל פורומי "תכנות ובניית אתרים" ו"חומרה ורשתות"
 
חבר מתאריך: 25.10.01
הודעות: 42,775
בתגובה להודעה מספר 4 שנכתבה על ידי Espires שמתחילה ב "י'אלללה שתי תותחים אתם..."

אתה בטוח שקראת?
ציטוט:
במקור נכתב על ידי http://php.net/mysql_fetch_array
Return Values

Returns an array of strings that corresponds to the fetched row, or FALSE if there are no more rows. The type of returned array depends on how result_type is defined. By using MYSQL_BOTH (default), you'll get an array with both associative and number indices. Using MYSQL_ASSOC, you only get associative indices (as mysql_fetch_assoc() works), using MYSQL_NUM, you only get number indices (as mysql_fetch_row() works).

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

תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
תגובה

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

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

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

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



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

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

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

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