4

I have a MySQL database that looks like this:

ID        TEXT        PARENTID
20        Item1        null
23        Item2        20
27        Item3        20
80        Item4        27

What I want is to retreive this data in an array like this:

Array ( 
[20] => Array ( [text] => Item1 [parentID] => ) 
[23] => Array ( [text] => Item2 [parentID] => 20 ) 
[27] => Array ( [text] => Item3 [parentID] => 20 ) 
[80] => Array ( [text] => Item4 [parentID] => 27 )
);

Notice that the key values represent the value of the id column in the table.

I have tried makin an array inside a mysql loop (I am still in the process of learning MySQLi, and hopefully it'll stick pretty soon but this example is in the old MySQL):

$hent_folder = mysql_query("SELECT id, text, parentID FROM folders");   
while($row = mysql_fetch_assoc($hent_folder))
    {
        $array[] = $row;
    }

The result here of course generates "automatic" key values and not the values from the ID column as wanted plus it puts the ID column as a part of the inside array.

Is there a way or workaround to succeed here?

I hope someone can lead me in the right direction...

----- EDIT ------

I have replaced

$array[] = $row;

with

$array[$row['ID']] = $row;

But it still does not return the above wanted result. It returns this:

Array ( 
[0] => Array ( [id] => 20 [text] => Item1 [parentID] => ) 
[1] => Array ( [id] => 23 [text] => Item2 [parentID] => 20 ) 
[2] => Array ( [id] => 27 [text] => Item4 [parentID] => 20 ) 
[3] => Array ( [id] => 80 [text] => Item4 [parentID] => 27 )
);
6
  • 3
    $array[$row['ID']] = $row; Commented Nov 19, 2015 at 13:22
  • 1
    $array[$row['id']] = $row; Commented Nov 19, 2015 at 13:22
  • if your new to php then my first suggestion is to drop mysql_* function and to look into pdo and mysqli Commented Nov 19, 2015 at 13:25
  • the OP is actually already doing that as said in his actual question gentlemen, mysql_* and mysqli_* aren't very different but again, not everyone is equally experienced otherwise we wouldn't need SO Commented Nov 19, 2015 at 13:33
  • @SidneyLiebrand - OP wasn't doing that according to the original question, that has been added since..... though the original gave no indication of case in column names, and this is a now a case-sensitivity issue Commented Nov 19, 2015 at 17:22

4 Answers 4

6

This is doable as an associative array.

All you have to do is change

$array[] = $row

to

$array[$row['ID']] = $row

You need to make sure that the ID column in your database is unique so that the associative array doesn't overwrite keys (in which case only the last record with duplicate ID's would remain)

EDIT (19-11-2015)

Also about your 'mysql loop' - it's just a regular PHP while loop that loops through records given by either mysql_* or mysqli_* functions. You're looping through the returned result from executing an sql statement on the database which just fetches and formats rows for you in a certain way.

MySQL and MySQLi are two different things but the SQL they use is no different (except for maybe prepared statements?). Learning SQL is what you're going to do and to execute it you're going to use mysqli_* from now on since mysql_* functions are deprecated

I just wanted to point those things out to clear out some confusion you might already have or will have in the future. :)

For more reading on mysqli read the php.net manual, it's all a bit complex if you're just starting but that's fine - understand what you can and work to understand what you can't.


EDIT 2 (19-11-2015)

the indexes in your $row array are case-sensitive so ID and id are something different entirely. one will add up to an undefined index error.

I noticed in your output that the id key is actually lowercase so I would try changing to that.

Good luck!

Sign up to request clarification or add additional context in comments.

9 Comments

Thanks @Sidney - I have tried this, but unfortunately this does not work. It returns everything from the table but still with the array key values from 0 to 3. My ID column is setup as an integer with auto increment and unique so I think that should do it. I am not sure what I am doing wrong then?
This is definitely the way to make it work @MazeyMazey, I am failing to understand why it wouldn't since I've done this a billion times. Could you update your question with the new code and the new error output perhaps?
Hi @Sidney - There are no errors. It works, but the value given for each array-result is numbered from 0 and up instead of the value of my id column in my table. Result: Array ( [0] => Array ( [text] => Item1 [parentID] => ) I wanted it to output: Array ( [20] => Array ( [text] => Item1 [parentID] => )
@MazeyMazey I understand your problem completely, it just baffles me - it shouldn't happen unless there's some bug in PHP concerning this which I highly doubt
@sidneyliebrand op is calling array_values for some unknown reason, so he is stripping the array keys himself
|
3

You can achieve this result easily using PDO. It has a fetch mode called PDO::FETCH_GROUP and when combined with PDO::FETCH_ASSOC will produce you the array that you want.

$pdo = new PDO("mysql:host=$host;dbname=$db;charset=utf8mb4", $user, $pass, [
    \PDO::ATTR_ERRMODE => \PDO::ERRMODE_EXCEPTION,
    \PDO::ATTR_EMULATE_PREPARES => false
]);

$stmt = $pdo->prepare('SELECT id, text, parentID FROM folders');
$stmt->execute();
$array = $stmt->fetchAll(PDO::FETCH_UNIQUE|PDO::FETCH_ASSOC);

Comments

0
// Multidimensional array. 
// main array by id with text and parent in secondary array
// tryed going by the second diagram

$arr = array();
$hent_folder = mysql_query("SELECT id, text, parentID FROM folders");

while($row = mysql_fetch_array($hent_folder))
{
    $arr[$row['id']]['text']     = $row['text'];
    $arr[$row['id']]['parentID'] = $row['parentID'];
}

6 Comments

Thanks @Ian - this does display the content inside the array correct without the ID, but still the array key values are numerically made and not the ID values unfortunately...
theres gotta be something else wrong, aside from me usin mysqli instead of mysql I've used this exact looking code a hundred times
you mentioned that your ids are auto increment, perhaps they are the same values as the array keys?
It does work @Ian, I mean there is no error in it, but the first array value is just not the ID value: [0] => Array ( [text] => Item1 [parentID] => ) The [0] should have been [20].
I have checked this - the values in the ids in the column is 1,5,59,60,61,62 etc. and not the 0,1,2,3 as displayed when printing the array.
|
-1

Below code can be used to produce an array of the ids from SQL response :

$ids_array = array();

foreach($idsFromDb as $row)
{
    $ids_array[] = $row['id'];
}

echo print_r($ids_array[0]) ;

1 Comment

This code will produce an array of the ids, but that is not what the question asked for.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.