Actually Linus, the unique condition only needs to be present on the subquery.  It can update multiple records on the target table with a single record from the subquery.
That said, the  thing that you must obtain is a unique record returned from the subquery for each record on the target table.  We can only guess at the overall structure of your data, so you must figure out the best way to get a single record returned.  Distinct may do it, assigning a record number and selecting the first or last one in a partition, are a couple of options.  
Try collecting data from your source for a single patient to see the structure of the duplication.  You may want to create a temporary dataset to eliminate dupplicates if that is easier for you to clean up.