Jump to content

Recommended Posts

How would you put a keyword column to a table with pictures ?

 

What I want to do is to have a column in the picture table where I would store keyword related to the picture.

for example a picture about a honda cbr 600 bike would get the keywords bike motorcycle motorbike honda cbr

 

the aim is to be able to select only the pictures with a given keyword in the keyword column.

to make it a little bit more difficult (maybe) this also has to work with multiple languages for example honda cbr 600 would get keywords

bike motorcycle honda in english and Japanese (multibyte)

 

Anyone any ideas or experience with something like this ?

 

thanks

anatak

Link to comment
https://forums.phpfreaks.com/topic/132524-solved-key-word-field/
Share on other sites

Make separate table called 'keywords' to store your... keywords and then another one 'keywords_pictures' that will relate keywords to pictures.

 

This is an example of many-to-many relation (one picture can have many keywords, and one keyword can be assigned to many pictures)

how would you take the input for the keywords for pictures ?

say a user uploads a snowboard picture. He wants to assign the keywords

winter snow snowboard holiday to the picture

Do you have a number of input fields or would you have 1 input field and separate all the words with a string function ? I guess m_byte string functions will have to be used.

 

Isn't a search going to be very slow ? searching for a picture about snowboard first have to find the snowboard reference in the keyboard table after that search the keyboard_pictures table and finally get the pictures from the pictures table with the right reference

 

 

 

Yes. One input field, and then use explode to get an array of keywords.

 

No. The search will not be slow (compared to design, where all keywords are stored in one table alongside pictures), provided that you create indexes and use proper queries.

I have a question about indexes. If you use primary keys do you still need to create indexes ?

if yes how do you create an index ? is it something that is part of the table structure or do you need to create indexes regularly with a cron job or something similar ?

 

Thanks for all the help till now.

it is really appreciated.

 

of topic

I see in your signature that you use PostgreSQL. Is PostgreSQL similar to MySQL in php support ?

 

anatak

PostgresSQL is in my imput queue - which means I'm going to spend some time learning about it soon :) But as far as I know, PHP interaction is very similar. See pgsql

 

As for the indexes, yes you (usually) need them even if you use primary keys. If you have phpmyadmin or similar tool it is really easy to create. And creating them is a one_time thing done either during creating a table, or with ALTER TABLE syntax.

Basically you should create indexes on fields that are appearing in WHERE part of your queries. Check mysql manual for some more information about it. 7.4. Optimizing Database Structure

ok thanks

I thought that a primary key was an index.

I learned SQL a long time ago on Oracle (don't remember wich version) and I think that oracle created indexes when you created a table with a primary key automatically.

 

thanks a lot

I ll close topic now

 

anatak

This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.