tags:

views:

34

answers:

3

So apparently the support you get from Varien when you purchase the Enterprise Edition is next to worthless so I am hoping that someone here can maybe lead me in the right direction.

In Magento I am would like to create a product attribute that is the type int. When I create the attribute from the admin panel it creates it as a varchar.

What I am ultimately trying to do is create a total sold attribute so that I can use it for sorting by most sold products in the category display. The problem with it being varchar is that when you sort by this, it sorts it as a string and not a number.

Varien told me that in order to get this to be an integer I would have to do an update to the database. It looks like to me that I would have to change the backend_type column in the eav_attribute table to int and that should hopefully move the values to catalog_product_entity_int table instead of it going to catalog_product_entity_varchar table. Does this make sense? Has anyone else done this before?

Now that I have that question out there, is this what I should expect from the support from Varien? So far their support seem pretty useless. It seems that asking how to do something this simple would not be a big deal (especially since I asked them how to do it, and not to do it for me)

Thanks

Josh Pennington

A: 

You're on the right track with changing the backend_type in eav_attribute, however that won't automatically migrate the attribute values to catalog_product_entity_int, you'll need to run a INSERT INTO SELECT query to take your values from catalog_product_entity_varchar across.

If you create your own module (which you will need to do to calculate the total sales per product anyway), you can insert a new int type attribute via the mysql-install file per this blog post . Also, the module creator extension will give you the module framework to get started.

The other option is to leave the attribute as a varchar and alter the category sort so that it evals the attribute as an int. But I think changing the type is safer and more efficient.

Hope this helps, JD

Jonathan Day
+1  A: 

I've never tried to change the type of an existing attribute before, and I try to stay out of fiddling directly with the mysql database structure. It's sort of like directly changing the contents of a memory location in a running desktop application; you can do it, but unless you know exactly what you're doing chances are you'll leave something in an unsupported state. Also, I can't prove this, but I'm pretty sure the specifics of the EAV implementation has chanced over the lifetime of the product, which means different versions would have different answers.

If you can start over from scratch, I'd add an attribute to the model programmatically (around the "Final Array of Key Value Pairs that Define the Attribute" header). Even if you can't start over from scratch, create an integer attribute programmatically and diff your database before and after to see what needs to happen on the backend for an attribute to be created.

Alan Storm
Good suggestion to diff the database, and I agree that it's better to work with the framework than the DB direct. The other option is to turn on SQL logging to identify what other actions are performed as you create the attribute and add it to an attribute set. Forum post here on SQL logging: http://www.magentocommerce.com/boards/viewthread/19609/ Don't forget to turn off before production!
Jonathan Day
A: 

With regard to your second question about expectations from support, it depends on the terms of the agreement as to whether it would just cover bug fixes, server and application configuration etc. I think it would be unusual for a support agreement to write new code for your custom requirements, but perhaps I'm missing the point.

Their webpage explicitly says that Not included = Code Development, Development Support, Custom Extensions, etc...

Cheers, Jonathan

Jonathan Day
I guess I was more surprised that giving me a little guidance is out of scope of the service agreement. Creating an attribute that is a number does not seem like it should be that big of a deal to do.
Josh Pennington
I completely agree that it would seem like a helpful thing to do, but I guess that they might get a lot of seemingly simple requests that would lead to more and more demands. Much easier to enforce a blanket rule on supporting development than to make judgement calls. Not defending it, just trying to see their POV.
Jonathan Day