Sqlserver 学习笔记

by:授客 QQ1033553122

-----------------------接Part 9-------------------

删除约束的语法

ALTER TABLE 表名

DROP CONSTRAINT 约束名

6 创建登陆

--添加SQL登陆账户(用户账号:laiyu, 密码:1234)

USE student

GO

EXEC SP_ADDLOGIN 'laiyu', '1234'

双击登录名laiyu后可以进行密码的修改等

7 创建数据库用户

需要调用系统存储过程:

SP_GRANTDBACCESS ‘登录名’ ‘对应数据库用户账户’

创建用户还可以用sp_adduser。SP_GRANTDBACCESS的执行过程中也会使用sp_adduser,但是在安全性上要比sp_adduser好,因为它能建立一个安全性连接,如果仅仅从添加的用户来说,两者创建的用户没有设么本质的区别

--创建用户

EXEC SP_GRANTDBACCESS 'laiyu', 'username'

其中,“数据库用户名“为可选参数,默认为登录帐户,即数据库用户默认和登录帐户同名。

--在数据库student中添加两个用户

USE student

GO

EXEC SP_GRANTDBACCESS 'jbtrain\s123', 's123dbuser'

说明:jbtraining为计算机域名

EXEC SP_GRANTDBACCESS 'zhangsan', 'zdbuser'

--结果提示出错,因为登陆名不存在

8 授权的语法为:

GRANT 权限 [ON  表名 ]  TO  数据库用户

--授权

USE stuDB

GO

GRANT SELECT,INSERT,UPDATE

ON stuInfo TO laiyu

USE stuDB

GO

GRANT create table TO laiyu

禁用权限的语法为:

DENY 权限 [ON  表名 ]  TO  数据库用户

--禁用权限

USE stuDB

GO

DENY select,insert,update

ON stuInfo TO laiyu

--禁用权限

DENY SELECT, INSERT, UPDATE

ON std_table TO laiyu

--删除权限

--回收laiyu用户的建立表的权限[可以级联CASCADE或者有限制的(RESTRICT)的回收用户的权限]

REVOKE CREATE TABLE FROM laiyu

9 使用变量

变量分为:

1)   局部变量:

a)   局部变量必须以标记@作为前缀 ,如@age

b)   局部变量的使用也是先声明,再赋值

2)   全局变量:

a)   全局变量必须以标记@@作为前缀,如@@version

b)   全局变量由系统定义和维护,我们只能读取,不能修改全局变量的值

局部变量

声明局部变量

DECLARE @变量名  数据类型

赋值

SET @变量名 =值

或 SELECT  @变量名 = 值 FROM 表

--局部变量的声明与赋值

DECLARE @name CHAR(6)

DECLARE @deptNo CHAR(2)

--或者如下

--DECLARE @name CHAR(6), @deptNo CHAR(2)

SET @name = '张三'

--或者如下方式

SELECT @deptNo = 系部代码 FROM std_table WHERE 高考分数= 500;

--这里要注意,执行的时候必须把声明和使用一起执行,即选定声明和使用声明的语句,然后执行,否则会出现“须声明标量变量"@deptNo"”的错误提示

示例

问题:

编写T-SQL查找李文才的左右同桌 ?

分析:

第一步,找出“李文才“的座位号;

第二步,李文才的座位号加1或减1

DECLARE @name VARCHAR(7)--学员姓名

SET @name='李文才'--使用SET 赋值

SELECT * FROM stuInfo WHERE stuName = @name

DECLARE @seat INT --座位号

SELECT @seat=stuSeat FROM stuInfo --使用SELECT 赋值

WHERE stuName=@name

SELECT * FROM stuInfo

WHERE(stuSeat = @seat+1) OR (stuSeat = @seat-1)

GO

WHERE stuName=@name

SELECT * FROM stuInfo

WHERE(stuSeat = @seat+1) OR (stuSeat = @seat-1)

GO


 


全局变量
(使用两个@@作为前缀标识)

 

全局变量示例

--打印

PRINT
'SQL Server的版本'

+ @@VERSION

PRINT
'SQL Server的名称'

+ @@SERVERNAME

--先执行下下面这条错误语句,再打印错误号

INSERT
INTO std_table(学号,

姓名,

专业方向)

VALUES(1,'jjk',信息管理)

--如果错误号大于表示上一条语句,执行有错

10
逻辑控制语句

1.IFELSE语句

SQL中的IF-ELSE语句

IF

(条件)

BEGIN

语句1

语句2

