编程基础

注释

注释命名来对一些语句进行说明,便于日后维护或者其他用户理解,注释不会执行。

单行注释

SELECT GETDATE() --查询当前日期

多行注释

/*
注释有助于
理解操作的内容
查询当前日期
*/
SELECT GETDATE()

变量

在T-SQL执行命令时,可以申明变量临时存储各种数据,申明时被初始化为NULL,只能代替数值,不能代替对象或关键字

局部变量

必须先用DECLARE 语句定义,局部变量在名称前加@

SELECT 赋值语句哟啊保证结果不超过一条数据,否则将会把最后一条数据赋予变量

/*申明变量*/
DECLARE @name VARCHAR(10)
/*赋值变量*/
SET @name='LUCAS'
/*输出变量*/
SELECT @name

全局变量

sqlserver系统内部使用的变量,作用范围是整个系统的任何程序,以@@开头,常用的全局变量有:

@@ERROR,最后一个T-SQL错误代码

@@IDENTITY,最后一个插入的标示值

@@LANGUAGE,当前使用的语言

@@ROWCOUNT,受上一个SQL语句影响的行数

@@SERVERNAME,本地服务器名称

@@VERSION,sqlserver版本信息

PRINT @@ERROR
PRINT @@IDENTITY
PRINT @@LANGUAGE
PRINT @@ROWCOUNT
PRINT @@SERVERNAME
PRINT @@VERSION

输出为

输出语句

PRINT 使用中文方式输出

SELECT 使用表格方式输出

批处理语句

批处理是一个T-SQL语句集,集合中的语句一起提交给sqlserver作为一个整体执行。GO就是批处理标志。

sqlserver会将批处理编译成一个可执行单元(执行计划),提高执行效率。

一般情况,一些操作放在同一个批处理命令,但是如果是创建数据库或其他对象的语句,则必须在结尾添加GO,便于与其他命令分开执行。

批处理有3种限制:

  • CREATE 语句不能与其他语句组合使用
  • 如果批处理命令有改字段名称,则不能在同一个批处理中使用该字段新名称
  • 如果EXECUTE 语句是批处理第一句,则可以省略EXECUTE关键字,否则不可以省略

IF...ELSE语句

统计商品平均价格,如果均价在2000元以上输出“总体价格较贵”,并显示最贵商品信息;如果在2000以下,显示“总体价格便宜”,并显示最便宜商品信息。

DECLARE @avgjg FLOAT
--获取均价
SELECT @avgjg=AVG(进价) FROM 商品表
PRINT '所有商品的均价为:'+CONVERT(VARCHAR(5),@avgjg) --进行判断
IF(@avgjg>=2000)
BEGIN
PRINT '总体价格较贵,最贵商品是:'
SELECT TOP 1 * FROM 商品表 ORDER BY 进价 DESC
END
ELSE
BEGIN
PRINT '总体价格便宜,最便宜商品是:'
SELECT TOP 1 * FROM 商品表 ORDER BY 进价
END

  注意:如果需要将表格数与文本数据同时显示,需要设置:工具-》选项-》查询结果-》显示结果的默认方式,选择以文本格式显示结果

WHILE语句

将所有销售利润在10%以下商品的销售价格增加10元,如果仍有商品销售利润在10%以下的,在增加10元,直到所有商品价格利润都在10%以上,最后显示增加最多的商品增加的钱数。

PRINT '开始更新销售额偏低商品的价格'
DECLARE @cs INT
SET @cs=0
WHILE ((SELECT COUNT(*) FROM 商品表 WHERE 销售价/进价<1.1)>0)
BEGIN
UPDATE 商品表
SET 销售价=销售价+10
WHERE 销售价/进价<1.1
SET @cs=@cs+10
IF((SELECT COUNT(*) FROM 商品表 WHERE 销售价/进价<1.1)=0)
BREAK
END
PRINT '增加最多的商品,增加了:'+CONVERT(VARCHAR(8),@cs)+'元'
GO

多分支语句CASE

对A牌所有商品分类,进价高于3000元为高价商品,1000-3000元为中价商品,1000以下为低价商品

SELECT 商品名称,型号,进价=
CASE
WHEN 进价>3000 THEN '高价商品'
WHEN 进价 BETWEEN 1000 AND 3000 THEN '中价商品'
WHEN 进价<1000 THEN '低价商品'
END
FROM 商品表

