When to use VARCHAR and DATE/DATETIME

前端 未结 5 1587
野趣味
野趣味 2020-11-29 00:40

We had this programming discussion on Freenode and this question came up when I was trying to use a VARCHAR(255) to store a Date Variable in this format: D/MM/YYYY. So the q

相关标签:
5条回答
  • 2020-11-29 01:03

    When you'll have database with more than 2-3 million rows you'll know why it's better to use DATETIME than VARCHAR :)

    Simple answer is that with databases - processing power isn't a problem anymore. Just the database size is because of HDD's seek time.

    Basically with modern harddisks you can read about 100 records / second if they're read in random order (usually the case) so you must do everything you can to minimize DB size, because:

    • The HDD's heads won't have to "travel" this much
    • You'll fit more data in RAM

    In the end it's always HDD's seek times that will kill you. Eg. some simple GROUP BY query with many rows could take a couple of hours when done on disk compared to couple of seconds when done in RAM => because of seek times.

    For VARCHAR's you can't do any searches. If you hate the way how SQL deals with dates so much, just use unix timestamp in 32 bit integer field. You'll have (basically) all advantages of using SQL DATE field, you'll just have to manipulate and format dates using your choosen programming language, not SQL functions.

    0 讨论(0)
  • 2020-11-29 01:04

    I'd vote for using the date/datetime types, just for the sake of simplicity/consistency.

    If you do store it as a character string, store it in ISO 8601 format:

    • http://www.iso.org/iso/date_and_time_format
    • http://xml.coverpages.org/ISO-FDIS-8601.pdf
    • http://www.cl.cam.ac.uk/~mgk25/iso-time.html

    Among other things, ISO 8601 date/time string (A) collate properly, (B) are human readable, (C) are locale-indepedent, and (D) are readily convertable to other formats. To crib from the ISO blurb, ISO 8601 strings offer

    representations for the following:

    • Date
    • Time of the day
    • Coordinated universal time (UTC)
    • Local time with offset to UTC
    • Date and time
    • Time intervals
    • Recurring time intervals

    Representations can be in one of two formats: a basic format that has a minimal number of characters and an extended format that adds characters to enhance human readability. For example, the third of January 2003 can be represented as either 20030103 or 2003-01-03.

    [and]

    offer the following advantages over many of the locally used representations:

    • Easily readable and writeable by systems
    • Easily comparable and sortable
    • Language independent
    • Larger units are written in front of smaller units
    • For most representations the notation is short and of constant length

    One last thing: If all you need to do is store a date, then storing it in the ISO 8601 short form YYYYMMDD in a char(8) column takes no more storage than a datetime value (and you don't need to worry about the 3 millisecond gap between the last tick of the one day and the first tick of the next. But that's a matter for another discussion. If you break it up into 3 columns — YYYY char(4), MM char(2), DD char(2) you'll use up the same amount of storage, and get more options for indexing. Even better, store the fields as a short for yyyy (4 bytes), and a tinyint for each of MM and DD — now you're down to 6 bytes for the date. The drawback, of course, to decomposing the date components into their constituent parts is that conversion to proper date/time data types is complicated.

    0 讨论(0)
  • 2020-11-29 01:07

    Between DATE/DATETIME and VARCHAR for dates I would go with DATE/DATETIME everytime. But there is a overlooked third option. Storing it as a INTEGER unsigned!

    I decided to go with INTEGER unsigned in my last project, and I am really satisfied with making that choice instead of storing it as a DATE/DATETIME. Because I was passing along dates between client and server it made the ideal type for me to use. Instead of having to store it as DATE and having to convert back every time I select, I just select it and use it however I want it. If you want to select the date as a "human-readable" date you can use the FROM_UNIXTIME() function.

    Also a integer takes up 4 bytes while DATETIME takes up 8 bytes. Saving 50% storage.

    The sorting problem that Berin proposes is also solved using integer as storage for dates.

    0 讨论(0)
  • 2020-11-29 01:12

    Why not put screws in with a hammer?

    Because it isn't the right tool for the job.

    Some of the disadvantages of the VARCHAR version:

    • You can't easily add / subtract days to the VARCHAR version.
    • It is harder to extract just month / year.
    • There is nothing stopping you putting non-date data in the VARCHAR column in the database.
    • The VARCHAR version is culture specific.
    • You can't easily sort the dates.
    • It is difficult to change the format if you want to later.
    • It is unconventional, which will make it harder for other developers to understand.
    • In many environments, using VARCHAR will use more storage space. This may not matter for small amounts of data, but in commercial environments with millions of rows of data this might well make a big difference.

    Of course, in your hobby projects you can do what you want. In a professional environment I'd insist on using the right tool for the job.

    0 讨论(0)
  • 2020-11-29 01:14

    Two reasons:

    • Sorting results by the dates
    • Not sensitive to date formatting changes

    So let's take for instance a set of records that looks like this:

    5/12/1999 | Frank N Stein
    1/22/2005 | Drake U. La
    10/4/1962 | Goul Friend
    

    If we were to store the data your way, but sorted on the dates in assending order SQL will respond with the resultset that looks like this:

    1/22/2005 | Drake U. La
    10/4/1962 | Goul Friend
    5/12/1999 | Frank N. Stein
    

    Where if we stored the dates as a DATETIME, SQL will respond correctly ordering them like this:

    10/4/1962 | Goul Friend
    5/12/1999 | Frank N. Stein
    1/22/2005 | Drake U. La
    

    Additionally, if somewhere down the road you needed to display dates in a different format, for example like YYYY-MM-DD, then you would need to transform all your data or deal with mixed content. When it's stored as a SQL DATE, you are forced to make the transform in code, and very likely have one spot to change the format to display all dates--for free.

    0 讨论(0)
提交回复
热议问题