資料庫單行函數
1. oracle函數abs怎麼用
ABS(x)
【功能】返回x的絕對值
【參數】x,數字型表達式
【返回】數字
【示例】
select abs(100),abs(-100) from al;
2. 請問在sql資料庫中,單行函數每一行返回一個值是什麼意思😭
單行函數有以下幾種:
字元函數:接受字元輸入並且返回字元或數值
數值函數:接受數值輸入並返回數值
日期函數:對日期型數據進行操作
轉換函數:從一種數據類型轉換為另一種數據類型
通用函數:NVL函數、DECODE函數
比如將小寫字母變為大寫字母的函數UPPER()就是常見的字元函數的一種。
關於你的問題: 單行函數每一行返回一個值是什麼意思?
舉個簡單的例子可能會更好理解:比如你有一張表table1,裡面有5行數據,那麼使用下面的語句:
SELECT UPPER('smith') FROM table1
將會返回5個大寫的'SMITH'
SMITH
SMITH
SMITH
SMITH
SMITH
3. 資料庫常用函數
1、系統信息函數
系統信息函數用來查詢MySQL資料庫的系統信息。
函數代碼:
SELECT VERSION()
->5.0.67-community-nt
CONNECTION_ID() 返回伺服器的連接數
DATABASE()、SCHEMA 返回當前資料庫名
USER()、SYSTEM_USER()返回當前用戶
2、日期時間函數
MySQL的日期和時間函數主要用於處理日期時間。
函數代碼:
CURDATE(),CURRENT_DATE() curdate() 返回當前日期
SELECT CURDATE()
->2014-12-17
CURTIME(),CURRENT_TIME curtime()
返回當前時間
SELECT CURTIME()
->15:59:02
3、字元串函數
函數代碼:
CHAR_LENGTH(s) char_length()返回字元串s的字元數
SELECT CHAR_LENGTH('你好123') -- 5
CONCAT(s1,s2,...) concat(s1,s2...)
將字元串s1,s2等多個字元串合並為一個字元串
4、加密函數
加密函數是MySQL用來對數據進行加密的函數。
函數代碼:
PASSWORD(str)
該函數可以對字元串str進行加密,一般情況下,PASSWORD(str)用於給用戶的密碼加密。
SELECT PASSWORD('123')
->*
5、數學函數
數學函數主要用於處理數字,包括整型、浮點數等。
函數代碼:
ABS(x) abs(x)返回x的絕對值
SELECT ABS(-1) -- 返回1
CEIL(x),CEILING(x) cell(x),celling(x)
返回大於或等於x的最小整數
SELECT CEIL(1.5) -- 返回2
4. 資料庫中轉換數據類型的幾種方法
oracle有三種最基本的數據類型,即字元型、數值型、日期型。 (注意需要起別名的地方要起別名)
oracle提供的單行函數中,針對不同的數據類型,提供大量實用的函數,同時提供一系列數據類型轉換函數,如下:
sql.append(" select CURVE_NAME,S_YEAR_LIMIT,AVERAGE_VALUE,to_char(d_date,'yyyy-MM-dd') d_date from t_treasury_yield_curve t where d_date = to_date ('"+d_date+"','yyyy-MM-dd')");
24 小時的形式顯示出來要用 HH24select to_char(sysdate,'yyyy-MM-dd HH24:mi:ss') from al;
select to_date('2005-01-01 13:14:20','yyyy-MM-dd HH24:mi:ss') from al;to_date() function。
1、日期格式參數 含義說明
D 一周中的星期幾。
DAY 天的名字,使用空格填充到 9 個字元。DD 月中的第幾天,DDD 年中的第幾天。
DY 天的簡寫名,IW ISO 標準的年中的第幾周,IYYY ISO 標準的四位年份。YYYY 四位年份,
YYY,YY,Y 年份的最後三位,兩位,一位。
select sysdate,sysdate - interval '7' month from al。
當前時間減去 7 年的時間。
select sysdate,sysdate - interval '7' year from al。
時間間隔乘以一個數字。
select sysdate,sysdate - 8 *interval '2' hour from al
2、日期到字元操作
select sysdate,to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from al,select sysdate,to_char(sysdate,'yyyy-mm-dd hh:mi:ss') from al,select sysdate,to_char(sysdate,'yyyy-ddd hh:mi:ss') from al。
select sysdate,to_char(sysdate,'yyyy-mm iw-d hh:mi:ss') from al。
3、字元到日期操作
select to_date('2003-10-17 21:15:37','yyyy-mm-dd hh24:mi:ss') from al。
具體用法和上面的 to_char 差不多。
4、TO_NUMBER
使用TO_NUMBER函數將字元轉換為數字
TO_NUMBER(char[, '格式'])
數字格式格式:
9 代表一個數字 。
0 強制顯示0 。
$ 放置一個$符 。
L 放置一個浮動本地貨幣符 。
. 顯示小數點 。
, 顯示千位指示符。
(4)資料庫單行函數擴展閱讀:
在使用數據類型轉換之前,同樣的 SQL 在有的伺服器不報錯,主要是資料庫的版本不同,當然該過配置的不算。
常見的兩種類型轉換錯誤如下:
ERROR: operator does not exist: integer = character varying。
ERROR: operator does not exist: character varying = integer。
字元串轉數字,數字轉字元串。這一點支持的不如 MySQL 好,當然 PostgreSQL 在新版本中也對這個問題做了改進!
第一種轉換方式:使用 CAST 函數。
SELECT * FROM xttblog WHERE id = CAST(888 AS VARCHAR);
SELECT * FROM xttblog WHERE id = CAST('888' AS integer)。
第二種轉換方式:使用「::」操作欄位。
格式,欄位 :: 要轉換為的數據類型。
SELECT * FROM xttblog WHERE id = 888 :: VARCHAR;
SELECT * FROM xttblog WHERE id = '888' :: integer。
數據類型轉換,雖然看起來很痛苦,但是如果用戶的類型用的不對,查詢效率會下降。所以,在設計的時候,欄位的類型,一定要設計的合理,尤其是在關聯表的時候。
5. 在oracle中where 子句和having子句中的區別
在oracle中where 子句和having子句中的區別
1.where 不能放在GROUP BY 後面
2.HAVING 是跟GROUP BY 連在一起用的,放在GROUP BY 後面,此時的作用相當於WHERE
3.WHERE 後面的條件中不能有聚集函數,比如SUM(),AVG()等,而HAVING 可以
Where和Having都是對查詢結果的一種篩選,說的書面點就是設定條件的語句。下面分別說明其用法和異同點。註:本文使用欄位為oracle資料庫中默認用戶scott下面的emp表,sal代表員工工資,deptno代表部門編號。
一、聚合函數
說明前我們先了解下聚合函數:聚合函數有時候也叫統計函數,它們的作用通常是對一組數據的統計,比如說求最大值,最小值,總數,平均值(
MAX,MIN,COUNT, AVG)等。這些函數和其它函數的根本區別就是它們一般作用在多條記錄上。簡單舉個例子:SELECT SUM(sal) FROM emp,這里的SUM作用是統計emp表中sal(工資)欄位的總和,結果就是該查詢只返回一個結果,即工資總和。通過使用GROUP BY 子句,可以讓SUM 和 COUNT 這些函數對屬於一組的數據起作用。
二、where子句
where自居僅僅用於從from子句中返回的值,from子句返回的每一行數據都會用where子句中的條件進行判斷篩選。where子句中允許使用比較運算符(>,<,>=,<=,<>,!=|等)和邏輯運算符(and,or,not)。由於大家對where子句都比較熟悉,在此不在贅述。
三、having子句
having子句通常是與order by 子句一起使用的。因為having的作用是對使用group by進行分組統計後的結果進行進一步的篩選。舉個例子:現在需要找到部門工資總和大於10000的部門編號?
第一步:
select deptno,sum(sal) from emp group by deptno;
篩選結果如下:
DEPTNO SUM(SAL)
------ ----------
30 9400
20 10875
10 8750
可以看出我們想要的結果了。不過現在我們如果想要部門工資總和大於10000的呢?那麼想到了對分組統計結果進行篩選的having來幫我們完成。
第二步:
select deptno,sum(sal) from emp group by deptno having sum(sal)>10000;
篩選結果如下:
DEPTNO SUM(SAL)
------ ----------
20 10875
當然這個結果正是我們想要的。
四、下面我們通過where子句和having子句的對比,更進一步的理解它們。
在查詢過程中聚合語句(sum,min,max,avg,count)要比having子句優先執行,簡單的理解為只有有了統計結果後我才能執行篩選啊。where子句在查詢過程中執行優先順序別優先於聚合語句(sum,min,max,avg,count),因為它是一句一句篩選的。HAVING子句可以讓我們篩選成組後的對各組數據篩選。,而WHERE子句在聚合前先篩選記錄。如:現在我們想要部門號不等於10的部門並且工資總和大於8000的部門編號?
我們這樣分析:通過where子句篩選出部門編號不為10的部門,然後在對部門工資進行統計,然後再使用having子句對統計結果進行篩選。
select deptno,sum(sal) from emp
where deptno!='10' group by deptno
having sum(sal)>8000;
篩選結果如下:
DEPTNO SUM(SAL)
------ ----------
30 9400
20 10875
不做太多解釋了,這個簡單的小例子能夠很好的說明where和having的作用。
五、異同點
它們的相似之處就是定義搜索條件,不同之處是where子句為單個篩選而having子句與組有關,而不是與單個的行有關。
最後:理解having子句和where子句最好的方法就是基礎select語句中的那些句子的處理次序:where子句只能接收from子句輸出的數據,而having子句則可以接受來自group by,where或者from子句的輸入。