SQL Serever学习13——数据库编程语言的更多相关文章

  1. SQL Serever学习12——数据库的备份和还原

    公司的服务器奔溃了,事先没相应的保护措施,使得公司遭到了较大损失,为了以后不再出现类似事件,在系统中引入备份机制,使得数据库被破坏后损失降到最低. 数据的导出和导入 数据转换服务 数据转换服务DTS( ...

  2. SQL Serever学习17——数据库的分析和设计

    数据库的分析和设计 设计数据库确定一个合适的数据模型,满足3个要求: 符合用户需求,包含用户所需的所有数据 能被数据库管理系统实现,如sqlserver,oracle,db2 具有比较高质量,容易理解 ...

  3. SQL Serever学习11——数据库的安全管理

    公司管理软件设计完成,但是日常工作繁忙,向领导提出增加几个管理员,帮助管理和维护系统,领导同意了,但是要求一定要管理好这几个管理员用户,保证数据库的安全. 修改身份验证模式 数据库验证机制 sqlse ...

  4. SQL Serever学习5——数据库配置

    数据库的主要属性 限制访问 用来设置数据允许用户访问的状态,或者说允许多少客户访问,有3个选项: MULTI_USER(多个),大多数数据库正常状态,允许多个用户同时访问该数据库. SINGLE_US ...

  5. SQL Serever学习4

    SQL Server系统中数据库相关概念 在SQLServer数据库系统中分为2大类,系统数据库和用户数据库. SQLServer安装后系统会自动生成4个系统数据库,他们是Master,Model,M ...

  6. SQL基础学习_01_数据库和表

    SQL语句及其种类 1. SQL语句分为三类:     DDL(Data Definition Language): CREATE.DROP.ALTER;     DML(Data Manipulat ...

  7. SQL Serever学习16——索引,触发器,数据库维护

    sqlserver2014数据库应用技术 <清华大学出版社> 索引 这是一个很重要的概念,我们知道数据在计算机中其实是分页存储的,就像是单词存在字典中一样 数据库索引可以帮助我们快速定位数 ...

  8. SQL Serever学习15——进阶

    特别说明:在sqlserver2014中,不区分大小写,也就是说,SQL是大小写不敏感的 数据库模型3类: 层次模型 网状模型 关系模型 关系型数据库语言3种: DDL数据定义语言 CREATE(创建 ...

  9. SQL Serever学习14——存储过程和触发器

    存储过程 在数据库中很多查询都是大同小异,编写他们费时费力,将他们保存起来,以后执行就很方便了,把SQL语句“封装”起来. 存储过程的概念 存储过程是一组SQL语句集,经过编译存储,可以”一次编译,多 ...

随机推荐

  1. 激活IDEA,pycharm方法

    1.修改hosts文件将0.0.0.0 account.jetbrains.com添加到hosts文件最后,注意hosts文件无后缀,如果遇到无法修改或权限问题,可以采用覆盖的方法去替换hosts文件 ...

  2. Java多线程(汇聚页)

    Java多线程(汇聚页) Java多线程总结

  3. P5282 【模板】快速阶乘算法(多项式运算+拉格朗日插值+倍增)

    题面 传送门 前置芝士 优化后的\(MTT\)(四次\(FFT\)) 题解 这里有多点求值的做法然而被\(shadowice\)巨巨吊起来打了一顿,所以来学一下倍增 成功同时拿到本题最优解和最劣解-- ...

  4. django使用haystack来调用Elasticsearch搜索引擎

    如何使用django来调用Elasticsearch实现全文的搜索 环境:django ==1.11.11 Haystack为Django提供了模块化的搜索.它的特点是统一的,熟悉的API,可以让你在 ...

  5. rpm 卸载

    卸载:python-urlgrabber-3.9.1-9.el6.noarch rpm -e python-urlgrabber-3.9.1-9.el6.noarch

  6. flask后端获取前端post/get数据

    post:用request.form 而且要加上return !!记着加上return get:用 request.args()就可以了

  7. linux中rc.d目录下的文件

    参考 http://blog.sina.com.cn/s/blog_414d78870102vqj5.html http://www.360doc.com/content/12/0820/17/933 ...

  8. tf入门-卷积步长strides参数的具体解释

    conv1 = tf.nn.conv2d(input_tensor,conv1_weights,strides=[1,1,1,1],padding='SAME') 这是一个常见的卷积操作,其中stri ...

  9. 为什么 React Elements 会有 $$typeof 这个属性?

    简评:debug 的时候看到 element 对象中有 $$typeof 这属性,于是查了一下这到底干嘛的. 我们知道,通过 JSX 创建一个 React Elements 时: <marque ...

  10. 在Eclipse之中调试FastDFS-storage

    FDFS版本为5.03 1.首先在eclipse之中创建一个C/C++工程,取名为FastDFS_v5.03 2.将FastDFS源码解压后拷贝到新创建的工程目录下,然后在ecipse之中刷新下工程就 ...