當前位置:首頁 » 編程語言 » sql除法函數

sql除法函數

發布時間: 2022-10-30 06:56:42

A. sql語句實現關系代數中的「除法」

給定關系R(X,Y)和S(Y,Z),其中X,Y,Z為屬性組。R中Y與S中的Y可以有不同的屬性名,但必須出自相同的域集。R與S的除運算可以得到一個新的關系P(X),P是R中滿足下列條件的元組在X 屬性列上的投影: 元組在X上的分量值x的像集Y(x)包含S在Y上的投影的集合。

第一步:找出關系R和關系S中相同的屬性,即Y屬性。在關系S中對Y做投影(即將Y列取出);

第二步:被除關系R中與S中不相同的屬性列是X,關系R在屬性X上做取消重復值的投影;

第三步:求關系R中X屬性對應的像集Y;

第四步:判斷包含關系,R÷S其實就是判斷關系R中X各個值的像集Y是否包含關系S中屬性Y的所有值。

R(X,Y)÷S(Y,Z)的運算用結構化語言SQL 語句可表達為下列形式:

B. SQL資料庫中除法用什麼來實現

select 一個結果/另一個結果 from table_name

你上邊寫的那個*難道是多列除多列?

那好像不行吧,被除數別=0哈,要不報錯

C. SQL如何做除法

這樣:

select

t.[origin-destination],t.[SH/LANE/MOT] /(select count(1) from ['TMS$'] )ASPERCENTAGE
FROM (代碼1) t

group by [origin-destination],t.[SH/LANE/MOT]

having t.[SH/LANE/MOT] /count(*) <= 0.01

註:兩個count都是int,相除會沒有小數部分,所以應該都給轉成帶小數的數。

cast as numeric(10,4) 。

(3)sql除法函數擴展閱讀:

SQL中除法運算的實現

R(X,Y)÷S(Y,Z)的運算用結構化語言SQL 語句可表達為下列形式:

select distinct R.X from R R1

where not exists

(

select S.Y from S

where not exists

(

select * from R R2

where R2.X=R1.X and R2.Y=S.Y

)

)

D. 急急急!!!SQL Server 中有沒有除法函數或者求商函數

這個函數是沒有的,你直接用" / "號就行了啊。select 一個結果 / 另一個結果 from table_name。

E. SQL的基本函數

【二】SQL的基本函數

2.1 關系型資料庫SQL命令類別

數據操縱語言:DML: select; insert; delete; update; merge.

數據定義語言:DDL: create; alter; drop; truncate; rename; comment.

事務控制語言:TCL: commit; rollback; savepoint.

數據控制語言:DCL: grant; revoke.

2.2 單行函數與多行函數

單行函數:指一行數據輸入,返回一個值得函數。所以查詢一個表時,對選擇的每一行數據都會返回一個結果。

SQL>select empno,lower(ename) from emp;

多行函數:指多行數據輸入,返回一個值得函數。所以對表的群組進行操作,並且每組返回一個結果。(典型的是聚合函數)

SQL>select sum(sal) from emp;

2.3 單行函數的幾種類型

2.3.1 字元型函數

lower('SQL Course')----->sql course 返回小寫

upper('sql course')----->SQL COURSE 返回大學

initcap('SQL course')-----> Sql Course 每個單字返回首字母大寫

concat('good','string')---->good string 拼接 只能拼接2個字元串

substr('String',1,3)---->Str 從第1位開始截取3位數,

演變:只有兩個參數的

substr('String',3) 正數第三位起始,得到後面所有字元

substr('String',-2) 倒數第二位,起始,得到最後所有字元

instr('t#i#m#r#a#n#','#') --->找第一個#字元在那個絕對位置,得到的數值

Instr參數經常作為substr的第二個參數值

演變:Instr參數可有四個之多

如select instr('aunfukk','u',-1,1) from al; 倒數第一個u是哪個位置,結果返回5

length('String')---->6 長度,得到的是數值

length參數又經常作為substr的第三個參數

