Re: [Boost-users] ¤Multi_indexcomposite_key~~
data:image/s3,"s3://crabby-images/fe81e/fe81ede6ee3d687e601d245eb85c277725b9795c" alt=""
Oh, sorry.
Assume "cadillac" have "A4" model, "bmw" have "A4" model too.
now, if I will querying "A4" 's price, I must kown the manufacturer.
ordered_no_unique< tag<model>,BOOST_MULTI_INDEX_MEMBER(car_model,std::string,model) >,ct.insert(car_model("A4",cadillac,78901));ct.insert(car_model("A4",bmw,65412));
index_iterator
thanks a lot!
now, I have a new problem:
Multi_index example 6: complex searches and forergn keys, struct car_manufacturer { std::string name; };
struct car_model { std::string model; car_manufacturer* manufacturer; int price; };
I want use "model, name" to query "price", and I maybe to modify "price".
How to do it? thanks.
Sorry but your question is not clear to me: what do you mean by querying "price" using "model, name"? If you know the model of a car then you just can use find() in the car_table to locate the element and access the price. As for modifying, there's a tutorial section on updating elements of a multi_index_container at http://www.boost.org/libs/multi_index/doc/tutorial/basics.html#ord_updating Joaquín M López Muoz Telefónica, Investigación y Desarrollo _______________________________________________ Boost-users mailing list Boost-users@lists.boost.org http://lists.boost.org/mailman/listinfo.cgi/boost-users
data:image/s3,"s3://crabby-images/d15a8/d15a849e756d614839063b3d7e2d9dd31858352b" alt=""
isjk
Oh, sorry.
Nothing to be sorry about. On another topic, please don't top-post and try to follow the discussion policies of the list as summarized at http://www.boost.org/community/policy.html
Assume "cadillac" have "A4" model, "bmw" have "A4" model too. now, if I will querying "A4" 's price, I must kown the manufacturer. ordered_no_unique< tag<model>,BOOST_MULTI_INDEX_MEMBER(car_model,std::string,model),
Correct, you must change from the example's original ordered_unique to ordered_no_unique so as to allow cars with from different manufacturers yet the same model name.
ct.insert(car_model("A4",cadillac,78901)); ct.insert(car_model("A4",bmw,65412));
index_iterator
::type im0,im1; boost::tuples::tie(im0,im1)=get<model>(ct).equal_range(model); car_table_manufacturer_view ctmv; copy(im0,im1,back_inserter(ctmv)); car_table_manufacturer_view::iterator ictmv = ctmv.find(cm);
This looks right (haven't compiled it), although a little contrived: unless you expect to have *many* cars with the same model name, you can just traverse [im0,im1) and locate the car you're after.
ctmv.modify(cctmv, _Modify_price(10000)); // right or wrong???
I don't know how you've defined _Modify_price. Care to show? Joaquín M López Muñoz Telefónica, Investigación y Desarrollo
participants (2)
-
isjk
-
Joaquin M Lopez Munoz