热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

[SqlServer]

关于SqlServerLogin,User,Schema这几个概念通常比较容易混淆,说不清具体的差别。在这里我梳理一下以作为记录,方便自己查阅,也方便感兴趣的朋友查阅,希望对大家有所帮助。1.LoginLogin的官方解释是:数据库引擎登录名。(msdn.microsoft.com

关于SqlServer Login,User,Schema这几个概念通常比较容易混淆,说不清具体的差别。在这里我梳理一下以作为记录,方便自己查阅,也方便感兴趣的朋友查阅,希望对大家有所帮助。 1.Login Login的官方解释是: 数据库引擎登录名。 (http://msdn.microsoft.com/

关于SqlServer Login,User,Schema这几个概念通常比较容易混淆,说不清具体的差别。在这里我梳理一下以作为记录,方便自己查阅,也方便感兴趣的朋友查阅,希望对大家有所帮助。

1.Login

Login的官方解释是:数据库引擎登录名。(http://msdn.microsoft.com/zh-cn/library/ms189751.aspx)Login 是服务器(Server)级别的概念,也就是说如果你有一个Login的账号和密码,你就能登录到这台Server的数据库引擎。登录数据库引擎意味着什么呢?意味着你可以查看master,msdb,tempdb数据库,但是无法查看model数据库,对于用户创建的数据库,对不起,没有任何操作权限。

那么我们如何才能操作数据库呢?我们需要User.

创建Login的语句如下:

--Create Login
--Windows Authentication
create login [ReportLogin] from windows with default_database = [master],default_language = [us_english]
--SQL Server Authentication
create login [ReportLogin] with password = N'123456',default_database = [master],default_language = [us_english]

2.User

User属于数据库对象,不属于Server对象,因此我们如果想创建一个User,首先必须进入到想创建User的数据库中(use该数据库),然后创建User

创建User的语句如下:

--Create User
use DBDemo;
create user [ReportUser] for login [ReportLogin] with default_schema = ReportSchema
一个User对应一个Login,一个Login可以有多个User。对于同一个Login,我们针对一个数据库只能创建一个User。如果我们再次创建账户就会得到一个错误。

注意到我们创建User的时候我们指定了一个默认的Schema,这个又是什么呢?

3.Schema

Schema翻译成中文是架构。数据库架构是为了方便对数据库对象进行管理,就像我们自己的文件夹目录会分为学习资料,音乐视频,公司资料三个schema一样,数据库默认的schema是dbo。数据库对象的管理方式是:User->Schema->Object.这个非常类似仓库的管理方式,每个提货的人跟货物类型先关联起来,减少了直接针对货物编码的索引,大大简化了操作过程。

4.Role

角色这个概念是为了降低管理成本,简化管理的工作量而出现的。如果要针对1000个用户给定权限,需要勾选1000次,这个非常繁琐,那么我们只需要将这些人加入到某个角色,让这个角色的人都具有某个权限即可。

一些常见角色

Server Roles:

bulkadmin

dbcreator

diskadmin

processadmin

public ---- 每个新建login的默认Server Role

securityadmin

serveradmin

setupadmin

sysadmin

Database Roles:

db_accessadmin

db_backupopeator

db_datareader

db_datawriter

db_ddladmin

db_denydatareader

db_denydatawriter

db_owner

db_securityadmin

public




推荐阅读
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • Windows服务与数据库交互问题解析
    本文探讨了在Windows 10(64位)环境下开发的Windows服务,旨在定期向本地MS SQL Server (v.11)插入记录。尽管服务已成功安装并运行,但记录并未正确插入。我们将详细分析可能的原因及解决方案。 ... [详细]
  • 优化联通光猫DNS服务器设置
    本文详细介绍了如何为联通光猫配置DNS服务器地址,以提高网络解析效率和访问体验。通过智能线路解析功能,域名解析可以根据访问者的IP来源和类型进行差异化处理,从而实现更优的网络性能。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 如何配置Unturned服务器及其消息设置
    本文详细介绍了Unturned服务器的配置方法和消息设置技巧,帮助用户了解并优化服务器管理。同时,提供了关于云服务资源操作记录、远程登录设置以及文件传输的相关补充信息。 ... [详细]
  • 本文详细介绍了如何在 Linux 平台上安装和配置 PostgreSQL 数据库。通过访问官方资源并遵循特定的操作步骤,用户可以在不同发行版(如 Ubuntu 和 Red Hat)上顺利完成 PostgreSQL 的安装。 ... [详细]
  • 深入理解 Oracle 存储函数:计算员工年收入
    本文介绍如何使用 Oracle 存储函数查询特定员工的年收入。我们将详细解释存储函数的创建过程,并提供完整的代码示例。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 在 Windows 10 中,F1 至 F12 键默认设置为快捷功能键。本文将介绍几种有效方法来禁用这些快捷键,并恢复其标准功能键的作用。请注意,部分笔记本电脑的快捷键可能无法完全关闭。 ... [详细]
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
  • 理解存储器的层次结构有助于程序员优化程序性能,通过合理安排数据在不同层级的存储位置,提升CPU的数据访问速度。本文详细探讨了静态随机访问存储器(SRAM)和动态随机访问存储器(DRAM)的工作原理及其应用场景,并介绍了存储器模块中的数据存取过程及局部性原理。 ... [详细]
  • 本文介绍如何通过注册表编辑器自定义和优化Windows文件右键菜单,包括删除不需要的菜单项、添加绿色版或非安装版软件以及将特定应用程序(如Sublime Text)添加到右键菜单中。 ... [详细]
  • 本文探讨了在不使用服务器控件的情况下,如何通过多种方法获取并修改页面中的HTML元素值。除了常见的AJAX方式,还介绍了其他可行的技术方案。 ... [详细]
author-avatar
真实的小莹_808
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有