Jump to content

Recommended Posts

Hello

 

I've got two tables, one of the rows has the same name in both tables.

 

When I try to echo the rows it stops working. How do I echo a row from a specific table?

 

while( $i < $row = mysql_fetch_array($feed_query, $votefeed_query))
  {
  
  echo $row['post'] . "<br>";
  echo $row['username'] . "<br>";

Link to comment
https://forums.phpfreaks.com/topic/241411-row-name-clashing/
Share on other sites

while( $i < $row = mysql_fetch_array($feed_query, $votefeed_query))
  {
  
  echo $row['post'] . "<br>";
  echo $row['username'] . "<br>";

 

if both your arguments in your mysql_fetch_array function actually are queries...it won't work, can you post more of your code please

Link to comment
https://forums.phpfreaks.com/topic/241411-row-name-clashing/#findComment-1240066
Share on other sites

In addition to what AyKay47 stated (i.e. you can use mysql_fetch_array() on two different query results) the "$i < " in your while() clause makes no sense.

 

one of the rows has the same name in both tables

 

Then do a single query using a JOIN between the tables using the name value to match up the records.

Link to comment
https://forums.phpfreaks.com/topic/241411-row-name-clashing/#findComment-1240090
Share on other sites

Basically here is what I am trying to do.

 

So far I have set up a friends system. Here is my table layout.

 

User

id

1

2

3

4

username

John

Billy

Jacob

Tina

password

eqfnj1k3

123ejkn13

132kjenf

123ekn

email

[email protected]

[email protected]

[email protected]

[email protected]

 

Friends

User_id

1

2

3

4

1

4

Friend_id

2

1

4

3

4

1

 

Posts

Post_id

1

2

3

4

Username_id

2

1

4

3

 

post

Hello I'm billy

Hello I'm John

Hello I'm Tina

Hello I'm Jacob

 

So John is friends with Billy and Tina.

Jacob is friends with Tina.

 

If John posts something, it will only be viewable by his friends, billy & tina.

(All the above has already been setup, the next bit is what I'm stuck on)

 

Tina has the ability to share John's post.

If she shares it, it will be viewable by all her friends. (Jacob)

How do I go about doing this?

 

I've setup a new table, I'm just not sure how I would go about putting it in my query.

 

posts_share

Share_id

1

2

3

User_id

1

4

3

Post_id

21

33

45

 

Here is the SQL query I am using, to display posts to friends.

$friendfeed = "SELECT Posts.post, Users.username FROM Posts, Friends, Users, Posts_share WHERE Posts.username_id = Users.id AND Friends.user_id = $user AND Friends.friend_id = Posts.username_id";

$i = "0";
while( $i < $row = mysql_fetch_array($friendfeed_query))
  {
  echo $row['post'] . "<br>";
  echo $row['username'] . "<br>";
  }?>

 

 

Link to comment
https://forums.phpfreaks.com/topic/241411-row-name-clashing/#findComment-1240168
Share on other sites

I have figured out how to display all the shared posts to friends. The only issue is how do I combine both queries into one output.

 

$friendfeed is the query for displaying all the friends posts

$friendshare is the query for displaying all the shared posts

 

How do I combine both queries? I've tried using OR either I'm not using it correctly or that does not work.

 

$friendfeed = "SELECT * FROM Posts, Friends, Users WHERE Posts.username_id = Users.id AND Friends.user_id = $user AND Friends.friend_id = Posts.username_id";
$friendfeed_query = mysql_query($friendfeed);

$friendshare = "SELECT * FROM Posts, Users, Posts_share, Friends WHERE Posts.username_id = Users.id AND Posts_share.user_id = Friends.friend_id AND Friends.user_id = $user AND Posts_share.post_id = Posts.post_id";
$friendshare_query = mysql_query($friendshare);

Link to comment
https://forums.phpfreaks.com/topic/241411-row-name-clashing/#findComment-1240212
Share on other sites

You need to look into the UNION clause. This combines two queries into a single resultset. However, the two queries must return the same number of columns with the same data-types in the same order; and the column names in the result set will be the column names used in the FIRST query. This should not be a problem, though. You should not use SELECT * in a query unless you actually intend to use ALL of the columns returned.

 

(SELECT "Room" AS ResType, ID, Name, Description FROM Rooms)
UNION
(SELECT "Equipment", ID, Name, Manufacturer FROM Equipment)
ORDER BY Description

This query will return four columns. They will be named "ResType", "ID", "Name", and "Description". The first column is a literal indicating (to me) what type of resource the row describes - I showed this as an example of adding data to the query AND using an Alias - the name of this column is "ResType" (in PHP $type = $row['ResType']). The fourth column is named Description eventhough it will contain Manufacturer for "Equipment" rows, it will still be named "Description". The result will be sorted by the fourth column, regardless of which table it came from.

 

Link to comment
https://forums.phpfreaks.com/topic/241411-row-name-clashing/#findComment-1240221
Share on other sites

you could also use table notation

 

"SELECT Rooms.ResType, Rooms.ID, Rooms.Name, Rooms.Description,Equipmen.ID,Equipment.Name,Equipment.Manufacturer FROM Rooms, Equipment ORDER BY Rooms.Description"

 

however a UNION in this case would be more effificent

Link to comment
https://forums.phpfreaks.com/topic/241411-row-name-clashing/#findComment-1240246
Share on other sites

This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.