मेरे पास उपयोगकर्ता 'dbo' वाला डेटाबेस है जिसका लॉगिन नाम "डोमेन \ xzy" है। मैं इसे "डोमेन \ xzy" से "डोमेन \ abc" में कैसे बदलूं।एसक्यूएल सर्वर 2005 डीबीओ लॉगिन नाम बदलने के लिए कैसे करें
उत्तर
मैंने इसे समझ लिया। एसक्यूएल प्रबंधन स्टूडियो के भीतर आपको डेटाबेस -> गुण -> फ़ाइलें -> स्वामी फ़ील्ड पर राइट-क्लिक करना होगा। इस फ़ील्ड को उस लॉगिन नाम/खाते में बदलें जिसे आप उस डेटाबेस के लिए "dbo" उपयोगकर्ता नाम से जोड़ना चाहते हैं। कृपया ध्यान रखें कि आपके द्वारा चुने गए लॉगिन नाम/खाते को सुरक्षा के तहत एसक्यूएल सर्वर में पहले से ही सेटअप किया जाना चाहिए -> लॉग इन
यह एक विंडोज लॉगिन है, एक SQL सर्वर लॉगिन नहीं है, इसलिए आप लॉगिन नाम 'नहीं बदल सकते हैं क्योंकि यह सक्रिय निर्देशिका में उपयोगकर्ता खाते से जुड़ा हुआ है।
नए विंडोज़ उपयोगकर्ता (मैप) को नए विंडोज उपयोगकर्ता में मैप किया गया (और यदि आवश्यक हो तो पुराना हटा दें)। फिर लॉगिन की सुरक्षा में> उपयोगकर्ता मानचित्रण, अनुमति है कि उपयोगकर्ता 'dbo' के रूप में उपयुक्त डेटाबेस के लिए लॉग इन (या db_owner भूमिका के लिए असाइन)
मुझे संदेह है कि आप SQL सर्वर सुरक्षा मॉडल को ठीक से समझ नहीं रहे हैं। * पूरे सर्वर इंस्टेंस * में ** लॉग इन ** सर्वर से जुड़े हैं। ये एसक्यूएल या विंडोज लॉग इन हो सकते हैं। सर्वर पर प्रत्येक डेटाबेस में उस डेटाबेस तक पहुंचने के लिए अनुमतियों के साथ ** ** ** ** हैं। डेटाबेस ** उपयोगकर्ता ** एक SQL ** लॉगिन ** से जुड़ा हुआ है जो आमतौर पर (लेकिन होने की आवश्यकता नहीं होती) होती है। ** डीबीओ ** प्रत्येक डेटाबेस पर एक * विशेष उपयोगकर्ता * है। ओपी डाटाबेस के db_owner अधिकारों के साथ एक नए मनमानी उपयोगकर्ता की कोशिश नहीं कर रहा है - वह मानक ** dbo ** उपयोगकर्ता के साथ एक अलग सर्वर लॉगिन को जोड़ने की कोशिश कर रहा है। –
आप एक डाटाबेस उपयोगकर्ता के लिए एक लॉगिन पुन: मैप करने की कोशिश कर रहे हैं, तो आप
sp_change_user_login उपयोग कर सकते हैंexec sp_change_user_login 'Update_One', 'user', 'login'
स्पोक 'sp_change_users_login' (यानी _users_) प्रतीत होता है। एफओआई बीओएल यह भी कहता है कि इसे बहिष्कृत किया गया है और भविष्य में इसके बजाय वैकल्पिक उपयोगकर्ता का उपयोग किया जाना चाहिए। –
हालांकि आमतौर पर यह काम करेगा, संग्रहित proc काफी विशेष रूप से ** ** ** ** dbo ** उपयोगकर्ता को इस तरीके से बदलने का प्रयास अस्वीकार करता है। –
पैंटोम टाइपिस्ट जीयूआई का उपयोग करके एक अच्छा जवाब देता है। टीएसक्यूएल के साथ एक ही परिणाम प्राप्त करने के लिए, आप इस कोड का उपयोग कर सकते हैं:
USE [My_Database_Name]
GO
EXEC dbo.sp_changedbowner @loginame = N'domain\abc', @map = false
GO
- 1. एसक्यूएल सर्वर 2005
- 2. टी-एसक्यूएल एसक्यूएल सर्वर 2005
- 3. एमएस एसक्यूएल सर्वर 2005
- 4. एसक्यूएल सर्वर 2005
- 5. एसक्यूएल सर्वर 2005: परिवर्तनीय
- 6. एमएस एसक्यूएल सर्वर 2005
- 7. एसक्यूएल सर्वर 2005
- 8. एसक्यूएल सर्वर 2005 (या 08)
- 9. चेक सर्वर (एसक्यूएल सर्वर 2005
- 10. एसक्यूएल सर्वर 2005/2008
- 11. एसक्यूएल सर्वर 2005
- 12. एसक्यूएल सर्वर 2005
- 13. एमएस एसक्यूएल सर्वर 2005
- 14. माइक्रोसॉफ्ट एसक्यूएल सर्वर 2005
- 15. एसक्यूएल सर्वर 2005
- 16. एसएएस एसक्यूएल सर्वर 2005
- 17. एसक्यूएल सर्वर 2005
- 18. एमएस एसक्यूएल सर्वर 2005 में एक कॉलम का नाम बदलना
- 19. माइक्रोसॉफ्ट एसक्यूएल सर्वर 2005 स्ट्रिंग
- 20. एसक्यूएल सर्वर 2005/2008: ट्रांसएक्ट-एसक्यूएल
- 21. एसक्यूएल सर्वर 2005: एकल क्वेरी
- 22. एसक्यूएल 2005
- 23. डीबीओ स्कीमा
- 24. एक चुनिंदा कथन एसक्यूएल सर्वर 2005
- 25. एसक्यूएल सर्वर - db नाम
- 26. कैसे एसक्यूएल सर्वर में समय क्षेत्र 2005
- 27. एसक्यूएल क्वेरी SQL सर्वर 2005
- 28. एसक्यूएल सर्वर 2005 डाटाबेस 'रिकवरी'
- 29. अद्यतन सेट में एसक्यूएल (एसक्यूएल सर्वर 2005)
- 30. एमएस एसक्यूएल सर्वर 2005 एक्सप्रेस
मुझे यह जानने की जरूरत है, 2 साल बाद - धन्यवाद। – Hogan
एक महान खोज है! +1 – Sprintstar
या कोड के माध्यम से एक ही परिवर्तन करें: कुछ डीबी का उपयोग करें; जाओ; exec sp_changedbowner 'newOwner' –