相关表:
<span style="white-space:pre">create table DEPT
(
<span style="white-space:pre"> </span>deptno int not null primary key,
<span style="white-space:pre"> </span>dname varchar(14)  null,
<span style="white-space:pre"> </span>loc varchar(13) null
) create table EMP
(
<span style="white-space:pre"> </span>empno int not null primary key,
<span style="white-space:pre"> </span>ename varchar(10) null,
<span style="white-space:pre"> </span>job varchar(9) null,
<span style="white-space:pre"> </span>mgr int null,
<span style="white-space:pre"> </span>hiredate date null,
<span style="white-space:pre"> </span>sal float null,
<span style="white-space:pre"> </span>comm float null,
<span style="white-space:pre"> </span>deptno int null foreign key references DEPT(deptno),
)
create table SALGRADE
(
<span style="white-space:pre"> </span>grade int null,
<span style="white-space:pre"> </span>losal int null,
<span style="white-space:pre"> </span>hisal int null,
)</span>
查询部分:
--查询雇员姓名的最后三个字母
SELECT SUBSTRING(ename,LEN(ename)-3,3) FROM dbo.EMP --查询10部门雇员进入公司的星期数
SELECT ename,DATEDIFF(wk,hiredate,GETDATE())AS 进入星期数 FROM dbo.EMP WHERE deptno=10 --1 查询部门30中的全部员工
SELECT * FROM dbo.EMP WHERE deptno=30 --2 列出全部办事员(CLERK)的姓名,编号和部门编号
SELECT ename , empno , deptno FROM emp WHERE job='clerk' --3 找出佣金高于薪金的员工
SELECT * FROM dbo.EMP WHERE comm>sal --求出每一个雇员的年薪 SELECT ename,sal*12+ISNULL(comm,0)*12 AS 年薪 FROM dbo.EMP --4 找出佣金高于薪金的60%的员工
SELECT * FROM dbo.EMP WHERE comm>sal*0.6 --5 找出部门10中全部经理(MANAGER)和部门20中全部办事员(CLERK)的具体资料
SELECT * FROM dbo.EMP WHERE deptno=10 AND job='manager' OR deptno=20 and job='CLERK' --6
-- 既不是经理又不是办事员但薪金大于或等于2000的全部员工的具体资料
SELECT * FROM dbo.EMP WHERE job!='manager' AND job!='clerk' AND sal>=2000 --7 找出收取佣金的员工的不同工作
SELECT DISTINCT job FROM dbo.EMP WHERE comm IS NOT NULL --8 找出不收取佣金或收取佣金低于100的员工
SELECT * FROM dbo.EMP WHERE comm IS NULL OR comm<100 --9 找出各月倒数第3天受雇的全部员工
SELECT * FROM dbo.EMP WHERE MONTH(DATEADD(DAY,3,hiredate))=MONTH(DATEADD(MONTH,1,hiredate)) --10 找出早于12年前受雇的员工
SELECT * FROM dbo.EMP WHERE DATEDIFF(YEAR,hiredate,GETDATE())>12 --11 以首字母大写的方式显示全部员工的姓名
select upper(substring(ename,1,1))+lower(substring(ename,2,len(ename)-1)) from emp; --12 显示正好为5个字符的员工的姓名
SELECT ename FROM emp WHERE LEN(ename)=5 --13 显示不带有"R"的员工的姓名
SELECT ename FROM dbo.EMP WHERE ename NOT LIKE '%R%' --14 显示全部员工的姓名的前三个字符
SELECT SUBSTRING(ename,1,3) FROM dbo.EMP --15 显示全部员工的姓名,用"a"取代全部的"A"
SELECT REPLACE(ename,'a','A') FROM dbo.EMP --16 显示满10年服务年限的员工的姓名和受雇日期
SELECT ename,hiredate FROM dbo.EMP WHERE DATEDIFF(year,hiredate,GETDATE())>10 --17 显示员工具体信息,按姓名排序
SELECT * FROM dbo.EMP ORDER BY ename --18 显示员工的姓名和受雇日期,依据其服务年限,将最老的员工排在前面
SELECT ename,hiredate FROM dbo.EMP ORDER BY DATEDIFF(year,hiredate,GETDATE()) DESC --19 显示全部员工的姓名,工作和薪金,按工作的降序排序,若工作同样则薪金排序
SELECT ename,job ,sal+ISNULL(comm,0)AS 薪金 FROM dbo.EMP order BY job ,sal+ISNULL(comm,0) --20 显示全部员工的姓名,增加公司的年份和月份,按受雇日期所在月排序,若月份同样则将
--最早年份的员工排在前面
SELECT ename,YEAR(hiredate),MONTH(hiredate) FROM dbo.EMP ORDER BY MONTH(hiredate),YEAR(hiredate) --21 显示在一个月为30天的情况,全部员工的日薪金,忽略余数
SELECT ROUND((sal+ISNULL(comm,0))/30,0) FROM dbo.EMP --22 找出在(不论什么年份的)2月受雇的全部员工
SELECT * FROM dbo.EMP WHERE MONTH(hiredate)=2 --23 对于每一个员工,显示其增加公司的天数
SELECT ename ,DATEDIFF(DAY,hiredate,GETDATE())AS 入职天数 FROM dbo.EMP --24 显示姓名字段的不论什么位置包括"A"的全部员工的姓名
SELECT ename FROM dbo.EMP WHERE ename LIKE '%A%' --25 以年月日的方式显示全部员工的服务年限(大概)
SELECT STR(ROUND(DATEDIFF(day,hiredate,GETDATE())/365,0))+'年'+
str(ROUND(DATEDIFF(day,hiredate,GETDATE())%365/30+1,0))+'月'+
STR(DATEDIFF(day,hiredate,GETDATE())%365%30)+'日' AS 服务年限 FROM dbo.EMP

