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

  • Home
  • SEARCH
  • 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 647135
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 13, 20262026-05-13T21:41:21+00:00 2026-05-13T21:41:21+00:00

I need to make a database that is highly localized. For almost all entities

  • 0

I need to make a database that is highly localized. For almost all entities I need a translation to 5+ languages. Some entities even require and additional resource localized (like images which I enter as paths).

The question now is:

1: LOOKUP TABLE PER ENTITY/TABLE (kinda bloated schema?)

should I create a “Localized” localization lookup table for each table I need localized values (and use standard int/bigint PKs for elements)
Like here:

MYITEMS
-------
 - MyItemId BIGINT PK
 - MyItemPrice DECIMAL

MYITEMLOCALIZED
---------------
 - CPK_MyItemId BIGINT FK
 - CPK_LanguageCode NCHAR
 - LocalizedName NVARCHAR
 - LocalizedResourcePath NVARCHAR

CUSTOMERS
---------
 - CustomerId BIGINT PK
 - CustomerName NVARCHAR

CUSTOMERLOCALIZED
---------------
 - CPK_CustomerId BIGINT FK
 - CPK_LanguageCode NCHAR
 - LocalizedName NVARCHAR
 - LocalizedResourcePath NVARCHAR

or

2: GUIDS WITH SINGLE LOOKUP LOCALIZATION TABLE (heavy guid usage?)

should I use GUIDs as PKs and then just use a single name and a single resource localization table.

MYITEMS
-------
 - MyItemId uniqueidentifier PK
 - MyItemPrice DECIMAL    

CUSTOMERS
---------
 - CustomerId uniqueidentifier PK
 - CustomerName NVARCHAR

LOCALIZED
    ---------------
     - CPK_ElementGuid uniqueidentifier FK
     - CPK_LanguageCode NCHAR
     - LocalizedValue NVARCHAR
     - LocalizedResourcePath NVARCHAR

3: SINGLE LOOKUP BUT GUIDS ONLY FOR LOCALIZATION (best of 2 worlds?)

should I use normal int/bigint PKs and then add a GUID column for each column I need localized and store localized values into a single localization lookup table.

MYITEMS
-------
 - MyItemId BIGINT PK
 - MyItemPrice DECIMAL
 - ItemNameLocalizationGuid uniqueidentifier(GUID)
 - ItemPictureLocalizationGuid uniqueidentifier(GUID)


CUSTOMERS
---------
 - CustomerId BIGINT PK
 - CustomerName NVARCHAR
 - CustomeerNameLocalizationGuid uniqueidentifier(GUID)

LOCALIZED
---------------
 - CPK_ElementGuid uniqueidentifier FK
 - CPK_LanguageCode NCHAR
 - LocalizedValue NVARCHAR

4: LOOKUP TABLE THAT RETURNS LOCALIZATION ID (go back and forth?)

should I create tables with no guids, but store localization id in the mother-table?

Like here:

MYITEMS
-------
 - MyItemId BIGINT PK
 - MyItemPrice DECIMAL
 - MyItemNameLocalizedId BIGINT    

CUSTOMERS
---------
 - CustomerId BIGINT PK
 - CustomerName NVARCHAR
 - CustomerGenderLocalizedId BIGINT

LOCALIZED
---------------
 - LocalizationId BIGINT PK
 - CustomerId BIGINT FK
 - LanguageCode NCHAR
 - LocalizedName NVARCHAR
 - LocalizedResourcePath NVARCHAR

If I use GUIDs as PKs I’ve read I’ll suffer huge performance and data size penalty, but I will also instantly deal with element uniqueness across servers, dbs…

  • 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. Editorial Team
    Editorial Team
    2026-05-13T21:41:22+00:00Added an answer on May 13, 2026 at 9:41 pm

    First of all, I’d strongly recommend using an existing standard for the localization identifiers – don’t re-invent yet another system! Use the ISO-639 standard codes for language, e.g. “en” for English, “fr” for French etc.

    See Wikipedia for a list of all the defined codes.

    Secondly, in my experience and my judgment, I would use a language table per entity.

    We typically have some “system name” on the main table, e.g. the English text, and then we have a table “(entity)_TX” for the textual representation in various languages.

    Something like this:

      TABLE CustomerType
          CustomerTypeID    INT IDENTITY(1,1) PK
          CustomerTypeName  VARCHAR(100)    -- English "system" name, e.g. "Gold customer"
    
      TABLE CustomerType_TX
          CustomerTypeID    INT
          LanguageID        CHAR(2)   -- ISO-639 codes
          CustomerTypeText  VARCHAR(200)   -- translated texts
    

    To me, this is clearer and more explicit and more “intuitive” than having a single, GUID-based encoding scheme.

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

Sidebar

Related Questions

I need to make changes to an in-use production database. Just adding a few
I need to make a WebCast presentation soon and need to do some whiteboarding
I need to make sure that user can run only one instance of my
I need to make some reflective method calls in Java. Those calls will include
I need to make a piece of C# code interact through COM with all
I have a crystal report file I need make a tiny edit in. It
I need to make an application in .NET CF with different/single forms with a
I need to make an ArrayList of ArrayLists thread safe. I also cannot have
I need to make a change to an ASP.NET web service written a couple
We need to make our enterprise ASP.NET/NHibernate browser-based application able to function when connected

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.