SQLServer 学习笔记之超详细基础SQL语句 Part 10
Sqlserver 学习笔记
-----------------------接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.IF-ELSE语句
SQL中的IF-ELSE语句
IF
(条件)
BEGIN
语句1
语句2
……
END
ELSE
BEGIN
语句1
语句2
……
END
注意:
ELSE是可选部分
如果有多条语句,才需要BEGIN-END语句块
实例
问题:
统计并显示本班笔试平均分,如果平均分在70以上,显示“成绩优秀“,并显示前三名学员的考试信息;如果在70以下,显示“本班成绩较差“,并显示后三名学员的考试信息
。
分析:
第一步,统计平均成绩存入临时变量;
第二步,用IF-ELSE判断;
SQLServer 学习笔记之超详细基础SQL语句 Part 10的更多相关文章
- SQLServer 学习笔记之超详细基础SQL语句 Part 3
Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 2------------------- 13. 使用compute对查 ...
- SQLServer 学习笔记之超详细基础SQL语句 Part 12(The End)
Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 11------------------- 现在,我们希望从 " ...
- SQLServer 学习笔记之超详细基础SQL语句 Part 11
Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 10------------------- DECLARE @myavg ...
- SQLServer 学习笔记之超详细基础SQL语句 Part 9
Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 8------------------- 3 范式的概念 第一范式的目标 ...
- SQLServer 学习笔记之超详细基础SQL语句 Part 8
Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 7------------------- --触发器str_trigge ...
- SQLServer 学习笔记之超详细基础SQL语句 Part 7
Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 6------------------- 29 存储过程和触发器 存储过 ...
- SQLServer 学习笔记之超详细基础SQL语句 Part 6
Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 5------------------- 28 聚合函数 --求平均分 ...
- SQLServer 学习笔记之超详细基础SQL语句 Part 5
Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 4------------------- 21使用默认 默认(也称默认值 ...
- SQLServer 学习笔记之超详细基础SQL语句 Part 4
Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 3------------------- 17 带比较运算符的嵌套查询 ...
随机推荐
- odoo开发笔记-- 按钮动作跳转到其他列表视图默认搜索
按钮动作跳转到其他列表视图 按照默认指定的条件搜索显示. 效果: 实现方式:
- redhat_6.5下载地址
redhat官方下载(需要注册帐号+订阅/申请试用方可下载) https://access.redhat.com/downloads/ 网络资源:附RHEL 6.5安装文件MD5及SHA-256:一. ...
- Oracle数据库导入报ORA-39083处理
------故障描述--------------------报错信息:ORA-39083: 对象类型 DEFAULT_ROLE 创建失败, 出现错误:ORA-01919: 角色 'ROLE_EMSP' ...
- MapReduce中的partitioner
1.日志源文件: 1363157985066 13726230503 00-FD-07-A4-72-B8:CMCC 120.196.100.82 i02.c.aliimg.com 24 27 2481 ...
- fastjson的JSONArray转化为泛型列表
背景:一个复杂结构体内部可能有array的数据,例如:{name:"test",cities:[{name:"shanghai",area:1,code:200 ...
- ASP.NET Core 与 .NET Core 演变与基础概述
https://github.com/dotnet/corehttps://github.com/aspnet/home 今天看到 .NET Core 的改名计划,感觉跨平台的时代快要来了,从之前的 ...
- mysql笔记-索引
什么是聚簇索引 聚簇索引:索引的叶节点就是数据节点(索引值).而非聚簇索引的叶节点仍然是索引节点(告诉你怎么在表中查找这一记录),只不过有一个指针指向对应的数据块. Innodb和MyIsam区别 转 ...
- CNN初探
CNN初探 版权声明:本文为博主原创文章,转载请指明转载地址 http://www.cnblogs.com/fydeblog/p/7450413.html 前言 这篇博客主要讲解卷积神经网络(CNN) ...
- HTTPS原理简述
角色: A,B,Server,Client,中间窃听者,数字证书签发机构(CA) 工具:对称加密算法,非对称加密算法,数字签名,数字证书 第一步,爱丽丝给出协议版本号.一个客户端生成的随机数(Cl ...
- 我的Visual Studio必用工具
自己备用 代码生成工具:Resharper 代码颜色:supercharger 高亮单词 Word highlight with margin Productivity Power Tools 详细介 ...