Images in database:
Advantages:
- Secured
- Easy backup and Recovery
- Simple queries
Disadvantages:
- Large size of database
- Performance degradation of database with heavy images
- Slower access speed
Images in file system:
Advantages:
- Easier access
- Increased performance (database’s performance will not be affected)
- Faster access (File system access is faster than database access)
Disadvantages:
- Less secure
- Complex process to backup and restore
- Added complexity while storage
(Suggested way: Create an ID, copy the ID, change the filename of the image and store the image to the database)
Suggestion:
Store Images in file system if:
- Number of images are huge
- Database space is limited
- Available database is costlier
- No problem in securing the images (Try setting permission over the images)
Store Images in database if:
- Number of images are considerably less (Try storing images in separate table)
- Not worried about the size of the database space (If you have enough space)
- Database cost can be met
- Scared about the security over the images in filesystem
Tips:
- While the image is uploaded, check for the format of the image (Not all formats are viewable in the webpage)
- Use compression algorithms to compress the size of the image
- Check if the image uploaded is really an image (There are chances of uploading any PHP scripts to the image location)
- Create a thumbnail image for every image uploaded.
- While storing the image in the file system, create a table in the database with Auto-incrementing attribute that creates an ID for every image uploaded. Rename the image of any name to imageID.ext and imageID.thumb.ext (Naming conventions can be in any form that helps you to identify the image). In this way the images can be fetched from the file system instantly