文章详情

短信预约信息系统项目管理师 报名、考试、查分时间动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

sql 基础

2015-02-24 23:52

关注

去除数据库登录界面的所有用户信息

C:UsersasusAppDataRoamingMicrosoftSQL Server Management Studio14.0SqlStudio.bin

查询姓名中第二个字与第三个字相同:

select * from Student s2 where SUBSTRING(s2.sname,2,1)=SUBSTRING(s2.sname,3,1)

用户授权

1 创建用户

create login names with password='pwd' , default_database=test;
create user names for login names with default_schema=dbo;

2 增删改查授权

grant select,insert,UPDATE,DELETE on 表 to names

3 创建表

grant create table to names 
GRANT ALTER ON SCHEMA::dbo TO names;

4 存储过程授权

GRANT EXECUTE ON 存储过程名 TO username

5 禁止对表授权

DENY UPDATE ON 表 TO username CASCADE;

6 回收权限

REVOKE DELETE ON 表 FROM username

7 删除表

truncate table a
delete from dbo.a
drop table a

8 修改列

alter table a add sa nvarchar(10) not null
Alter Table a Add Constraint PK_Course_Cno Primary Key(id)
ALTER TABLE a ALTER COLUMN id int
ALTER TABLE a DROP CONSTRAINT PK_a
alter table a drop column sa

9 创建一个简单的登录,登录名为:newlogin;登录密码:123456;默认数据库:master,默认数据库也可以不指定。

EXEC sp_addlogin 'newlogin','123456','master'

10 创建用户

EXEC sp_adduser 'newlogin'
EXEC sp_adduser 'newlogin','newuser'
EXEC sp_addrole 'newrole'
EXEC sp_adduser 'newlogin','newuser','newrole'
GRANT ALL ON jobs TO newrole
GRANT SELECT,UPDATE ON sales TO newrole
DENY INSERT ON employees TO newrole
EXEC sp_grantdbaccess 'newlogin','newuser'
EXEC sp_addrolemember 'newrole','newuser'
EXEC sp_revokedbaccess 'newuser';
EXEC sp_droplogin 'newlogin'
EXEC sp_droprole 'newrole'
EXEC sp_droprolemember 'newrole', 'newuser'
CREATE LOGIN mylogin WITH PASSWORD = '123456' MUST_CHANGE;
CREATE LOGIN mylogin WITH PASSWORD = '123456',
CREDENTIAL = mycredential;
CREATE LOGIN [jackxiangzhao] FROM WINDOWS;
CREATE USER myuser FOR LOGIN mylogin
CREATE ROLE myrole AUTHORIZATION myuser;
CREATE ROLE myrole AUTHORIZATION db_role

规则

1 创建雇佣日期规则 hire_date_rule

CREATE RULE hire_date_rule
AS @hire_date>='1980-01-01' and @hire_date<=getdate()

2 创建性别规则sex_rule

CREATE RULE sex_rule
AS @sex in ('男','女')

3 -创建评分规则grade_rule

CREATE RULE grade_rule
AS @value between 1 and 100

4 创建字符规则my_character_rule

Create rule my_character_rule
As @value like '[a-z]%[0-9]' 

5 sp_helptext 查看规则,查看规则hire_date_rule的文本信息

EXECUTE sp_helptext hire_date_rule

6 sp_bindrule绑定规则

EXEC sp_bindrule hire_date_rule, 'employee.hire_date'
EXEC sp_addtype pat_char,'varchar(10)','NOT NULL'
EXEC sp_bindrule my_character_rule, pat_char, 'futureonly';

7 sp_unbindrule 解除规则的绑定

EXEC sp_unbindrule 'employee.hire_date';
* DROP RULE语句删除当前数据库中的一个或多个规则
DROP RULE sex_rule,hire_date_rule 

分页

select * from (
select * ,ROW_NUMBER() over(order by sid) as rowcindex --增加索引
from Student) as t
where t.rowcindex between 1 and 3;

分裂与合并

select s.sid,s.sname,
max(case c.cname when '语文' then sc.score end) as '语文',
min(case c.cname when '数学' then sc.score end) as '数学',
sum(case c.cname when '英语' then sc.score end) as '英语',
max(case c.cname when '化学' then sc.score else 0 end) as '化学'
from (Student as s inner join SC as sc on s.sid=sc.sid
inner join Course as c on c.cid=sc.cid)
group by s.sid,s.sname;

T-sql

1 全局变量

select @@VERSION --数据库版本
insert into Course values('',''); select @@IDENTITY --获取最近insert语句的标识
print @@servername --服务器名称
print @@rowcount--返回受影响的行数

2 选择语句

declare @id int
set @id =10
if @id>5
begin
    print 'ok'
end
else
begin
    print 'no'
end

3 循环语句

declare @id int
set @id=1
while @id<10
begin 
    print @id
    set @id=@id+1
end

4 异常

begin try
    delete from SC--不能成功
end try
begin catch
    print @@error --判断错误信息 0对
end catch

5 事务:回滚函数

begin try
    begin transaction --开启事务
    --错误SQL
    commit tran --提交事务
end try
begin catch
    rollback tran --回退事务
end catch

6 锁:同步

begin tran --锁上
     --修改操作
rollback tran --开锁 commit tran
阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