The Session of NHibernate does not only implement the 'Unit Of Work' pattern, but it also implements the 'Identity Map' pattern.
That is, when you retrieve an entity from the datastore for the first time in a session, then NHibernate will retrieve that entity from the DB.
When you want to retrieve that same entity again using the same Session, then NHibernate will not fetch it back from the DB, but it will return the reference that it has already fetched. Offcourse, this is only true if you use the same Session instance when you fetch that same entity for the 2nd time.
When you make changes to an entity, and in the meantime someone else changes the same entity and persists those changes to the DB, then, offcourse, you will not see those changes, since you cannot expect that NHIbernate keeps track of the entire database, and checks if someone else has changed (and persisted) an entity that you have in memory.
Therefore, it is advised that your Sessions should be short-lived. In order to not overwrite someone elses changes, you can easily implement optimistic locking in NHibernate.
But, I wonder ... Are you sure that NHibernate is a good solution for your problem ? What kind of application are you going to build ?