lpad('first',10,'#39;)左填充

rpad(676768,10,'*')右填充

replace('JACK and JUE','J','BL')---->BLACK and BLUE

trim('m' from 'mmtimranm')---->timran 兩頭截,這里的『m』是截取集,僅能有一個字元

trim( ' timran ')---->timran 作用是兩頭去空字元

處理字元串時,利用字元型函數的嵌套組合是非常有效的:

create table customers(cust_name varchar2(20));

insert into customers values('Lex De Hann');

insert into customers values('Renske Ladwig');

insert into customers values('Jose Manuel Urman');

insert into customers values('Joson Malin');

select * from customers;

CUST_NAME

--------------------

Lex De Hann

Renske Ladwig

Jose Manuel Urman

Joson Malin

一共四條記錄,客戶有兩個名的,也有三個名的,現在想列出僅有三個名的客戶,且第一個名字用*號略去

答案之一:

SELECT LPAD(SUBSTR(cust_name,INSTR(cust_name,' ')),LENGTH(cust_name),'*') "CUST NAME"

FROM customers

WHERE INSTR(cust_name,' ',1,2)>0;

CUST NAME

------------------------------------------------------------------------------------------------------------------------

*** De Hann

**** Manuel Urman

分析:

先用INSTR(cust_name,' ')找出第一個空格的位置,

然後,SUBSTR(cust_name,INSTR(cust_name,' '))從第一個空格開始往後截取字元串到末尾,結果是第一個空格以後所有的字元,

最後,LPAD(SUBSTR(cust_name,INSTR(cust_name,' ')),LENGTH(cust_name),'*')用LPAD左填充到cust_name原來的長度,不足的部分用*填充,也就是將第一個空格前的位置,用*填充。

where後過濾是否有三個名字,INSTR(cust_name, ' ',1,2)從第一個位置,從左往右,查找第二次出現的空格,如果返回非0值,則說明有第二個空格,則有第三個名字。

2.3.2 數值型函數

round 對指定的值做四捨五入,round(p,s) s為正數時,表示小數點後要保留的位數,s也可以為負數,但意義不大。

round:按指定精度對十進制數四捨五入,如:round(45.923, 1),結果,45.9

round(45.923, 0),結果,46

round(45.923, -1),結果,50

trunc 對指定的值取整 trunc(p,s)

trunc:按指定精度截斷十進制數,如:trunc(45.923, 1),結果,45.9

trunc(45.923),結果,45

trunc(45.923, -1),結果, 40

mod 返回除法後的余數

SQL> select mod(100,12) from al;

2.3.3 日期型函數

因為日期在oracle里是以數字形式存儲的,所以可對它進行加減運算,計算是以天為單位。

預設格式:DD-MON-RR.

可以表示日期范圍:(公元前)4712 至(公元)9999

時間格式

SQL> select to_date('2003-11-04 00:00:00' ,'YYYY-MM-DD HH24:MI:SS') FROM al;

SQL> select sysdate+2 from al; 當前時間+2day

SQL> select sysdate+2/24 from al; 當前時間+2hour

SQL> select sysdate+2/1440 from al; 當前時間+2分鍾

SQL> select (sysdate-hiredate)/7 week from emp; 兩個date類型差,結果是以天為整數位的實數。

①MONTHS_BETWEEN 計算兩個日期之間的月數

SQL>select months_between('1994-04-01','1992-04-01') mm from al;

查找emp表中參加工作時間>30年的員工

SQL>select * from emp where months_between(sysdate,hiredate)/12>32;

很容易認為單行函數返回的數據類型與函數類型一致,對於數值函數類型而言的確如此,但字元和日期函數可以返回任何數據類型的值。比如instr函數是字元型的,months_between函數是日期型的,但它們返回的都是數值。

②ADD_MONTHS 給日期增加月份

SQL>select hiredate,add_months(hiredate,4) from emp;

③LAST_DAY 日期當前月份的最後一天

SQL>select hiredate,last_day(hiredate) from emp;

④NEXT_DAY NEXT_DAY的第2個參數可以是數字1-7,分別表示周日--周六(考點)

比如要取下一個星期六,則應該是:

SQL>select next_day(sysdate,7) FROM DUAL;

⑤ROUND(p,s),TRUNC(p,s)在日期中的應用,如何舍入要看具體情況,s是MONTH按30天計,應該是15舍16入,s是YEAR則按6舍7入計算。

SQL>SELECT empno, hiredate,round(hiredate,'MONTH') AS round,trunc(hiredate,'MONTH') AS trunc FROM emp;

SQL>SELECT empno, hiredate, round(hiredate,'YEAR') AS round,trunc(hiredate,'YEAR') AS trunc FROM emp;

2.3.4 幾個有用的函數和表達式

1)DECODE函數和CASE表達式:

實現sql語句中的條件判斷語句,具有類似高級語言中的if-then語句的功能。

decode函數源自oracle, case表達式源自sql標准,實現功能類似,decode語法更簡單些。

decode函數用法:

SQL> SELECT job, sal,

decode(job, 'ANALYST', SAL*1.1, 'CLERK', SAL*1.15,'MANAGER', SAL*1.20, SAL) SALARY FROM emp

decode函數的另幾種常見用法:

SQL>select ename,job,decode(job,'MANAGER','中層幹部') leader from emp;

SQL> select ename,job,comm,decode (comm,null,'nonsale','sale') saleman from emp;

註:單一列處理,共四個參數:含義是:comm 如果為null就取'nonsale,否則取'sale'

SQL> select sal,sign(sal-1500) from emp;

SQL> select ename,decode (sign(sal-1500), 1, 'NORMAL','LOW') as "LEV" from emp;

註:sign()函數根據某個值是0、正數還是負數,分別返回0、1、-1,含義是:工資大於1500,返回1,真取'NORMAL',假取'LOW'

CASE表達式第一種用法:

