一、计算字段

  1.1拼接字段

  一般情况下返回的字段是指定列的属性名。如果有时我们对返回格式有特殊要求。

  例如,我们需要将显示商品名,即商品价格,同时商品名后面的价格放在括号内。

  prod_name(prod_price) 以这种方式显示数据。

  这时我们就需要使用拼接字段。

  

  

  

  可以看到显示的 数据是以prod_name(prod_price)的格式显示的。  

  实现这个功能的过程中使用了一个函数:CONCAT(str1,str2,...)。

  该函数将str1,str2,..拼接起来显示。

  1.2使用别名

  上例中的列名是SELECT语句后面的名称,但这个可读写不强。我们可以通过为改列指定一个别名

  然后显示的就是我们指定的别名了。别名通过as指定,as可省略不写。

  

  第一列的名称从CONCAT(prod_name, '(',prod_price, ')')变成了prod_name_price。

  指定别名可以使列名更具可读性。

  1.3字段计算

  例如有一列为单价,有一列为数量,我们需要返回一列总价,但是总价在表中并未存储。

  这时我们就可以单价*数量,这种方式间接的获取总价。

  

  

  通过quantity * item_price计算,并为其起一个别名total。

二、函数

  2.1数据处理函数

  SQL提供一些函数,以便于对数据进行操作。

  但不同的数据库管理软件对函数的支持不一致,具体需查阅对应文档。

  

  2.1.1 UPPER()将文本内容转换为大写。

  

  

  

  2.1.2 YEAR() 获取数据类型为日期的年份,MONTH()获取数据类型为日期的月份,DAY()获取数据类型为日期的天数。

  

  获取数据类型为日期的年、月、日前提是改数据是日期类型,可以看到order_date的类型是datetiem.

  

  

  获取所有一月份的订单。

  SQL中还有很多函数,具体可查阅对应文档。

  

  2.2聚集函数

  聚集函数和前面的函数不同,它不返回全部的检索数据,只返回我们需要的数据。

  例如计算当前表有多少行,并不需要返回每一行,只需要返回一个总行数即可。

  同样计算指定列的最大值,也不需要返回所有列,只需要该列的最大值即可。

 

  2.2.1 AVG()

  计算平均值,只返回一个平均值

  

  

  

  计算prod_id为‘BR01’的item_price的平均值.

  

  2.2.2COUNT()

  用于计数,COUNT(*)对表中行数进行计数,null也计入总数中。

  COUNT(colName)对指定列进行计数,null不计入总数中。

  

  

  

  

  此时返回的是总行数5.

  

  

  此时返回的cust_email这一行,此时emali为空的行没有被记入总数。

  

  2.2.3MAX(),MIN()

  返回指定列中最大、最小值。

  

  

  prod_price的最大值与最小值。

  

  2.2.4SUM()

  计算指定列的和。

  

  

  SUM(price * quantity),计算单价*数量,然后通过SUM求和可以计算出所有总价。

  SELECT后可以跟随多个聚合函数

  SELECT AVG(colName), COUNT(colName), SUM(colName) FROM tableName;

  

  但不能这样写:

  SELECT AVG(colName), UPPER(colName) FROM tableName;

  UPPER不是聚集函数,返回的不是单个值,而是检索出来的所有结果进行大写转换。

  而AVG只返回一个值,这是冲突的。

  

参考资料:

《SQL必知必会》

