Question:

Insert into table_name  (1),(2),....

Teradata 貌似不能同时插入,只能一条一条插入,报错。

后来改为:

Insert into table_name (1);

Insert into table_name (2);

Insert into table_name (3);

...

就可以了。  但是不确定 是不是不能同时插入,还没找到确切的证据!!!

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

1. 系统变量

SELECT date,  time, user, database

-- 当前系统日期, 系统时间, 当前登陆的用户, 当前缺省的数据库

 
date 一般不用来更新 create_dt 和update_dt, 一般用 current_timestamp
SELECT user, current_timestamp
 

2. Extract

Teradata中EXTRACT函数支持日期数据中选取年.月.日.从时间数据中选取小时.分钟和秒

SELECT DATE;                                                   11/07/2014

SELECT EXTRACT(YEAR FROM DATE);      2014

SELECT EXTRACT(MONTH FROM DATE);  11

SLEECT EXTRACT(DAY FROM DATE);        07

SELECT EXTRACT(MONTH FROM DATE + 17);   12, 先date加17天,再计算month

SLEECT EXTRACT(MONTH FROM DATE) + 17;    29, 先计算month,再加上17

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

SELECT TIME; 14:52:32

SELECT EXTRACT(HOUR FROM TIME); 14

SELECT EXTRACT(SECOND FROM TIME+30

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

时间差处理,+-interval

例如

SEL current_timestamp,

current_timestamp + interval '1' YEAR         -- 年+1

current_timestamp + interval '1' MONTH      -- 月+1

current_timestamp + interval '1' DAY            -- 日+1

current_timestamp + interval '1' HOUR         -- 时+1

current_timestamp + interval '1' MINUTE      -- 分+1

3.输入参数

sp:    (IN test_variable INTEGER)

调用时,写  : test_variable 

----比如: WHERE group_id = : group_id

4. 调用/run某个sp

call dtv_iap_stage.rpt_run_prodqc_group(3)  -- 跑group_id 为3的QC report

5. Teradata 里面的NULL 值显示为 ?

如果要把NULL 值转化为其他的,用COALESCE (num, 0)  把num中的NULL 值转化为 0

6. 有时候遇到一个关键词作为列名或者表名,

这时候识别时会出现UDFCALLNAME 错误,只要加上"" 双引号即可。

比如SELECT  *  FROM DTV_TARGET. "ACCOUNT"

7 Teradata 里面怎么copy表,(相当于select into)

CREATE TABLE new_name AS

(SELECT

--指明列名) WITH NO DATA;  -- copy 表结构

WITH DATA;  -- copy 表结构和values

此时默认的是 SET table,不允许duplicates

若要保持数据一致,CREATE MULTISET table 即可,保留duplicates

Teradata SQL tips的更多相关文章

  1. Teradata SQL programming

    Teradata的SQL设计和Oracle真不是一个水平, 一点美感的没有.  上个世纪它靠着MPP一招鲜吃变天, 居然做了十多年数据仓库的老大,  时过境迁, 现在有不少SQL On Hadoop ...

  2. 【Teradata SQL】行转列函数TDStats.udfConcat

    TDstats.udfConcat为Teradata自带UDF,定义如下: show function tdstats.udfconcat; REPLACE FUNCTION tdstats.UDFC ...

  3. TERADATA SQL学习随笔<一>

    此博客内容简介及目录 http://www.cnblogs.com/weibaar/p/6644261.html 最近在TERADATA环境学习SQL.在这里记录一下学习中查过的知识点,作为备案. 目 ...

  4. 【Teradata SQL】字符串分割函数STRTOK和STRTOK_SPLIT_TO_TABLE

    STRTOK函数: 按照指定分隔符,将字符串分割成多个部分,返回指定部分字符串. 参数说明: (1)instring:字符串或字符串表达式. (2)delimiter:分隔符列表,字符串每个字符都会做 ...

  5. 【Teradata SQL】使用SQL将多个逗号分隔改为一个逗号分隔

    1.问题说明: //将如下字符串改为一个逗号分隔 张三,李四,王五,,,,,,六,,,,其,,,,,,,,,,,把 ==> 张三,李四,王五,六,其,把 2.解决方法 sel oreplace( ...

  6. Oracle SQL Tips

    左连接的同时只输出关联表的一条记录 WITH X AS (SELECT 1 ID FROM DUAL UNION SELECT 2 FROM DUAL UNION SELECT 3 FROM DUAL ...

  7. 【Teradata SQL】从中文数字字母混合字符串中只提取数字regexp_substr

    目标:从中文数字字母的字符串中只提取数字 sel regexp_substr('mint choc中文11国1','\d+')

  8. 【Teradata SQL】一个字段为空即取另外一个字段(连续取4个字段)-case when

    目标:如果col1为空则取col2的值,如果col2也为空则取col3的值,如果col3还为则取col4的值,如果四个字段均为空则取默认值 1.数据准备 create multiset table t ...

  9. 【Teradata SQL】日历函数查询

    查询2018年agmt_id=1076226890174464676612的,且金额类型代码为0212,每日协议金额. 1.协议金额历史表取某一日数据(20180101) sel t.start_dt ...

随机推荐

  1. HDU 1085 Holding Bin-Laden Captive --生成函数第一题

    生成函数题. 题意:有币值1,2,5的硬币若干,问你最小的不能组成的币值为多少. 解法:写出生成函数: 然后求每项的系数即可. 因为三种硬币最多1000枚,1*1000+2*1000+5*1000=8 ...

  2. nginx 一二事(2) - 创建虚拟静态服务器

    一.什么是nginx 是一个C语言开发的HTTP反向代理服务器,性能非常高 一个俄罗斯的哥们开发的,官方提供的测试性能能够达到5W的并发,我的天呐~,实际测试差不多是2W,而淘宝的牛人可以优化到200 ...

  3. iOS页面传值方式

    普遍传值方式如下: 1.委托delegate方式: 2.通知notification方式: 3.block方式: 4.UserDefault或者文件方式: 5.单例模式方式: 6.通过设置属性,实现页 ...

  4. NOI 1.7编程基础之字符串(35题)

    01:统计数字字符个数 查看 提交 统计 提问 总时间限制:  1000ms 内存限制:  65536kB 描述 输入一行字符,统计出其中数字字符的个数. 输入 一行字符串,总长度不超过255. 输出 ...

  5. 14Spring_AOP编程(AspectJ)_环绕通知

    在目标方法执行前后,进行代码增强 (阻止目标方法的执行 ) 环绕通知实现任何通知效果. 案例如下: 案例结构:

  6. 修改sqlserver2008默认的数据库文件保存路径

    在SSMS(SQL Server Management Studio)中,右键服务器,然后选择属性. 然后数据库设置,再配置数据库默认位置 方法二,直接使用sql语句修改 USE [master] G ...

  7. [资料]Keychain 获取设备唯一

    BAIDU http://blog.csdn.net/wonengxing/article/details/42142595 http://www.cnblogs.com/max5945/archiv ...

  8. Linux 进程通信(有名管道)

    有名管道(FIFO) 有名管道是持久稳定的. 它们存在于文件系统中. FIFO比无名管道作用更大,因为他们能让无关联的进程之间交换数据. 管道文件一般用于交换数据. shell命令创建管道 一个she ...

  9. IBatis.Net学习笔记七--日志处理

    IBatis.Net中提供了方便的日志处理,可以输出sql语句等调试信息. 常用的有两种:1.输出到控制台:   <configSections>    <sectionGroup  ...

  10. python 调用 shell 命令方法

    python调用shell命令方法 1.os.system(cmd) 缺点:不能获取返回值 2.os.popen(cmd) 要得到命令的输出内容,只需再调用下read()或readlines()等   ...