這個(gè)簡(jiǎn)單:
沁源ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書未來市場(chǎng)廣闊!成為創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:13518219792(備注:SSL證書合作)期待與您的合作!
select
case when
(syddm=1 and id=1) or (syddm=2 and id=2)
then id
else syddm as syddm_t,
case when
(syddm=1 and id=1) or (syddm=2 and id=2)
then id
else syddm as id_t
from table_t;
你的問題不太明確,我只能是假設(shè)你的要求是,當(dāng)syddm、id條件滿足你所列出的任意條件時(shí),原syddm列顯示id值,原id列顯示syddm值。
所以我的解決思路是使用case when來處理,當(dāng)滿足你的兩個(gè)條件中的任意時(shí),交換兩列值。
這種錯(cuò)誤最可能出現(xiàn)的情況就是rown列名不存在
你desc mytable后,把那個(gè)字段拷出來,不會(huì)那個(gè)rown的那個(gè)圈是零吧?
仔細(xì)檢查一下吧:)
1、首先建表語法:Create table 表名,字段 1 數(shù)據(jù)類型 [default 默認(rèn)值],字段 2 數(shù)據(jù)類型 [default 默認(rèn)值],...字段 n 數(shù)據(jù)類型 [default 默認(rèn)值]。
2、表刪除語法:DROP TABLE 表名。
3、表的修改,在sql中使用alter,可以修改表,添加語法:ALTER TABLE 表名稱 ADD(列名 1 類型 [DEFAULT 默認(rèn)值]。
4、UPDATE(修改)全部修改:UPDATE 表名 SET 列名 1=值 1,列名 2=值 2,....局部修改:UPDATE 表名 SET 列名 1=值 1,列名 2=值 2,....WHERE 修改條件。
5、?最后DELETE(刪除)語法 : DELETE FROM 表名 WHERE 刪除條件。
不能象修改表那樣直接改列名,只能是在定義視圖的語句里寫新的列名。
Oracle?11g 行列互換 pivot 和 unpivot 說明在Oracle 11g中,Oracle 又增加了2個(gè)查詢:pivot(行轉(zhuǎn)列) 和unpivot(列轉(zhuǎn)行)
參考:、 一下,網(wǎng)上有一篇比較詳細(xì)的文檔:
pivot 列轉(zhuǎn)行
測(cè)試數(shù)據(jù) (id,類型名稱,銷售數(shù)量),案例:根據(jù)水果的類型查詢出一條數(shù)據(jù)顯示出每種類型的銷售數(shù)量。
?
123456789
create table demo(id int,name varchar(20),nums int);? ---- 創(chuàng)建表insert into demo values(1, '蘋果', 1000);insert into demo values(2, '蘋果', 2000);insert into demo values(3, '蘋果', 4000);insert into demo values(4, '橘子', 5000);insert into demo values(5, '橘子', 3000);insert into demo values(6, '葡萄', 3500);insert into demo values(7, '芒果', 4200);insert into demo values(8, '芒果', 5500);
分組查詢 (當(dāng)然這是不符合查詢一條數(shù)據(jù)的要求的)
?
1
select name, sum(nums) nums from demo group by name
行轉(zhuǎn)列查詢
?
1
select * from (select name, nums from demo) pivot (sum(nums) for name in ('蘋果' 蘋果, '橘子', '葡萄', '芒果'));
注意: pivot(聚合函數(shù) for 列名 in(類型)) ,其中 in(‘’) 中可以指定別名,in中還可以指定子查詢,比如 select distinct code from customers
當(dāng)然也可以不使用pivot函數(shù),等同于下列語句,只是代碼比較長(zhǎng),容易理解
?
12
select * from (select sum(nums) 蘋果 from demo where name='蘋果'),(select sum(nums) 橘子 from demo where name='橘子'),???????(select sum(nums) 葡萄 from demo where name='葡萄'),(select sum(nums) 芒果 from demo where name='芒果');
unpivot 行轉(zhuǎn)列
顧名思義就是將多列轉(zhuǎn)換成1列中去
案例:現(xiàn)在有一個(gè)水果表,記錄了4個(gè)季度的銷售數(shù)量,現(xiàn)在要將每種水果的每個(gè)季度的銷售情況用多行數(shù)據(jù)展示。
創(chuàng)建表和數(shù)據(jù)
?
1234567
create table Fruit(id int,name varchar(20), Q1 int, Q2 int, Q3 int, Q4 int);?insert into Fruit values(1,'蘋果',1000,2000,3300,5000);insert into Fruit values(2,'橘子',3000,3000,3200,1500);insert into Fruit values(3,'香蕉',2500,3500,2200,2500);insert into Fruit values(4,'葡萄',1500,2500,1200,3500);select * from Fruit
列轉(zhuǎn)行查詢
?
1
select id , name, jidu, xiaoshou from Fruit unpivot (xiaoshou for jidu in (q1, q2, q3, q4) )
注意: unpivot沒有聚合函數(shù),xiaoshou、jidu字段也是臨時(shí)的變量
如果列名不適合,那么可以使用alter
table語句的rename
column子句改變列名。語法如下:
alter
table
table_name
rename
column
column_name
to
new_column_name;
你這一題該是
alter
text
rename
textpass
to
password
去試下!