วันจันทร์ที่ ๑๗ ธันวาคม พ.ศ. ๒๕๕๐

ปัญหาจากการ Attach ไฟล์ใน SQL Server เมื่อมีการเคลื่อนย้ายไฟล์ (Attach files problem in SQL Server 2005)

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

Related Post