SQL Server นั้น สามารถเคลื่อนย้ายฐานข้อมูลได้หลายวิธี ซึ่งหนึ่งในนั้น คือ การใช้ขบวนการ attach/detach จากไฟล์ .mdf และ .ldf ที่นิยมกันมาก เพราะง่ายและสะดวก (แต่จะไม่สะดวกถ้าฐานข้อมูลมีข้อมูลจำนวนมาก เพราะทำให้ไฟล์มีขนาดใหญ่) แต่ปัญหาที่พบกันมากคือ เมื่อนำไฟล์ฐานข้อมูลไป attach ไว้อีกเครื่อง diagrams จะไม่สามารถใช้ได้ โดยจะมีคำเตือนขึ้นว่า "Database diagram support objects cannot be installed because this database does not have a valid owner. To continue, first use the File page of the Database Properties dialog box or the ALTER AUTHORIZATION statement to set database owner to a valid login, then add the database diagram support objects." อีกปัญหาคือย้าย path ของไฟล์ฐานข้อมูล (โดย copy หรือ cut ก็ตาม) ก็จะพบปัญหาการ login ไม่สำเร็จอีกเช่นกัน
ปัญหานี้สามารถแก้ไขได้โดยการสร้างสิทธิ์ให้ user ที่ต้องการ ให้สามารถเข้าถึงฐานข้อมูลนั้นได้ โดยใช้คำสั่ง
ALTER AUTHORIZATION ON DATABASE::database_name TO valid_login
database_name หมายถึง ฐานข้อมูลที่มีปัญหา ส่วน valid_login หมายถึง user ที่ต้องการกำหนดสิทธิ์
ถ้ายังไม่มี user สำหรับการเข้าถึงฐานข้อมูลนั้น ให้สร้าง user ในโฟลเดอร์ Security (ไม่ใช่ Security ในฐานข้อมูลนั้นนะครับ) คลิ๊กขวาที่โฟลเดอร์ Logins เพื่อเลือก New Login แล้วค่อยใช้คำสั่งด้านบนให้สิทธิ์แก่ user ใหม่ที่สร้างขึ้น
และสุดท้าย อย่าลืม stop services ก่อน เคลื่อนย้ายหรือก็อปปี้นะครับ ไม่งั้นจะโดนเตือนแบบนี้ครับ
แหล่งข้อมูล :
Understanding Database Diagram Ownership