SQL第二章(T-SQ编程)


1、批处理
/*--------------------------------------------批  处  理-----------------------------------------------------*/
    -- GO
        --可以使不在同一批处理中的sql语句相互之间不受影响 
        --把相互联系的放在同一批次,没联系的放在不同批次
        --批处理中某一条语句出现编译错误时,其他语句不受影响

    create table T
    (
        id int primary key identity(1,1)
    )
    
    create table t1
    (
        id int references T(tid) --出错了
    )
    go
    create table t2
    (
        id int references T(id) --不受影响部范围内有效

2、局部变量
/*--------------------------------------------变  量  分  类-----------------------------------------------------*/
    /*--局部变量--*/
    ①局部变量必须用@前缀
    ②先声明,再赋值
    ③只在定义它的局部范围内有效

        --声明变量  
            --DECLARE @变量名  数据类型
            DECLARE @id char (10)   --声明一个长度为个字符的变量id
            DECLARE @age int   --声明一个存放职员年龄的整型变量

        --变量赋值 
            --SET @变量名 = 值 :用于普通的赋值
            SET @age = 20
            --SELECT  @变量名 = 值:用于从表中查询数据并赋值
            SELECT @id = '11111'

        --使用变量            
            --找王五学号前后的同学
            declare @sid int 
            select @sid = stuid  from StuInfo where stuname='王五'
            print '王五的学号为:' + convert(varchar(20),@sid)
            select * from StuInfo where stuid=@sid-1 or stuid=@sid+1
            
            --注意:使用select 进行赋值时如果查询到的是一个结果集 那么变量得到的值是最后一条记录        
    
            --查询表中学号最小的学生姓名。
            declare @stuname  varchar(20)
            select @stuname = stuname from StuInfo order by stuid desc
            print @@error --错误代号
            print @stuname
    /*--全局变量--*/
    ①全局变量必须以@@作为前缀
    ②只能读取,不能修改
    ③全局变量在整个SQL环境下都可以被访问或调用

        --是以@@全局变量名   全局变量只能使用,由系统定义。我们不能更改和定义   @@ERROR
        --@@ERROR    最后一个T-SQL错误的错误号
        --@@IDENTITY    最后一次插入的标识值
        --@@ROWCOUNT    受上一个SQL语句影响的行数
        PRINT @@IDENTITY

3、/*--------------------------------------------输  出  语  句----------------------------------------------------
-*/
    --print  变量或表达式:以消息形式进行显示
        PRINT '数据库服务器名:' + @@SERVICENAME
        print 15 * 8
    
    --select 变量或表达式:以表格形式进行显示
        SELECT 15 * 8 
        select '数据库服务器名:' + @@SERVICENAME

    --强制类型转换 convert(要转成的数据类型,要转换的值)


4、
/*--------------------------------------------逻  辑  控  制-----------------------------------------------------*/
    /*--分支结构--*/

        --1.IF-ELSE语句

            --if(条件)
            --    begin
            --        T-SQL语句  
            --    end
            --else if (条件)
            --    begin
            --        T-SQL语句  
            --    end
            --else
            --    begin
            --        T-SQL语句  
            --    end

            ---统计男生的平均成绩和女生的平均成绩
            declare @avgman float
            declare @avggirl float
            select @avgman=avg(score) from StuMarks,StuInfo  where   StuInfo.stuid=StuMarks.stuid   and
stusex='男'
            select  @avggirl=avg(score) from StuMarks,StuInfo where   StuInfo.stuid=StuMarks.stuid  and
stusex='女'
            if (@avgman>@avggirl)
                begin
                    print '男生优于女生'
                    --获取男生第一名的成绩
                    select top 1 sum(score) as '总分',StuInfo.stuid,stuname  from StuMarks
,StuInfo where StuInfo.stuid=StuMarks.stuid and stusex='男'            
                    group by StuInfo.stuid,stuname  order by '总分' desc
                end
            else if(@avgman<@avggirl)
                begin
                    print '女生优于男生'
                    --获取男生第一名的成绩
                    select top 1 sum(score) as '总分',StuInfo.stuid  from StuMarks ,StuInfo
where StuInfo.stuid=StuMarks.stuid and stusex='女'            
                    group by StuInfo.stuid  order by '总分' desc
                end
            else
                begin
                    print '男女平等'
                end

        --2.CASE-END语句

            --CASE    
            --    WHEN   条件1  then   结果1
            --    WHEN   条件2  then   结果2
            --    [ELSE 结果]
            --END

            --成绩分等级
            select stuname as 姓名,成绩 = case
                    when score >= 90 then 'A'
                    when score >= 80 then 'B'
                    when score >= 70 then 'C'
                    when score >= 60 then 'D'
                    else 'E'
                end
            from StuInfo,StuMarks where StuInfo.stuid = StuMarks.stuid and  [subject] = 'SQL'

    /*--循环控制语句--*/
        --while(循环控制条件)
        --    begin 
        --        T-SQL语句
        --    end

        declare @mark int,@markid int
        select @mark = score,@markid = StuMarksno  from StuMarks where subject = 'html'
        while @mark < 90
            begin
                update StuMarks set score = @mark+1 WHERE StuMarksno = @markid
                select @mark = score,@markid = StuMarksno  from StuMarks where subject = 'html'
            end
        print @score --90

        

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQL Server 2005微软官方权威参考手册     是Inside Microsoft SQL Server 2005系列书中的第一本,SQL Server类的顶尖之作   全球公认SQL Server 2005经典著作,囊括大量鲜为人知的技术内幕,大师智慧、专家经验尽览无余。       本系列图书中文版得到了微软总部SQL Server组专家的高度重视,同时也得到了微软中国上海SQL Server全球技术支持中心的高度关注。        本书详细介绍了T-SQL的内部构造,包含了非常全面的编程参考。数据库开发人员和DBA可以通过书中的最佳实践、高级技巧和代码示例来掌握这门复杂的编程语言,以切合实际的方案来解决复杂的问题。本书涵盖了T-SQL程序设计的方方面面,如基于集合的编程技术、日期和时间相关的XML和CLR数据类型的使用、临时对象、T-SQL和CLR用户自定义函数、存储过程、触发器、事务和新的错误处理结构、应用并发模型支持并发用户、使用Service Broker来控制数据库应用程序中的异步处理等。   内容简介 本书是Inside Microsoft SQL Server 2005系列四本著作中的一本。它详细介绍了T-SQL的内部构造,包含了非常全面的编程参考。它提供了使用Transact-SQL(T-SQL)的专家级指导,T-SQL是用于SQL Server的最常见的也是功能最强大的编程语言。该书由Itzik Ben-Gan权威执笔,重点关注语言特性以及它们如何被SQL Server引擎解释和处理。   通过本书,你将深入了解T-SQL的高级用法,包括触发器、用户自定义函数、异常处理等。该书解释并比较了SQL Server 2000和SQL Server 2005在数据库开发相关问题上的解决方案,深入讨论了SQL Server 2005中新增的T-SQL编程特性,包含了大量的代码示例、表示例和逻辑难题以帮助数据库开发人员和管理员理解复杂的逻辑并掌握T-SQL。   本书适合于专业数据库开发者、BI开发者、DBA和以SQL Server作为后台数据库的一般应用程序开发者,读者可以通过书中的最佳实践、高级技巧和代码示例来掌握这门复杂的编程语言,以切合实际的方案来解决复杂的实际问题。 作者简介 Itzik Ben-Gan是Solid Quality Learning的导师和创始人。从1999年开始,他一直是Microsoft SQL Server MVP(最有价值专家),并在全世界已经开展过无数次T-SQL查询、T-SQL优化和编程方面的培训。Itzik是Microsoft SQL Server方面几本著作的作者。他在SQL ServerMagazine和MSDN上发表了许多文章和白皮书。Itzik被邀请在许多会议上做报告,包括TechEd、DevWeek、世界各地的各种SQL用户组、PASS、SQL server Magazine Connections和Solid Quality Learning的会议。 从1992年开始,Itzik就一直致力于涉及各种数据库和计算机系统相关技术的多个课题。除了帮助顾客处理紧迫的要求、修复问题、优化数据库、教学和担任顾问以外,他还帮助开发人员和数据库管理员转变关系/基于集合的理念,改善他们编写代码的性能和可维护性。Itzik擅长T-SQL查询、查询优化、编程和内部原理,此外他还精通其他的数据库领域。1999年,Itzik创立以色列SQL Server和OLAP用户组,一直管理至今。 目录 序 前言 致谢 引言 第1章 数据类型相关的问题,XML和CLR UDT 1.1 DATETIME数据类型 DATETIME的存储格式 时间处理   Datetime相关的查询问题  1.2 与字符相关的问题   模式匹配   区分大小写(Case-Sensitive)的筛选器  1.3 大型对象(Large Object,LOB)   MAX 说明符   BULK行集提供程序  1.4 隐式转换(Implicit Conversion)   标量表达式   筛选表达式  1.5 基于CLR的用户定义类型   UDT理论简介   开发UDT  1.6 XML数据类型   关系数据库中的XML支持   什么时候应该使用XML代替关系表现形式?   数据库中的XML序列化对象   使用开放架构(Open Schema)的XML   作为存储过程参数的XML数据类型   Xquery修改语句  1.7 结论 第2章 临时表和表变量  2.1 临时表   局部临时表   全局临时表  2.2 表变量   限制条件   tempdb   范围和可见性   事务上下文   统计信息  2.3 tempdb相关的注意事项  2.4 表表达式  2.5 比较临时对象  2.6 综合练习——关系分区(Relational Division)  2.7 结论 第3章 游标  3.1 使用游标  3.2 游标开销  3.3 单独处理每一行  3.4 按顺序访问   自定义聚合   连续聚合   最大并发会话   匹配问题  3.5 结论 第4章 动态SQL 第5章 视图 第6章 用户定义函数 第7章 存储过程 第8章 触发器 第9章 事务 第10章 错误处理 第11章 Service Broker 附录A CLR程序指南 A.1 创建CLRUtilities数据库: SQL Server A.2 部署:Visual Studio A.3 部署和测试:Visual Studio 和 SQL Server 索引 中英文术语对照表

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值