i have multi-to-multi table, going have millions of rows. let me describe confusion example.
example:
table: car_dealer_rel
opt:1
columns: car_id: int unsigned, dealer_id: int unsigned index on: car_id, dealer_id
car_id|dealer_id -------|--------- 1 | 1 1 | 2 ....
- sub-opt:1: here can have 1 index on both columns.
- sub-opt:2: 1 combined index on 2 columns.
opt-2:
one column table
col: car_id_dealer_id: varchar:21 index on: pki on single column.
here idea put values as: car_id.dealer_id
, searches %.xxx , or xxx.%
car_id_dealer_id ---------------- 1.1 1.2 1.15 2.10 ... ...
after millions of records faster for:
- read from
- add/update/delete.
i novice on mysql, appreciated.
with first 1
car_id|dealer_id -------|--------- 1 | 1 1 | 2
you can easlily create composite index fo both sides
create index ind1 on car_dealer_rel (car_id,dealer_id ); create index ind2 on car_dealer_rel (dealer_id, car_id );
that work fast
and can filter in both sense
car_id = your_value
or
where dealer_id = another_value
or using both
with second 1 can't easily( need string manipulation , don't let use index) , in condition can't using sql
and update, insert , delete performance remain pratically same
Comments
Post a Comment