Ever get an error message that goes something like this:
Cannot resolve the collation conflict between “SQL_Latin1_General_CP1_CI_AS” and “Latin_General_CI_AS”…
Generally, the two columns that are being used have different collation options. Collation “…specifies the bit patterns that represent each character in a dataset. Collations also determine the rules that sort and compare data.” (source). So if you are having errors with comparing fields, check the collation between the fields.
I’ve created a simple little database project to display an example:
data:image/s3,"s3://crabby-images/68abe/68abec80bd37c3dbe99ac0b5e7891af17145822f" alt=""
The image above shows two database projects; one as the source and the other as target. The goal is to move data from CollateSourceDB.dbo.tblPerson, stage only changes in CollateTargetDB.stg.tblPerson, and merge the changes into CollateTargetDB.dbo.tblPerson. I have already deployed the source database to my local as Local_CollationSource. Here is the data in Local_CollationSource.dbo.tblPerson:
data:image/s3,"s3://crabby-images/a30bc/a30bcdf7694d4845ffea3f65e9319d3f800ec6aa" alt=""
As I try to deploy CollateTargetDB to Local_CollationTarget, we get an error in the Data Tools Operations window:
data:image/s3,"s3://crabby-images/daf90/daf90456f20492edc8e0534e3b6960dcecc5e481" alt=""
Viewing the log from the message output:
data:image/s3,"s3://crabby-images/528ef/528efe8a10560db1473bae5cec6a8ba627dc0d40" alt=""
We can see we’re having a collation conflict issue with the EXCEPT operation in in the stored procedure spGetPerson. Taking a look at the procedure:
data:image/s3,"s3://crabby-images/ffca4/ffca4b7afea3a37c6a27f24dc5781572af0ee66d" alt=""
Confirming nothing suspicious is going on with the code, we should go to the column level to see the collations set:
data:image/s3,"s3://crabby-images/57836/57836807ab9d2d502d0785886931bdfb0d2aed85" alt=""
/* Code from https://stackoverflow.com/questions/1607560/cannot-resolve-the-collation-conflict-between-sql-latin1-general-cp1-ci-as-and */
We can confirm FirstNameDenorm, MiddleNameDenorm, and LastNameDenorm have different collations between the source and target for dbo.tblPerson. One solution is to update the columns in the target to match the source:
data:image/s3,"s3://crabby-images/c5e7e/c5e7e761abe16e2881889776d7351ee39fcf5275" alt=""
data:image/s3,"s3://crabby-images/69721/697218786ab378d316ac26fd7e232ddb1676fc58" alt=""
Now the deploy works, we validate the collations match:
data:image/s3,"s3://crabby-images/25de6/25de619d2f80f34ac16eddb30b25a269182600d1" alt=""
data:image/s3,"s3://crabby-images/48017/480174e9634eb8291cd442e781d70a166f716af2" alt=""
Running the procedures:
data:image/s3,"s3://crabby-images/af228/af22807ce47e0ba1dfb5faba56024e5bce59c14c" alt=""
This was an oversimplified way of how I found the issue in my other projects. Hopefully helps you.
Happy coding!