Wayback Machinekoobas.hobune.stream
May JUN Jul
Previous capture 13 Next capture
2021 2022 2023
1 capture
13 Jun 22 - 13 Jun 22
sparklines
Close Help
  • Products
  • Solutions
  • Made with Unity
  • Learning
  • Support & Services
  • Community
  • Asset Store
  • Get Unity

UNITY ACCOUNT

You need a Unity Account to shop in the Online and Asset Stores, participate in the Unity Community and manage your license portfolio. Login Create account
  • Blog
  • Forums
  • Answers
  • Evangelists
  • User Groups
  • Beta Program
  • Advisory Panel

Navigation

  • Home
  • Products
  • Solutions
  • Made with Unity
  • Learning
  • Support & Services
  • Community
    • Blog
    • Forums
    • Answers
    • Evangelists
    • User Groups
    • Beta Program
    • Advisory Panel

Unity account

You need a Unity Account to shop in the Online and Asset Stores, participate in the Unity Community and manage your license portfolio. Login Create account

Language

  • Chinese
  • Spanish
  • Japanese
  • Korean
  • Portuguese
  • Ask a question
  • Spaces
    • Default
    • Help Room
    • META
    • Moderators
    • Topics
    • Questions
    • Users
    • Badges
  • Home /
avatar image
0
Question by Jiro-Ng · Apr 11, 2014 at 04:29 AM · sqlquery

Use subquery result multiple times.

I have a sql code like this

 SELECT * 
 FROM friend
 WHERE 
     character_id_a IN (
         SELECT player_character_id 
         FROM player_character
         WHERE game_account_id IN ('1', '2')
     )
     AND
     character_id_b IN (
         SELECT player_character_id 
         FROM player_character
         WHERE game_account_id IN ('1', '2')
     )
 ;

Is there a way to avoid double execution of the subquery? Thank you in advance for any help.

Comment
Add comment · Show 4
10 |3000 characters needed characters left characters exceeded
▼
  • Viewable by all users
  • Viewable by moderators
  • Viewable by moderators and the original poster
  • Advanced visibility
Viewable by all users
avatar image getyour411 · Apr 11, 2014 at 04:45 AM 1
Share

So the usual answer is "don't do it", can you elaborate on the purpose of character_id_a and b?

avatar image flamy · Apr 11, 2014 at 04:52 AM 0
Share

both character_id_a and character_id_b seems to return the same thing!

avatar image Jiro-Ng · Apr 11, 2014 at 04:56 AM 0
Share

There is a friend table with 3 column friend_id, character_id_a, character_id_b.

The character_id is integer value which is the primary key of player_character table.

Then the game_account_id from player_character table is the primary key from game_account. Game account table store the user login id, password, name, etc.

One game account can have multiple character and the friend relation store is only between character. I want to write a sql statement to get all friend record between two game account.

avatar image perchik · Apr 11, 2014 at 06:52 PM 1
Share

This question is completely unrelated to unity, even if this is in a unity game, this very clearly an SQL question. I'd suggest going to StackOverflow which is a much more general program$$anonymous$$g support site

1 Reply

· Add your reply
  • Sort: 
avatar image
0
Best Answer

Answer by musaranya · Apr 11, 2014 at 07:24 AM

Can you try this?

SELECT f.* FROM friend f INNER JOIN player_character c ON (f.character_id_a =c.player_character_id OR f.character_id_b =c.player_character_id ) WHERE c.game_account_id in (1,2)

Comment
Add comment · Show 3 · Share
10 |3000 characters needed characters left characters exceeded
▼
  • Viewable by all users
  • Viewable by moderators
  • Viewable by moderators and the original poster
  • Advanced visibility
Viewable by all users
avatar image Jiro-Ng · Apr 11, 2014 at 07:44 AM 0
Share

Thank you for this. I try but the result end up not only getting friend record between two game account but all friend record from these two game account

avatar image musaranya · Apr 11, 2014 at 06:22 PM 1
Share

and this?

 SELECT 
 f.* 
 FRO$$anonymous$$ 
 friend f 
 LEFT JOIN player_character pca ON f.character_id_a = pca.player_character_id
 LEFT JOIN player_character pcb ON f.character_id_b = pcb.player_character_id
 WHERE 
 (pca.game_account_id=1 AND pcb.game_account_id=2)
 OR
 (pca.game_account_id=2 AND pcb.game_account_id=1)
avatar image Jiro-Ng · Apr 17, 2014 at 01:45 AM 0
Share

Is working.... thanks for you help.

Your answer

Hint: You can notify a user about this post by typing @username

Up to 2 attachments (including images) can be used with a maximum of 524.3 kB each and 1.0 MB total.

Follow this Question

Answers Answers and Comments

24 People are following this question.

avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image

Related Questions

SQL Query SET Statement issue with nested Statements in PHP 2 Answers

Querys for multiple databases at the same time 0 Answers

MSSQL Connection and Select 2 Answers

Linq Query - Strange Outcome 1 Answer

How to use Sqlite3 in Unity for android 0 Answers


Enterprise
Social Q&A

Social
Subscribe on YouTube social-youtube Follow on LinkedIn social-linkedin Follow on Twitter social-twitter Follow on Facebook social-facebook Follow on Instagram social-instagram

Footer

  • Purchase
    • Products
    • Subscription
    • Asset Store
    • Unity Gear
    • Resellers
  • Education
    • Students
    • Educators
    • Certification
    • Learn
    • Center of Excellence
  • Download
    • Unity
    • Beta Program
  • Unity Labs
    • Labs
    • Publications
  • Resources
    • Learn platform
    • Community
    • Documentation
    • Unity QA
    • FAQ
    • Services Status
    • Connect
  • About Unity
    • About Us
    • Blog
    • Events
    • Careers
    • Contact
    • Press
    • Partners
    • Affiliates
    • Security
Copyright © 2020 Unity Technologies
  • Legal
  • Privacy Policy
  • Cookies
  • Do Not Sell My Personal Information
  • Cookies Settings
"Unity", Unity logos, and other Unity trademarks are trademarks or registered trademarks of Unity Technologies or its affiliates in the U.S. and elsewhere (more info here). Other names or brands are trademarks of their respective owners.
  • Anonymous
  • Sign in
  • Create
  • Ask a question
  • Spaces
  • Default
  • Help Room
  • META
  • Moderators
  • Explore
  • Topics
  • Questions
  • Users
  • Badges