……

END

ELSE

BEGIN

语句1

语句2

……

END

注意:

ELSE是可选部分

如果有多条语句,才需要BEGIN-END语句块


实例

问题:

统计并显示本班笔试平均分,如果平均分在70以上,显示“成绩优秀“,并显示前三名学员的考试信息;如果在70以下,显示“本班成绩较差“,并显示后三名学员的考试信息

分析:

第一步,统计平均成绩存入临时变量;

第二步,用IF-ELSE判断;

SQLServer 学习笔记之超详细基础SQL语句 Part 10的更多相关文章

  1. SQLServer 学习笔记之超详细基础SQL语句 Part 3

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 2------------------- 13. 使用compute对查 ...

  2. SQLServer 学习笔记之超详细基础SQL语句 Part 12(The End)

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 11------------------- 现在,我们希望从 " ...

  3. SQLServer 学习笔记之超详细基础SQL语句 Part 11

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 10------------------- DECLARE @myavg ...

  4. SQLServer 学习笔记之超详细基础SQL语句 Part 9

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 8------------------- 3 范式的概念 第一范式的目标 ...

  5. SQLServer 学习笔记之超详细基础SQL语句 Part 8

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 7------------------- --触发器str_trigge ...

  6. SQLServer 学习笔记之超详细基础SQL语句 Part 7

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 6------------------- 29 存储过程和触发器 存储过 ...

  7. SQLServer 学习笔记之超详细基础SQL语句 Part 6

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 5------------------- 28 聚合函数 --求平均分 ...

  8. SQLServer 学习笔记之超详细基础SQL语句 Part 5

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 4------------------- 21使用默认 默认(也称默认值 ...

  9. SQLServer 学习笔记之超详细基础SQL语句 Part 4

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 3------------------- 17 带比较运算符的嵌套查询 ...

随机推荐

  1. [Umbraco] Data Type的扩展编程

    继续从上面的Data Types的自定义控件说起.前面用到了自定义控件的数据绑定,虽然这使得我们可以调用外部数据了,但这似乎还比较死板,如果再调用其他数据,还得再创建一个控件,那样的话就会出现类似的功 ...

  2. 课程一(Neural Networks and Deep Learning),第二周(Basics of Neural Network programming)—— 0、学习目标

    1. Build a logistic regression model, structured as a shallow neural network2. Implement the main st ...

  3. 广度优先遍历-BFS、深度优先遍历-DFS

    广度优先遍历-BFS 广度优先遍历类似与二叉树的层序遍历算法,它的基本思想是:首先访问起始顶点v,接着由v出发,依次访问v的各个未访问的顶点w1 w2 w3....wn,然后再依次访问w1 w2 w3 ...

  4. MVC源码分析 - Action/Result 过滤器(续)

    上一篇 看到了Action/Result过滤器的执行顺序: OnActionExecuting -> Action -> OnActionExecuted -> OnResultEx ...

  5. 使用ssh-keygen生成ssh公钥和私钥

    默认是在用户目录下: windows一般为 c:\User\username\.ssh下 linux一般为 /home/username/.ssh 生成的命令如下: ssh-keygen -t rsa ...

  6. 进程间通信 IPC(Inter-Process Communication)

    目录 一.管道 二.FIFO 三.消息队列 四.信号量 五.共享存储 六.网络IPC:套接字   一.管道 管道是进程间通信中最古老的方式,所有UNIX都提供此种通信机制.管道有以下两种局限性: 历史 ...

  7. multimap多重映照容器(常用的方法总结)

    multimap和map的不同之处在于前者允许重复键值的元素出现. /*关于C++STL中mulitmap的学习,与map不同的是,multimap允许插入重复键值的元素*/ #include < ...

  8. C# Azure 设置云端应用程序的默认时间

    在微软云Azure中,应用程序(website)的默认时间是按照美国UTC的时间的. 例如,在应用程序中获取DateTime.Now,的时候,是获取UTC的时间,不是中国的时间. 所以我们开始在这里设 ...

  9. [转]NodeBB 环境搭建

    本文转自:https://my.oschina.net/pauli/blog/198405 摘要: Windows 7 下面 NodeBB (https://nodebb.org/)环境搭建      ...

  10. 在iframe窗体内 获取父级的元素;;在父窗口中获取iframe中的元素

    在iframe中获取父窗口的元素 $(‘#父窗口中的元素ID’, parent.document).click(); 在父窗口中获取iframe中的元素 $(“#iframe的ID”).content ...