You are viewing a plain text version of this content. The canonical link for it is here.
Posted to notifications@shardingsphere.apache.org by GitBox <gi...@apache.org> on 2020/11/13 07:42:01 UTC

[GitHub] [shardingsphere] xue2lang opened a new issue #8152: when use in search , sql will occur cartesian set

xue2lang opened a new issue #8152:
URL: https://github.com/apache/shardingsphere/issues/8152


   ## Bug Report
   
   **For English only**, other languages will not accept.
   
   Before report a bug, make sure you have:
   
   - Searched open and closed [GitHub issues](https://github.com/apache/shardingsphere/issues).
   - Read documentation: [ShardingSphere Doc](https://shardingsphere.apache.org/document/current/en/overview).
   
   Please pay attention on issues you submitted, because we maybe need more details. 
   If no response anymore and we cannot reproduce it on current information, we will **close it**.
   
   Please answer these questions before submitting your issue. Thanks!
   
   ### Which version of ShardingSphere did you use?
   4.1.1 
   
   
   ### Which project did you use? ShardingSphere-JDBC or ShardingSphere-Proxy?
   ShardingSphere-JDBC
   
   
   ### Expected behavior
   database: db0,db1
   table:tb_0,tb_1  (every database has two table)
   shardingColumn: id  (database and table all use it)
   sql:select * from tb where id in (a,b)
   
   ShardingConditions: id in (a,b)
   id=a is in db0.tb0
   id=b is in db1.tb1
   
   
   expect:
   
   select * from db0.tb0 in (a,b)   # will be better: select * from db0.tb0 in (a);
   select * from db1.tb1 in (a,b)   #  will be better:  select * from db1.tb1 in (b)
   
   ### Actual behavior
   
   sql behavior is cartesian set
   
   eg:
   select * from db0.tb0 in (a,b)
   select * from db0.tb1 in (a,b)
   select * from db1.tb0 in (a,b)
   select * from db1.tb1 in (a,b)
   
   ### Reason analyze (If you can)
   code:org.apache.shardingsphere.sharding.route.engine.type.standard.ShardingStandardRoutingEngine#route0
   
   not bind route value with every database when routeDataSources ,only return the database collection 
   
   so when routeTables ,every route value will be to route all tables for every database ,return cartesian set
   
   ![Uploading image.png…]()
   
   
   ### Steps to reproduce the behavior, such as: SQL to execute, sharding rule configuration, when exception occur etc.
   
   has any plan to optimize it ???  or have some good idea
   
   expect:
   select * from db0.tb0 in (a,b)   # will be better: select * from db0.tb0 in (a);
   select * from db1.tb1 in (a,b)   #  will be better:  select * from db1.tb1 in (b)
   ### Example codes for reproduce this issue (such as a github link).
   
   i want to change code when routeDataSources ,bind every route value to database ,but i donot know it will produce other problem??
   
   
   
   


----------------------------------------------------------------
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

For queries about this service, please contact Infrastructure at:
users@infra.apache.org



[GitHub] [shardingsphere] kimmking closed issue #8152: when use in search , sql will occur cartesian set

Posted by GitBox <gi...@apache.org>.
kimmking closed issue #8152:
URL: https://github.com/apache/shardingsphere/issues/8152


   


----------------------------------------------------------------
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

For queries about this service, please contact Infrastructure at:
users@infra.apache.org



[GitHub] [shardingsphere] kimmking commented on issue #8152: when use in search , sql will occur cartesian set

Posted by GitBox <gi...@apache.org>.
kimmking commented on issue #8152:
URL: https://github.com/apache/shardingsphere/issues/8152#issuecomment-726632475


   It's a design so far.
   


----------------------------------------------------------------
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

For queries about this service, please contact Infrastructure at:
users@infra.apache.org