SQL server语句练习的更多相关文章

  1. Oracle、Mysql、Sql Server语句的区别

    1.空值的处理——判断是否为空,为空时取一个值,不为空时取另一个值 1).Sql Server 中 ISNULL(check_expression,replacement_value) 解释:如果ch ...

  2. SQL Server 语句整理

    1. 创建数据库 create database dbName 2. 删除数据库 drop database dbName 3. 备份sql server --- 创建 备份数据的 device US ...

  3. 基本的SQL Server 语句,包含 增、删、改、查 程序员必会

    这是我以前学习时, 整理的一套基础SQL Server增.删.改.查 等语句 ,初学者可以从上往下学完. 也方便自己忘记时翻看! create database SQLschool go --批 go ...

  4. sql server语句

    一.基础1.说明:创建数据库CREATE DATABASE 数据库名2.说明:删除数据库drop database 数据库名3.说明:备份sql server--- 创建 备份数据的 deviceUS ...

  5. Sql Server语句大全

    T-SQL语句大全 --跳转到SQL myDemo USE [SQL myDemo] go --声明变量id declare @id int --为变量赋值:直接赋值 --将cid为3的cname值赋 ...

  6. 常用SQL Server 语句

       常用SQL语句大全 1.//创建数据库 CREATE DATABASE DBName 2.//删除数据库 DROP DATABASE DBName 3.//备份SQL SERVER --- 创建 ...

  7. SQL SERVER 语句大全

    ·SQL的简单查询实例教程关键词:SQL语句大全 中文网 整理编辑,经典SQL语句大全(SQL语句大总结),欢迎网友投稿 下列语句部分是Mssql语句,不可以在access中使用.SQL分类:DDL— ...

  8. 经典实用SQL Server语句大全总结(一)

    简要介绍基础语句:1.说明:创建数据库CREATE DATABASE database-name2.说明:删除数据库drop database dbname3.说明:备份sql server--- 创 ...

  9. sql server 语句书写注意事项

    1  Between在某些时候比IN 2 在必要是对全局或者局部临时表创建索引,有时能够提高速度,但不是一定会这样,因为索引也耗费大量的资源.他的创建同是实际表一样 3 尽量少用视图,它的效率低.对视 ...

  10. SQL server 语句新建用户、对用户授权、删除用户实例

    Grant select on tb to db_user --给db_user用户授权 tb表 查询权限 一.命令操作 USE mydb GO --1. 新建测试用户 --1.1 添加登录用户和密码 ...

随机推荐

  1. mvc中的几个数据传递

    1.ViewData对象 ViewBagData是一种字典集合数据同时属于视图基类和控制器基类的属性. 实例: //控制器 public class HomeController:Controller ...

  2. Ubuntu服务器上SSH Server 的安装和设置

    网上有很多介绍在Ubuntu下开启SSH服务的文章,但大多数介绍的方法测试后都不太理想,均不能实现远程登录到Ubuntu上,最后分析原因是都没有真正开启ssh-server服务.最终成功的方法如下: ...

  3. Flask web开发 简单介绍

    Flask是一个基于python的轻量级web框架.当安装好后Flask后 (pip install flask),就可以开始使用了. 一.最简单的例子 1.新建目录,作为web应用的目录,如: mk ...

  4. 进入MFC讲坛的前言(三)

    MFC中的窗口创建及窗口消息映射 我经常碰到有人问我有关窗口创建的问题,他们经常把用HWND描述的系统窗口对象和用CWnd描述的MFC的窗口对象混淆不清.这两者之间是紧密联系在一起的,但是MFC为了自 ...

  5. 架构设计的UML图形思考

    本篇紧接着上一篇   基本OOP知识  ,介绍高焕堂老师的第二讲. 架构设计的UML图形思考.本篇最重要的是三个词语:图形.思考.UML. 架构师的作用体现主要在项目开发前期.在整个项目还没有完毕的时 ...

  6. JQuery - 根据节点获取对应的id,可用于留言板

    可以用于留言版的,点击展看和收起.显示评论等等功能. 效果: ----------------- html代码: JQuery代码:

  7. jsp生命周期和工作原理

    jsp的工作原理jsp是一种Servlet,但是与HttpServlet的工作方式不太一样.httpservlet是先由源代码编译为class文件后部署到服务器下的,先编译后部署.而jsp则是先部署后 ...

  8. js判断IP js判断域名

    <html> <head> <script language="javascript" type="text/javascript" ...

  9. 简要解析XMPP框架及iOS-Objective-C的使用

    前言:这两天看了XMPP框架,查阅了一些资料,写下这篇文章记录一下学习笔记 一.简要解析XMPP核心部分 XMPP框架分为两个部分 1.核心部分 2.扩展部分 扩展部分主要讲好友列表(roster). ...

  10. python中打印文件名,行号,路径

    print "I have a proble! And here is at Line: %s"%sys._getframe().f_lineno PDB,哈哈http://doc ...