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 600705
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 13, 20262026-05-13T16:38:04+00:00 2026-05-13T16:38:04+00:00

I am doing a web-application on asp.net mvc and I’m choosing between the long

  • 0

I am doing a web-application on asp.net mvc and I’m choosing between the long and Guid data type for my entities, but I don’t know which one is better. Some say that long is much faster. Guid also might have some advantages. Anybody knows ?

  • 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-13T16:38:05+00:00Added an answer on May 13, 2026 at 4:38 pm

    When GUIDs can be Inappropriate

    GUIDs are almost always going to be slower because they are larger. That makes your indexes larger. That makes your tables larger. That means that if you have to scan your tables, either wholly or partially, it will take longer and you will see less performance. This is a huge concern in reporting based systems. For example, one would never use a GUID as a foreign key in a fact table because its length would usually be significant, as fact tables are often partially scanned to generate aggregates.

    Also consider whether or not it is appropriate to use a “long”. That’s an enormously large number. You only need it if you think you might have over 2 BILLION entries in your table at some point. It’s rare that I use them.

    GUIDs can also be tough to use and debug. Saying, “there’s a problem with Customer record 10034, Frank, go check it out” is a lot easier than saying “there’s a problem with {2f1e4fc0-81fd-11da-9156-00036a0f876a}…” Ints and longs are also easier to type into queries when you need to.

    Oh, and it’s not the case that you never get the same GUID twice. It has been known to happen on very large, disconnected systems, so that’s something to consider, although I wouldn’t design for it in most apps.

    When GUIDs can be Appropriate

    GUIDs are the appropriate when you’re working with disconnected systems where entities are created and then synchronized. For example, if someone makes a record in your database on a mobile device and syncs it, or you have entities being created at different branch offices and synced to a central store at night. That’s the kind of flexibility they give you.

    GUIDs also allow you the ability to associate entities without persisting them to the database, in certain ORM scenarios. Linq to SQL (and I believe the EF) don’t have this problem, though there are times you might be forced to submit your changes to the database to get a key.

    If you create your GUIDs on the client, it’s possible that since the GUIDs you create are not sequential, that insert performance could suffer because of page splits on the DB.

    My Advice

    A lot of stuff to consider here. My vote is to not use them unless you have a compelling use case for them. If performance really is your goal, keep your tables small. Keep your fields small. Keep your DB indexes small and selective.

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

Sidebar

Related Questions

I have an ASP.NET MVC 3 Web Application using Linq-to-SQL for my data access
So I'm doing a project. MS SQL->WCF->Client (win32 application + asp.net MVC 3 web)
I am developing a web application using asp.net mvc... I am listing out the
For the web application (ASP.NET MVC) I'm currently developing, we have the following architecture
I am building a web application in asp.net MVC and am thinking how I
In my ASP.NET MVC 3 web application I am overriding the View name in
I have enabled form authentication in my ASP.NET MVC web application. I want to
I have built an ASP.NET MVC 3 web application (with exlusively Razor/cshtml pages) that
I have built an ASP.NET MVC web application that uses Entity Framework. To provide
I'm developing a web app in asp.net mvc using jquery, the language of application

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.