6.Mysql不要用top用limit

在我们使用查询语句的时候,经常要返回前几条或者中间某几行数据,这个时候怎么办呢?

查找时Mysql不能用top,反正我用不了,查了下可以用limit来替换。

比如,想查询下TotalPay前20有哪些人,不能用SELECT TOP 20 * FROM 加州薪水 WHERE OtherPay > 23;那用啥?答案是order by +limit,先排序再查前几

  1. select * from 加州薪水 order by TotalPay desc limit 10
  2.  

7.SQL LIKE 操作符

超喜欢这个like有木有,比如我只知道某个人叫John什么的,用它查就可以查到全名

  1. select * from 加州薪水 where EmployeeName like 'John%'

好吧有2377人叫John什么的。

like用法很相似,上述语句中可以'%xxx'、'xxx%'、'%xxx%',如果不想包含某个字段,用如下:

  1. select * from 加州薪水 where EmployeeName not like 'John%'

这里还有一个关于通配符的延伸,除了%,常用的还有 _ [] [! ]

  1. 图片来源:http://www.w3school.com.cn/sql/sql_wildcards.asp

举个例子:

知道某个人叫John_on Y_U什么的,查询一下:

  1. select * from 加州薪水 where EmployeeName like 'John_on Y_U'

想找名字开头是J或A或P的人,查找一下:

  1. select * from 加州薪水 where EmployeeName like '[JAP]%'

如果要排除名字开头是J或A或P的人,直接在[]中加个感叹号

8. in和between

要找两个人,知道他们名字,直接查找:(Mysql中不分大小写,所有有时候可能会出现名字大小写的同一个人返回两次)

  1. select *from 加州薪水 where EmployeeName in ('GARY JIMENEZ','VINCENT NOLAN')

between类似in,理解为介于某某与某某之间的行,不介于就在前加个not

9.SQL Alias(别名)

给表取个小别名jia

  1. select EmployeeName from 加州薪水 as jia

给列EmployeeName取个小别名Em

  1. select EmployeeName as Em from 加州薪水

四、SQL函数练习

这一节针对于数据库中的计算

1.最基础模板

根据下面这个模板,我们也知道了除了avg外,像first、last、count、max、min、sum、mid、len用法

  1. select 函数(column from table_name

2.group by

对于稍微复杂点的计算,group by函数不能忘记,比如在加州薪水例子中,我们需要查不同职位的薪水为多少,代码如下:

  1. select JobTitle,avg(BasePay) from 加州薪水 group by JobTitle

3.HAVING 子句

在 SQL 中增加 HAVING 子句原因是,WHERE 关键字无法与合计函数一起使用。举个例子,我们希望查找平均基本工资超过70000的职位

  1. select JobTitle,avg(BasePay) from 加州薪水 group by JobTitle having avg(BasePay>70000)

4.大小写转换

UCASE() 函数把字段的值转换为大写。如果要把大写转为小写,用LCASE 函数

  1. select ucase(column_name) from table_name

5.round函数

round函数用于把数值字段舍入为指定的小数位数。

比如我想把basepay部分的数值精确到后一位小数点:

  1. select round(BasePay,1) from 加州薪水

sql语句练习题的更多相关文章

  1. 数据库SQL语句练习题

    一.            设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher).四个表的结构分别如表1-1的表(一)~表( ...

  2. 20_学生选课数据库SQL语句练习题

    一.            设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher).四个表的结构分别如表1-1的表(一)~表( ...

  3. SQL语句练习题【主供自己学习、记忆】

    1.这是我在面试中遇到的一道sql题,没有答出来,o(╥﹏╥)o 这是我刚才在网上查找函数之后写的SQL语句,能得到这个结果.[谁有不同的方法,欢迎底下评论留言哈] select (DATENAME( ...

  4. 学生选课数据库SQL语句练习题

    一.            设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher).四个表的结构分别如表1-1的表(一)~表( ...

  5. ORACLE SQL语句练习题

    --1:选择部门30中的所有员工select * from emp where deptno=30--2:列出所有办事员(clerk) 的姓名.编号和部门编号select empno,ename,de ...

  6. Mysql Sql 语句练习题 (50道)

    MySql 语句练习50题 表名和字段 –1.学生表 Student(s_id,s_name,s_birth,s_sex) –学生编号,学生姓名, 出生年月,学生性别 –2.课程表 Course(c_ ...

  7. sql语句练习题及答案

    表结构 创建表数据    SET NAMES utf8;    SET FOREIGN_KEY_CHECKS = 0;    -- ----------------------------    -- ...

  8. 20_学生选课数据库SQL语句练习题1

    25.查询95033班和95031班全体学生的记录. select * from STUDENT t,SCORE s where t.sclass=95033 or t.sclass=95031 26 ...

  9. _学生选课数据库SQL语句练习题

    1. 查询Student表中的所有记录的Sname.Ssex和Class列. select Sname,Ssex,t.sclass from STUDENT t 2. 查询教师所有的单位即不重复的De ...

随机推荐

  1. 多继承下的super()指向的不一定是直接父类

    常规情况 class Base: def __init__(self): print('Base.__init__') class A(Base): def __init__(self): super ...

  2. [java笔记]JDK的安装和配置

    1.JDK安装下载java JDK:点击下载(http://www.oracle.com/technetwork/java/javase/downloads/index.html )JDK(Java ...

  3. wpf DataTemplate ColumnDefinition width equal

    <Grid.ColumnDefinitions> <ColumnDefinition SharedSizeGroup="col1" /> <Colum ...

  4. 【mysql】source导入多个文件

    在mysql中,可以将表导出为sql文件,比如1.sql, 2.sql等等. 导入一个文件: source /home/somepath/.sql 那么问题来了,如果我想一次导入100个文件呢?总不能 ...

  5. .NetCore Cap 结合 RabbitMQ 实现消息订阅

    开源分布式消息框架 Cap 可以在GitHub上拉也可以通过nuget添加 上一篇博文写了 Windows RabbitMQ的安装使用 Cap支持事务,通过捕获数据库上下文连接对象实现 消息事务,消息 ...

  6. K-Means和K Nearest Neighbor

    来自酷壳: http://coolshell.cn/articles/7779.html http://coolshell.cn/articles/8052.html

  7. 【LOJ】#2536. 「CQOI2018」解锁屏幕

    题解 什么破题,看一眼就能想出来\(n^2 2^n\)看了一眼数据范围有点虚,结果跑得飞快= = 处理出\(a[i][j]\)表示从\(i\)到\(j\)经过的点的点集 然后\(f[i][S]\)表示 ...

  8. H5中canvas标签制作在线画板

    1.介绍 左键点击下移动开始画图.放开鼠标不在画图. 2.重要使用理论 query的使用: 鼠标的按下mousedown 鼠标的移动mousemove 鼠标的放开 mouseup 3.程序 <! ...

  9. Java学习之模拟纸牌游戏,List的ArrayList,Map的HashMap,重写Collections类的sort方法对指定类进行通过特定属性排序,输入异常处理等的学习

    首先放上测试效果图 设计框架 具体的代码实现 创建玩家类 public class Player implements Comparable<Player>{ int id; String ...

  10. PLSQL Developer连接远程oracle配置

    在windows机器上不想安装oracle或者oracle的客户端,我们怎么使用PLSQL Developer工具呢?答案如下: 环境                       windows7   ...