USE study;
SELECT * FROM EMP

--查询雇员姓名的最后三个字母

SELECT ename,right(ename,3) FROM EMP ;

--查询10部门雇员进入公司的星期数

SELECT ename,datename(month,hiredate) from EMP where deptno =10

--1 查询部门30中的所有员工

SELECT * FROM EMP WHERE deptno=30

--2 列出所有办事员(CLERK)的姓名,编号和部门编号

SELECT ename,empno,deptno FROM EMP where job='clerk'

--3 找出佣金高于薪金的员工

SELECT ename from EMP where sal >comm

--求出每个雇员的年薪

SELECT ename,sal*12 FROM EMP ;

--4 找出佣金高于薪金的60%的员工

SELECT ename ,sal,comm FROM EMP WHERE sal>comm*0.6

--5 找出部门10中所有经理(MANAGER)和部门20中所有办事员(CLERK)的详细资料

SELECT *FROM EMP WHERE (job ='MANAGER'AND deptno =10) OR (job ='MANAGER'AND deptno =20)

--6 找出部门10中所有经理(MANAGER),部门20中的所有办事员(CLEAK),
-- 既不是经理又不是办事员但薪金大于或等于2000的所有员工的详细资料

SELECT *FROM EMP WHERE (job ='MANAGER'AND deptno =10) OR (job ='CLEAK'AND deptno =20)OR(job<>'MANAGER'AND job<>'CLEAK'AND sal >=2000) 

--7 找出收取佣金的员工的不同工作

SELECT DISTINCT job FROM EMP WHERE comm is not null

--8 找出不收取佣金或收取佣金低于100的员工

SELECT *FROM EMP where comm IS NULL OR comm<100

--9 找出各月倒数第3天受雇的所有员工

SELECT * FROM EMP WHERE month (dateadd (day,3,hiredate))=month(dateadd(month,1,hiredate))

--10 找出早于12年前受雇的员工

SELECT * FROM EMP WHERE datediff (year,hiredate ,getdate())>12

--11 以首字母大写的方式显示所有员工的姓名

SELECT upper(substring(ename,1,1))+lower(substring (ename,2,len(ename)))from emp

--12 显示正好为5个字符的员工的姓名

SELECT ename FROM EMP WHERE len(ename)=5 ;

--13 显示不带有"R"的员工的姓名

SELECT ename FROM EMP WHERE ename NOT LIKE 'R'

--14 显示所有员工的姓名的前三个字符

SELECT ename,right(ename,3) FROM EMP 

--15 显示所有员工的姓名,用"a"代替所有的"A"

SELECT replace(ename,'A','a')from EMP 

--16 显示满10年服务年限的员工的姓名和受雇日期

SELECT ename,hiredate FROM EMP WHERE datediff(year,hiredate,getdate())>10 

--17 显示员工详细信息,按姓名排序

SELECT * FROM EMP ORDER BY ename

--18 显示员工的姓名和受雇日期,根据其服务年限,将最老的员工排在前面

SELECT ename,hiredate FROM EMP ORDER BY datediff(year ,hiredate ,getdate())DESC    

--19 显示所有员工的姓名,工作和薪金,按工作的降序排序,若工作相同则薪金排序

SELECT ename,job,sal from EMP ORDER BY job DESC,sal

--20 显示所有员工的姓名,加入公司的年份和月份,按受雇日期所在月排序,若月份相同则将
--最早年份的员工排在前面

SELECT ename,year(hiredate)'年份',month(hiredate)'月份'FROM EMP ORDER BY 月份,年份 

--21 显示在一个月为30天的情况,所有员工的日薪金,忽略余数

SELECT ename,floor(sal/30) FROM EMP 

--22 找出在(任何年份的)2月受雇的所有员工

SELECT ename FROM EMP WHERE month(hiredate)=2

--23 对于每个员工,显示其加入公司的天数

SELECT ename,datediff (day,hiredate ,getdate()) FROM EMP

--24 显示姓名字段的任何位置包含"A"的所有员工的姓名

SELECT ename FROM EMP WHERE ename LIKE '%A%';

--25 以年月日的方式显示所有员工的服务年限(大概)

SELECT ename, floor(datediff(day,hiredate ,getdate())/365),floor(floor(datediff(day,hiredate ,getdate()))-floor(datediff(day,hiredate ,getdate())/365)*365)/12 from EMP

