db2 SQL

下面内容都是通过网上查找及实践后整理出来的 ,加入了部分个人理解,如果错误请指出

查看表结构:

db2 describe table db2inst1.eip4_info
db2 describe indexes for table db2inst1.eip4_info show detail


添加表字段
alter table td_storage add EXAPROJECT VARCHAR(100);


修改字段长度
db2 alter table eip_user alter column userpass set data type VARCHAR(40)


将表中一列修改为自动增长时,可用下面命令:
Alter table alter column set generated always as identity (start with 1,increment by 1)


修改表中一列自动增长的开始值时,可用下面的命令:
ALTER TABLE ALTER COLUMN RESTART WITH 18;


DB2可以使用generated always as identity 将某一个字段指定为自增长的字段,
比如:
  这表示id自动是一个自增长的字段,它从1开始增加每次增加1。也可以通过generated 将字段的值通过其他字段的计算的来,比如;
  create table user(name varchar(30),
  n1 integer,
  n2 integer ,
  id integer generated always as (n1+n2))
  如:
  create table strategy
  (
  strategy_id decimal(17)
  GENERATED ALWAYS AS IDENTITY (START WITH 1, INCREMENT BY 1 )
  primary key not null,
  strategy_name varchar(200),
  area_code decimal(6,0)
  );


查询所有用户
select distinct tabschema from syscat.tables


查询db2inst1用户的所有表(注意大小写)
db2 "select name,type,CREATOR from SYSIBM.systables where type='T' and CREATOR = 'DB2INST1'"


db2 "select name,type,CREATOR from SYSIBM.systables where type='T' and CREATOR = 'DB2INST1' and locate('tab',name)>0"


如果想看每一个表中的条数:
select A.name,B.rowcnt from sysibm.sysobjects A,sysibm.systabstats B WHERE A.id=B.id and A.type='U'


select B.rowcnt from SYSIBM.systabstats B 


VALUE函数 


语法:VALUE(EXPRESSION1,EXPRESSION2) 


VALUE函数是用返回一个非空的值,当其第一个参数非空,直接返回该参数的值,如果第一个参数为空,则返回第一个参数的值。 
eg:
--表示如果T1.ID为空,则返回空串,如果T1.ID不为空,则返回T1.ID。
SELECT VALUE(ID,'') FROM T1
 


COALESCE函数 


语法:COALESCE(ARG1,ARG2...) 


COALESCE返回参数集中第一个非null参数。用法类似于VALUE函数。 




LENGTH函数 


语法:LENGTH(ARG) 


LENGTH函数返回参数的长度。 
eg:SELECT LENGTH(NAME) FROM T1 


LCASE、LOWER函数 


语法:LCASE()、LOWER() 


LCASE、LOWER函数返回定长、变长字符串的小写形式。 
eg:SELECT LCASE(NAME),LOWER(NAME) FROM T1 


UCASE、UPPER函数 


语法:UCASE()、UPPER() 


UCASE、UPPER函数返回定长、变长字符串的大写形式。 
eg:SELECT UCASE(NAME),UPPER(NAME) FROM T1 


LTRIM、RTRIM函数 


语法:LTRIM()、RTRIM() 


LTRIM、RTRIM函数从CHAR、VARCHAR、GRAPHIC或者VARGRAPHIC中去掉左侧或右侧的空格。 
eg:SELECT LTRIM(NAME),RTRIM(NAME) FROM T1 


LEFT、RIGHT函数 


语法:LEFT(ARG,LENGTH)、RIGHT(ARG,LENGTH) 


LEFT、RIGHT函数返回ARG最左边、右边的LENGTH个字符串,ARG可以是CHAR或BINARY STRING。 
eg:SELECT LEFT(NAME,2),RIGHT(NAME,2) FROM T1 


CONCAT函数 


语法:CONCAT(ARG1,ARG2) 


CONCAT函数返回两个字符串的连接。 
eg:SELECT CONCAT(FIRST_NAME,LAST_NAME) FROM T1 


INSERT函数 


语法:INSERT(ARG1,POS,SIZE,ARG2) 


INSERT函数返回一个字符串,将ARG1从POS处删除SIZE个字符,将ARG2插入该位置。 
eg: 


LOCATE函数 


语法:LOCATE(ARG1,ARG2,


LOCATE函数在ARG2中查找ARG1第一次出现的位置,如果指定POS,则从ARG2的POS处开始查找ARG1第一次出现的位置。 
eg:SELECT LOCATE('a',NAME) FROM T1 


POSSTR函数 


语法:POSSTR(EXP1,EXP2) 


POSSTR函数返回EXP2在EXP1中的位置。 
eg:SELECT LOCATE(NAME,'a') FROM T1 


REPEAT函数 


语法:REPEAT(ARG1,NUM_TIMES) 


REPEAT函数返回ARG1被重复NUM_TIMES次的字符串。 
eg:SELECT REPEAT(NAME,2) FROM T1 


REPLACE函数 


语法:REPLACE(EXP1,EXP2,EXP3) 


REPLACE函数用EXP3代替EXP1中所有的EXP2。 
eg:SELECT REPLACE('ROMANND','NND','CCB') FROM T1 


SPACE函数 


语法:SPACE(SIZE) 


SPACE函数返回一个包含SIZE个空格的字符串。 
eg:SELECT SPACE(10) FROM T1 


SUBSTR函数 


语法:SUBSTR(ARG1,POS,


SUBSTR函数返回ARG1中POS位置开始的LENGTH个字符,如果没有指定LENGTH,则返回剩余的字符。 
eg:SELECT SUBSTR('CDNJFDJFJD',5,2) FROM T1

你可能感兴趣的:(db2)