Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 85843
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 10, 20262026-05-10T22:09:11+00:00 2026-05-10T22:09:11+00:00

I have a table in a DB (Postgres based), which acts like a superclass

  • 0

I have a table in a DB (Postgres based), which acts like a superclass in object-oriented programming. It has a column ‘type’ which determines, which additional columns should be present in the table (sub-class properties). But I don’t want the table to include all possible columns (all properties of all possible types).

So I decided to make a table, containg the ‘key’ and ‘value’ columns (i.e. ‘filename’ = ‘/file’, or ‘some_value’ = ‘5’), which contain any possible property of the object, not included in the superclass table. And also made one related table to contain the available ‘key’ values.

But there is a problem with such architecture – the ‘value’ column should be of a string data type by default, to be able to contain anything. But I don’t think converting to and from strings is a good decision. What is the best way to bypass this limitation?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. 2026-05-10T22:09:11+00:00Added an answer on May 10, 2026 at 10:09 pm

    The design you’re experimenting with is a variation of Entity-Attribute-Value, and it comes with a whole lot of problems and inefficiencies. It’s not a good solution for what you’re doing, except as a last resort.

    What could be a better solution is what fallen888 describes: create a ‘subtype’ table for each of your subtypes. This is okay if you have a finite number of subtypes, which sounds like what you have. Then your subtype-specific attributes can have data types, and also a NOT NULL constraint if appropriate, which is impossible if you use the EAV design.

    One remaining weakness of the subtype-table design is that you can’t enforce that a row exists in the subtype table just because the main row in the superclass table says it should. But that’s a milder weakness than those introduced by the EAV design.

    edit: Regarding your additional information about comments-to-any-entity, yes this is a pretty common pattern. Beware of a broken solution called ‘polymorphic association’ which is a technique many people use in this situation.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Ask A Question

Stats

  • Questions 79k
  • Answers 80k
  • Best Answers 0
  • User 1
  • Popular
  • Answers
  • Editorial Team

    How to approach applying for a job at a company ...

    • 7 Answers
  • Editorial Team

    How to handle personal stress caused by utterly incompetent and ...

    • 5 Answers
  • Editorial Team

    What is a programmer’s life like?

    • 5 Answers
  • Editorial Team
    Editorial Team added an answer Your build configuration Platform is set to 'Any CPU', that… May 11, 2026 at 4:14 pm
  • Editorial Team
    Editorial Team added an answer I'm not sure what you are build and what is… May 11, 2026 at 4:14 pm
  • Editorial Team
    Editorial Team added an answer You could take all your GUI building logic and initial… May 11, 2026 at 4:14 pm

Related Questions

SQLAlchemy's DateTime type allows for a timezone=True argument to save a non-naive datetime object
I would like to confirm that the following analysis is correct: I am building
Assume a table with the following columns: pri_id , item_id , comment , date
OpenOffice ships with HSQLDB. Is it possible to easily import the contents of an

Trending Tags

analytics british company computer developers django employee employer english facebook french google interview javascript language life php programmer programs salary

Top Members

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.