1.3(SQL学习笔记)计算字段及函数的更多相关文章

  1. SQL学习之计算字段的用法与解析

    一.计算字段 1.存储在数据库表中的数据一般不是应用程序所需要的格式.大多数情况下,数据表中的数据都需要进行二次处理.下面举几个例子. (1).我们需要一个字段同时显示公司名和公司地址,但这两个信息存 ...

  2. openerp学习笔记 计算字段、关联字段(7.0中非计算字段、关联字段只读时无法修改保存的问题暂未解决)

    计算字段.关联字段,对象修改时自动变更保存(当 store=True 时),当 store=False 时,默认不支持过滤和分组7.0中非计算字段.关联字段只读时无法修改保存的问题暂未解决 示例代码: ...

  3. openerp学习笔记 计算字段支持搜索

    示例1: # -*- encoding: utf-8 -*-import poolerimport loggingimport netsvcimport toolslogger = netsvc.Lo ...

  4. 【SQL学习笔记】排名开窗函数,聚合开窗函数(Over by)

    处理一些分组后,该组按照某列排序后 ,取其中某条完整数据的问题. 或 按照其中不同列分组后的聚合 比如 sum,avg之类. MSDN上语法: Ranking Window Functions < ...

  5. ORALCE PL/SQL学习笔记

    ORALCE  PL/SQL学习笔记 详情见自己电脑的备份数据资料

  6. Hadoop源码学习笔记(2) ——进入main函数打印包信息

    Hadoop源码学习笔记(2) ——进入main函数打印包信息 找到了main函数,也建立了快速启动的方法,然后我们就进去看一看. 进入NameNode和DataNode的主函数后,发现形式差不多: ...

  7. SQL学习笔记

    SQL(Structured Query Language)学习笔记 [TOC] Terminal登录数据库 1.登录mysql -u root -p ; 2.显示所有数据库show database ...

  8. Oracle之PL/SQL学习笔记

    自己在学习Oracle是做的笔记及实验代码记录,内容挺全的,也挺详细,发篇博文分享给需要的朋友,共有1w多字的学习笔记吧.是以前做的,一直在压箱底,今天拿出来整理了一下,给大家分享,有不足之处还望大家 ...

  9. sql 学习笔记 档

    从下面的内容 3c   school 1:Sql 它分为两部分: 6 2:查询 7 3:插入: 9 4:数据库更新 UPDATE 9 5:删除 DELETE 10 6:Sql TOP 子句: 10 7 ...

随机推荐

  1. Linux 入门记录:三、Linux 文件基本操作管理

    一.复制文件.目录 使用 cp 命令复制文件或目录: $ cp 源文件(夹)目标文件(夹) 常用参数: -r 递归复制整个目录树 -v 显示复制过程的详细信息 二.移动.重命名文件或目录 通过 mv  ...

  2. Linux系统编程——进程间通信(System V IPC 对象)

    基本查看命令 ipcs  -m查看共享内存        ipcs -s查看信号量        ipcs -q查看消息队列 ipcrm  -m  id 删除共享内存   -M+key值 ipcrm ...

  3. google fcm 推送的流程

    总结:1.给一个人推,能成功,2.给多个人推,有两种,一种是给组推,一种是给主题推,之前用的是组推,但是不成功,这里换成主题推: <?phpnamespace App\Http\Controll ...

  4. js cookies的使用及介绍 (非常详细)

    设置cookie 每个cookie都是一个名/值对,可以把下面这样一个字符串赋值给document.cookie:document.cookie="userId=828";如果要一 ...

  5. 创建数据库表的SQL语句

    创建表.视图.索引的sql语句如下: CREAT TABLE (列名,数据类型,约束) create view(创建视图) create index (创建索引) 1.primary key(主键) ...

  6. 堆--LogN的数据结构

    我们这里的堆是指用来表示元素集合的一种数据结构 一个二叉树是一个堆是由堆的两个性质决定的(以小根堆为例) 1:任何节点的值都小于或等于其子节点的值 2:该二叉树最多在两层上具有叶节点,其中最底层的叶节 ...

  7. POJ-2398

    Toy Storage Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 4243   Accepted: 2517 Descr ...

  8. Django 批量导入文件

    1. 按照xlrd软件 pip3 install xlrd 2. POST提交文件获取数据 方法一:写入硬盘,xlrd读取xlsx文件获取文件数据 def batch_view(self,reques ...

  9. Restful Framework (四)

    目录 一.分页 二.视图 三.路由 四.渲染器 一.分页 回到顶部 试问如果当数据量特别大的时候,你是怎么解决分页的? 方式a.记录当前访问页数的数据id 方式b.最多显示120页等 方式c.只显示上 ...

  10. hdu 1455(DFS+好题+经典)

    Sticks Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Subm ...