SQL 简单练习的更多相关文章

  1. MVC 学习(二)之Linq to Sql 简单Demo

    Linq to Entities 已经我的一篇博文中阐述了,这里阐述一下简单的Linq to Sql 的增删改查.Linq to sql 与Linq to Entities虽然同属于DataBase- ...

  2. Linq to SQL 简单的增删改操作

    Linq to SQL 简单的增删改操作. 新建数据库表tbGuestBook.结构如下: 新建web项目,完成相应的dbml文件.留言页面布局如下 <body> <form id= ...

  3. Mybatis动态SQL简单了解 Mybatis简介(四)

    动态SQL概况 MyBatis 的强大特性之一便是它的动态 SQL 在Java开发中经常遇到条件判断,比如: if(x>0){ //执行一些逻辑........ }   Mybatis应用中,S ...

  4. Oracle笔记 六、PL/SQL简单语句块、变量定义

    1.简单SQL语句,HellWorld示例 --输出信息 begin dbms_output.put_line('Oracle Hello World!'); end; 2.变量的定义.使用 --定义 ...

  5. PL/SQL简单使用——导入、导出数据表

    1.使用PL/SQL导出.导入表 在使用PL/SQL操作oracle数据库时,经常使用的一个操作就是将自己写的数据表导出,或者想把他人的数据表导入到自己的数据库中.虽然是很简单的操作,但自己之前一直出 ...

  6. Spark的Streaming和Spark的SQL简单入门学习

    1.Spark Streaming是什么? a.Spark Streaming是什么? Spark Streaming类似于Apache Storm,用于流式数据的处理.根据其官方文档介绍,Spark ...

  7. SQL简单基础(1)

    对于SQL不再做过多的介绍,毕竟作为一个初学者对于SQL(结构化查询语言)也好,关系型数据库也好理解都并不是很深,只知道一些基本的概念. 本系列旨在介绍一些简单开发中用得上的SQL语句以及其使用方法, ...

  8. SQL简单基础(2)

    查询功能是SQL语句最重要的功能,查询操作也是数据库系统最常用的操作.学习SQL查询语句,首先要弄清楚的是查询语句用到的关键字以及查询语句的执行顺序.SQL语言的一个特点在于,它是一种声明式语句,执行 ...

  9. sql 简单语法

    1.数据库操作 create database student_info -- 创建数据库 drop database student_info -- 删除数据库 2.表操作 -- 创建表 creat ...

  10. SQL简单嵌套查询与非嵌套查询的比较(MSSQL2005)

    某天的工作是修复某个项目的bug,接着就发现,其sql极其混乱,有非常多的left join和in操作,还有嵌套查询(只有一个表的嵌套查询).不知道看到过哪里的资料说,嵌套查询速度慢,于是我把全部嵌套 ...

随机推荐

  1. CentOS6.4中安装Python-Pip 以及Phyton gevent

    一.安装Phyton-pip 首先要安装 Setuptools wget --no-check-certificate https://pypi.python.org/packages/2.6/s/s ...

  2. google base库中的WaitableEvent

    这个类说白了就是对windows event的封装,没有什么特别的,常规做法,等侍另一线程无非就是等侍事件置信waitsingleobject,通知事件无非就是setevent,一看就明白,不就详解, ...

  3. 对于一些css样式的巧妙方法进行总结。

    针对之前遇到过的一些特殊样式的实现,我今天做个总结,目的有二:一是将这些方法记录下来,以便将来需要用到时查找使用.二为将这些大神们智慧的结晶发扬光大,让广大前端程序猿们能够少走弯路.此贴为更新帖,以后 ...

  4. HTML豆ちしき

    HTML文档里所有的空白符(空格,Tab,换行,回车)会被浏览器忽略,唯一的例外是空格,对空格的处理方式是所有连续的空格被当成一个空格,不管有一个,还是两个,还是100个.之所以有这样的规则是因为忽略 ...

  5. weather compare

  6. iframe自适应高度的问题

    最近工作中遇到了iframe自适应高度的问题. 如果在iframe中写定高度height的属性,并且iframe中内容高度小于给定的height时,会在手机浏览器中莫名的产生下拉框,造成体验度下降. ...

  7. redmine和svn server的部署

    作为一个程序猿,想要很好的管理自己项目和代码,我们需要一些工具做辅助. 项目管理工具redmine和代码版本管理工具 SVN(Subversion). 我们选择在虚拟机里面安装windows部署这两套 ...

  8. 升级linux内核(2.6.32->3.10.81),安装docker

    1.内核升级环境准备 #查看已经安装的和未安装的软件包组,来判断我们是否安装了相应的开发环境和开发库: yum grouplist #一般是安装这两个软件包组,这样做会确定你拥有编译时所需的一切工具 ...

  9. android 自定义控件,自定义属性设置

    做listView的上拉下拉刷新,网上找了个历程.但是有些界面只有上拉刷新,有些界面是下拉刷新.觉得应该在xml里定义一个属性控制上下拉使能. 0.关于自定义控件: 自定义控件设计主要方式有:a) 继 ...

  10. J2SE知识点摘记(二十五)

    Set 1.5.1        概述 Java 中的Set和正好和数学上直观的集(set)的概念是相同的.Set最大的特性就是不允许在其中存放的元素是重复的.根据这个特点,我们就可以使用Set 这个 ...