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