Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

Get Fabric certified for FREE! Don't miss your chance! Learn more

Reply
ShanthanPaladi
New Member

Foreign Key Constraints Behavior After Mirroring SQL Server to Fabric

Hi Team,

 

I have mirrored an on-premises Microsoft SQL Server database into Microsoft Fabric using the mirroring feature.

 

In the source database, multiple tables have foreign key constraints defined. After mirroring, I understand that these constraints are not carried over to Fabric by default.

So, I manually created the foreign key constraints in the mirrored database using SQL Endpoint. However, I am noticing that these constraints are not being retained — they seem to get dropped or deleted after some time (possibly during sync or refresh).

  • Is this expected behavior with Fabric mirroring?
  • Is there any way to prevent the foreign key constraints from being dropped automatically?
  • What is the recommended approach to maintain referential integrity in this scenario?

 

Any guidance would be greatly appreciated.

Thank you.

3 REPLIES 3
ShanthanPaladi
New Member

Hi @ssrithar & @deborshi_nag 

Thank you both for your detailed inputs and clarification.

 

I appreciate your guidance and the detailed explanation — it helped me understand the expected behavior and the recommended approach moving forward.

Thanks again for your support!

deborshi_nag
Memorable Member
Memorable Member

Hello @ShanthanPaladi 

 

This is expected behaviour. The mirrored database, available as a SQL analytics endpoint, is read-only. You are only allowed to analyze data in delta tables using a no code visual query editor or T-SQL to create views, functions, stored procedures, and apply SQL security - you can't apply DDL constructs! 

 

In summary, in Fabric Mirroring:

  • Foreign keys are not replicated
  • The SQL analytics endpoint is read‑only
  • Constraints you manually add are not retained

Therefore:

  • ARI (Assume Referential INtegrity) is the correct analytical substitute for missing physical constraints
  • Integrity should be enforced in the source SQL Server
  • ARI tells Fabric: “Trust the source system”

This is the recommended pattern for mirrored databases on Fabric at this time.

 

I trust this will be helpful. If you found this guidance useful, you are welcome to acknowledge with a Kudos or by marking it as a Solution.
ssrithar
Resolver III
Resolver III

Hi @ShanthanPaladi ,

 

Yes, this is expected behavior. The Fabric mirroring process only replicates data — it does not carry over DDL schema objects like foreign key constraints from the source SQL Server. More importantly, the SQL Analytics Endpoint in Fabric is a read-only, auto-generated view over the underlying Delta/Parquet files in OneLake. Any schema-level changes you make directly on the SQL Analytics Endpoint (including manually adding foreign keys) can be lost or overridden when the mirroring sync refreshes the metadata or when the endpoint regenerates its schema.

 

This is a fundamental architectural difference from on-premises SQL Server. Fabric is an analytics platform, not a transactional one, and its constraint system is intentionally non-enforcing.

 

If this post helps, then please appreciate giving a Kudos or accepting as a Solution to help the other members find it more quickly.
If I misunderstand your needs or you still have problems on it, please feel free to let us know. Thanks a lot!

Helpful resources

Announcements
Join our Fabric User Panel

Join our Fabric User Panel

Share feedback directly with Fabric product managers, participate in targeted research studies and influence the Fabric roadmap.

February Fabric Update Carousel

Fabric Monthly Update - February 2026

Check out the February 2026 Fabric update to learn about new features.

FabCon Atlanta 2026 carousel

FabCon Atlanta 2026

Join us at FabCon Atlanta, March 16-20, for the ultimate Fabric, Power BI, AI and SQL community-led event. Save $200 with code FABCOMM.