SQL> SELECT job, sal,

case job when 'ANALYST' then SAL*1.10

when 'CLERK' then SAL*1.15

when 'MANAGER' then SAL*1.20

else sal end SALARY

FROM emp

CASE表達式第二種用法:

SQL> SELECT job, sal, case

when job='ANALYST' then SAL*1.1

when job='CLERK' then SAL*1.15

when job='MANAGER' then SAL*1.20

else sal end SALARY

FROM emp

以上三種寫法結果都是一樣的

CASE第二種語法比第一種語法增加了搜索功能。形式上第一種when後跟定值,而第二種還可以使用表達式和比較符。

看一個例子

SQL> SELECT ename,sal,case

when sal>=3000 then '高級'

when sal>=2000 then '中級'

else '低級' end 級別

FROM emp

再看一個例子:使用了復雜的表達式

SQL> SELECT AVG(CASE

WHEN sal BETWEEN 500 AND 1000 AND JOB='CLERK'

THEN sal ELSE null END) "CLERK_SAL"

from emp;

比較;

SQL> select avg(sal) from emp where job='CLERK';

2)DISTINCT(去重)限定詞的用法:

distinct貌似多行函數,嚴格來說它不是函數而是select子句中的一個選項。

SQL> select distinct job from emp; 消除錶行重復值。

SQL> select distinct job,deptno from emp; 重復值是後面的欄位組合起來考慮的

SQL> select distinct * from emp; 消除重復記錄

3)sys_context 獲取環境上下文的函數(多用於應用環境)

scott遠程登錄

SQL>select SYS_CONTEXT('USERENV','IP_ADDRESS') from al;

--------------------------------------------------------------------------------

192.168.0.136

SQL> select sys_context('userenv','sid') from al;

SYS_CONTEXT('USERENV','SID')

--------------------------------------------------------------------------------

129

SQL> select sys_context('userenv','terminal') from al;

SYS_CONTEXT('USERENV','TERMINAL')

--------------------------------------------------------------------------------

TIMRAN-222C75E5

the end !!!

@jackman 共築美好!

F. sql server 簡單的除法運算

用一個SQL求出來就可以了
select sum(case s when b the 1 else 0 end)/sum(case s when b then 0 else 1 end ) as result from t
但要判斷一下除數是否為0的情況,就要寫成這樣:
select case when sum(case s when b then 0 else 1 end )=0 then 0 else sum(case s when b the 1 else 0 end)/sum(case s when b then 0 else 1 end ) end as result from t
如果除數是0,結果返回0

G. sql相除的問題

SELECT field1/field2 FROM TB;
當 field1的數值 > field2的數值時,除法得出的結果是<1的,即0.xxxxxx
這個時候在DB2的環境下SELECT出來的值是0
解決方法:
先把field1轉換成DOUBLE類型的,這樣計算出來的就會得出小數點了,會顯示出0.xxxx
SELECT CAST(field1 AS FLOAT)/field2 FROM TB;
ps.網上搜的資料,寫的是double,但在SQL Server2008中一直報錯,改成FLOAT就沒問題了。
小數點顯示4位小數。可以進一步四捨五入,保留兩位小數點
SELECT ROUND(CAST(field1 AS DOUBLE)/field2, 2) FROM TB;
如果數據列的值為NULL,將其設置為0,那麼sql就要這么寫
SELECT ROUND(COALESCE(CAST(field1 AS DOUBLE), 0)/field2, 2) FROM TB;
COALESCE這個函數系統的用法如下:
a. 輸入參數為字元類型,且允許為空的,可以使用COALESCE(inputParameter,」)把NULL轉換成」;
b. 輸入類型為整型,且允許為空的,可以使用COALESCE(inputParameter,0),把空轉換成0;
c. 輸入參數為字元類型,且是非空非空格的,可以使用COALESCE(inputParameter,」)把NULL轉換成」,然後判斷函數返回值是否為」;
d. 輸入類型為整型,且是非空的,不需要使用COALESCE函數,直接使用IS NULL進行非空判斷。

熱點內容
myeclipse手動編譯 發布:2025-01-07 19:28:35 瀏覽:750
阿里雲資料庫恢復 發布:2025-01-07 19:24:19 瀏覽:415
teradata資料庫 發布:2025-01-07 19:23:31 瀏覽:853
我的世界電腦版無規矩生存伺服器 發布:2025-01-07 19:21:07 瀏覽:611
phpcookie設置域 發布:2025-01-07 19:14:49 瀏覽:624
系統存儲和內存設備 發布:2025-01-07 19:14:05 瀏覽:391
淘寶上賣源碼 發布:2025-01-07 19:12:29 瀏覽:884
仿美團外賣小程序源碼 發布:2025-01-07 19:03:51 瀏覽:346
資料庫攻防 發布:2025-01-07 19:03:04 瀏覽:26
安卓打包生成apk文件在哪裡 發布:2025-01-07 18:54:39 瀏覽:898