Subversion - What are the differences between the SVN checkout and SVN update commands?

56,364

Solution 1

As I see it, the big difference is that checkout creates a working copy, whereas update brings down changes to an existing working copy.

Solution 2

svn checkout copies all the versioned files from the given directory in the repository at the given revision (default HEAD), and copies them to your local machine. It also generates all of the hidden .svn directories, and the meta-data within them, that make these files a working copy.

svn export copies all the versioned files from the given directory in the repository at the given revision (default HEAD), and copies them to your local machine, but produces a standard directory hierachy. (It does not produce a working copy that can be updated or checked back in).

svn update applies changes to an existing working copy. If, in doing so, a conflict is discovered the user is alerted and must resolve this before being able to commit any changes. When using svn commit it is a requirement that the working copy to be committed is up to date (ie. the same revision as HEAD).

Solution 3

Update will update your checked out version to the latest version (or a specified other revision) in repository. If you have made changes to your working copy, they will still be there after the update. If files have been added or deleted to the repository, that will be reflected in your working copy. If there are changes both in your local copy and in the repository SVN will try to merge all changes for you, if that doesn't work it'll flag for a conflict that you resolve manually.

Solution 4

Subversion uses hidden directories of metadata to enable the functionality it provides. These .svn directories are what makes a directory into a Subversion working copy -- without these, it's just a directory and Subversion can't do much with it.

UPDATE is an operation that is performed over a Subversion working copy; no .svn directories, no UPDATE. CHECKOUT is the operation that creates a working copy.

Solution 5

svn update brings only the difference in files from the user version to the latest available version. If no difference no actions.

But checkout creates a new folder and brings all the files for that branch. Checkout is a good way to work if we constantly change branches we work on. Update is when we have a trunk and need to get the updates done by others on that trunk.

Share:
56,364

Related videos on Youtube

Emilio
Author by

Emilio

Updated on February 21, 2020

Comments

  • Emilio
    Emilio about 4 years

    I understand that the "SVN checkout" command will do the initial get of file(s) from the Subversion repository and bring them locally to your working directory/copy and that the "SVN update" command will get changes to file(s) from the repository if changes have been made by others.

    It seems to me though that an "update" is just a special case of a "checkout", that is, when a checkout occurs, it's getting all files since none yet exist locally and hence ALL of the files have "changed", and that behind the scenes these commands are doing largely the same thing. I assume the commands exist separately just as a means of simplification?

    Or, are there other differences between the commands, for example, does "SVN update" get files get new files (files that exist in the repository that you don't have in your working copy) or just updates to existing files?

    • Mike Miller
      Mike Miller about 14 years
      Also related is the "svn export" command. This will bring down files from a repository, but not create a working copy. You will not be able to commit changes from an export.
    • Emilio
      Emilio about 14 years
      It's just for read-only, or "browse" type purposes? Where does it put them, some temp dir?
    • Dave Van den Eynde
      Dave Van den Eynde about 14 years
      No it'll be a writable copy, just not containing any hidden .svn directories to track changes.
  • Mike Miller
    Mike Miller about 14 years
    Sure you can update to the latest. This is what svn update does if you specify HEAD as the revision, or if you do not specify a revision at all.
  • Dror
    Dror over 11 years
    I'm not sure that you're 100% correct regarding the precondition that the working copy is updated before committing. Technically, I think you /can/ commit without updating first. However, I guess it is /not/ recommended and should be practiced with great care. Furthermore, I don't know when one would like to commit without first updating.
  • Golo Roden
    Golo Roden about 7 years
    IMHO this does not answer the question, because this distinction is already contained within the question. It's pretty obvious that the two commands have different semantics, but how do they differ technically? Aren't they effectively doing the same thing, just one at the beginning, and the other one at later point in times?
  • jxramos
    jxramos over 6 years
    what svn version did you see this behavior? I just did a "re-checkout" and it looks like it just interpreted it as an update. I'm running svn, version 1.8.9 (r1591380)
  • Hamza Saeed
    Hamza Saeed about 4 years
    @Dror Yes you are right! It is best practice to update before committing, although sometimes subversion does not commit without update, it gives pop up error to update before committing.