SQL查询刚開始学习的人指南读书笔记(三)值表达式
CHAPTER 5 Getting More Than Simple Columns
Intro Value expression,it contains column names, literal values, functions, or other value
expressions
The type of data
The SQL Standard defines seven general categories of types of data—character,
national character, binary, numeric, Boolean, datetime, and interval.
The national character data type is the same as the character data type except that it draws its characters from ISO-defined foreign language
character sets.
BOOLEAN数据类型能够使用TINYINT存储.
CAST
Changing Data Types
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvc29saWRkcmVhbTY2/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
data_type须要查看详细数据库实现文档,比方MySQL
The type for
the result can be one of the following values:
- BINARY[(N)]
- CHAR[(N)]
源文档 <http://dev.mysql.com/doc/refman/5.0/en/cast-functions.html#function_cast>
比方
SELECT OrderNumber, OrderDate, ShipDate,
CAST(ShipDate– OrderDate AS INTEGER)
AS DaysElapsed
FROM Orders
在MySQL中须要转为
SELECT OrderNumber, OrderDate, ShipDate,
CAST(ShipDate- OrderDate AS DECIMAL)
AS DaysElapsed
FROM Orders
Literal Value
分为字符串常量值,数值常量值和日期常量值.
假设使用单引號包括字符串,字符串中包括单引號,字符串中的单引號请使用两次以示与引用的单引號差别开来.
SQL 'The Vendor"s name is: '
Displayed as The Vendor's name is:
Types of Expressions
CONCATENATION
SQL字符串串接
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvc29saWRkcmVhbTY2/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
❖ Note Of the major database systems,we found that only IBM’s DB2 and
Informix and Oracle’s Oracle support the SQL Standard operator for concatenation.
Microsoft Office Access supports & and + as concatenation
operators,Microsoft SQL Server and Ingres support +, and in MySQL you
must use the CONCAT function. In all the examples in the book,we use the
SQL Standard || operator. In the sample databases on the CD,we use the
appropriate operator for each database type (Microsoft Access, Microsoft
SQLServer, and MySQL).
由上图可知SQL标准字符串串接用||。可是在MySQL使用会被当作逻辑运算符。
MySQL使用concat内建函数串接字符串。而有的数据库使用直观的+串接字符串.
DATE AND TIME ARITHMETIC
MySQL须要将日期常量值转为对应类型再做计算,另外须要使用对应的日期函数计算
CAST('2016-11-22'AS DATE)
CAST('03:30:25'AS TIME)
CAST('2008-09-2914:25:00' AS DATETIME)
比方
SELECT StfLastName || ', ' || StfFirstName AS Staff,
DateHired,
CAST(CAST('2007-10-01'- DateHired AS INTEGER)
/365 AS INTEGER)
AS YearsWithSchool
FROM Staff
ORDER BY StfLastName, StfFirstName
在MySQL中转为
SELECT CONCAT(StfLastName , ', ' , StfFirstName) AS Staff,
DateHired,
CAST(DATEDIFF(CAST('1990-01-11'AS date) , DateHired )/365 as decimal)
AS YearsWithSchool
FROM Staff
ORDER BY StfLastName, StfFirstName
That"Nothing" Value:Null
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvc29saWRkcmVhbTY2/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
推断Value Expression是否为NULL的时候请不要使用ValueExpression
= NULL,这是常犯的小错误.
SQL查询刚開始学习的人指南读书笔记(三)值表达式的更多相关文章
- SQL查询刚開始学习的人指南读书笔记(二)创建SQL查询
PARTII: SQL Basics CHAPTER 4Creating a Simple Query 介绍一种怎样创建SQL语句的技术--"Request/Translation/Clea ...
- SQL查询刚開始学习的人指南读书笔记(一)关系数据库和SQL介绍
PART I:Relational Databases and SQL Chapter2, Ensuring Your Database Structure IsSound. 数据库设计准则 什么是关 ...
- oracle刚開始学习的人经常使用操作100问
oracle刚開始学习的人经常使用操作100问 1. Oracle安装完毕后的初始口令? internal/oracle sys/change_on_install system/manager ...
- wxWidgets刚開始学习的人导引(3)——wxWidgets应用程序初体验
wxWidgets刚開始学习的人导引全文件夹 PDF版及附件下载 1 前言2 下载.安装wxWidgets3 wxWidgets应用程序初体验4 wxWidgets学习资料及利用方法指导5 用wx ...
- wxWidgets刚開始学习的人导引(2)——下载、安装wxWidgets
wxWidgets刚開始学习的人导引全目录 PDF版及附件下载 1 前言2 下载.安装wxWidgets3 wxWidgets应用程序初体验4 wxWidgets学习资料及利用方法指导5 用wxS ...
- wxWidgets刚開始学习的人导引(4)——wxWidgets学习资料及利用方法指导
wxWidgets刚開始学习的人导引全文件夹 PDF版及附件下载 1 前言2 下载.安装wxWidgets3 wxWidgets应用程序初体验4 wxWidgets学习资料及利用方法指导5 用wx ...
- 刚開始学习的人制作VMOS场效应管小功放
VMOS场效应管既有电子管的长处又有晶体管的长处,用它制作的功率放大器声音醇厚.甜美,动态范围大.频率响应好.因此近年来在音响设备中得到了广泛应用. 大功率的场效应管功率放大器.电.路比較复杂.制作和 ...
- wxWidgets刚開始学习的人导引(1)——前言
wxWidgets刚開始学习的人导引全文件夹 PDF版及附件下载 1 前言2 下载.安装wxWidgets3 wxWidgets应用程序初体验4 wxWidgets学习资料及利用方法指导5 用wx ...
- 对于刚開始学习的人Xcode最经常使用的快捷键
对于刚開始学习的人而言,好多人都是直接使用鼠标进行操作.差点儿非常少使用快捷键,从而再练习编程时比别人慢那么一点,今天就把刚開始学习的人最经常使用的几个快捷键给大家总结下,当然欢迎大家补充. (1)c ...
随机推荐
- 阿狸的打字机(bzoj 2434)
Description 阿狸喜欢收藏各种稀奇古怪的东西,最近他淘到一台老式的打字机.打字机上只有28个按键,分别印有26个小写英文字母和'B'.'P'两个字母. 经阿狸研究发现,这个打字机是这样工作的 ...
- ListView更新方法的优化
ListView和Adapter对象均具备有对象更新方法 ListView对象列表的更新方法1.invalidate();--重绘组件2.invlidateView()--重绘组件并包含所有的View ...
- 删除指定文件夹下所有的.svn文件夹
sudo find /目录 -name ".svn" -exec rm -r {} \;
- UVA - 10050 Hartals
#include <cstdio> #include <cstring> ]; ]; int main() { int t; scanf("%d", &am ...
- VS debug调试方法
F5 开始调试,执行到断点 Shift + F5 停止调试 F9 在光标所在行添加断点 Shift + F9 QuickWatch Shift Ctrl F9 delete all 断点 F10 单步 ...
- cmd 命令提示符常用操作
切换盘符: d: 进入子目录: cd web 返回上级目录: cd .. 查询子目录下所有文件:dir
- Codeforces 786B Legacy(线段树优化建图)
题目链接 Legacy 首先对于输入的$n$,建立一棵线段树. 显然线段树有大概$2n$个结点,每个节点对应一段区间 我们把这$2n$个结点加入我们的无向图中,一起跑最短路. 具体连边方案: 我们把 ...
- 2017-10-29-afternoon-清北模拟赛
T1 洗澡 贪心:将未匹配的右括号花费1变为左括号,最有多余的左括号有一半变成右括号 #include <cstring> #include <cstdio> ); int n ...
- k8s入门简介
1.docker的三种编排工具 Docker的第一类编排工具: a.docker compose(docker原生):只能对一个主机上的容器进行编排,无法编排多个主机上的容器; b.docker sw ...
- Java ArrayList 详解
只记录目前为止关注的.JDK1.8 一.基础属性 1.1 内部参数 //空存储实例.直接new ArrayList()便是以该空数组作为实例 private static final Object[] ...