Oracle简单脚本示例

1.增加表

--修改日期:2014.09.21

--修改人:易小群

--修改内容:新增采购支付情况表

DECLARE

VC_STR           VARCHAR2(5000);

VN_COUNT         NUMBER;

BEGIN

--查看现有系统是否有BT_PRODUCT_MODEL表

SELECTCOUNT(*)

INTO VN_COUNT

FROM USER_TABLES

WHERE TABLE_NAME =‘BT_BUY_PAY‘;

--如果没有则新增表,如果有就不处理

IF VN_COUNT < 1 THEN

VC_STR :=
‘  create table BT_BUY_PAY

(

id  NUMBER not null,

buynumber     VARCHAR2(30),

money     NUMBER(15,2),

recevietime     DATE,

recordtime    DATE,

currency VARCHAR2(30),

foreigncurrency  NUMBER(15,2),

constraint PK_BT_BUY_PAY_ID primary key (id)

)‘;

EXECUTE IMMEDIATE VC_STR;

END IF;

END;

2.增加字段

--修改人:易小群

--修改时间:2014-9-18

--修改内容:采购合同表增加合同所属字段(本部和集团)

DECLARE

VN_COUNT     NUMBER;

VC_STR        VARCHAR2(1000);

BEGIN

--查看该表中该字段是否存在

SELECTCOUNT(*)

INTO VN_COUNT

FROM USER_TAB_COLUMNS

WHERE TABLE_NAME =‘BT_BUY_RECORD‘AND
COLUMN_NAME =‘CONTRACTBELONG‘;

IF VN_COUNT < 1 THEN

VC_STR :=
‘ ALTER TABLE BT_BUY_RECORD ADD CONTRACTBELONG VARCHAR2(30)‘;

EXECUTE IMMEDIATE VC_STR;

END IF;

END;

3.创建视图

createorreplaceview v_bt_buy_fprecord_ceas

selectdistinct b.corp_code,

c.corp_name,--单位名称

d.buynumber,--采购合同号

b.buyname,--采购合同名称

d.sale_no,--销售合同号

d.product_id,--产品id

d.product_name,--产品名称

d.money,--明细金额

b.htprice,--合同金额

d.out_money,--已付金额

vf.ymoney,--已开发票金额

b.status

from bt_buy_record b

leftjoin bt_corp c

on b.corp_code = c.corp_code

leftjoin bt_buy_detail d

on b.buynumber = d.buynumber

leftjoin (select
f.detail_id, sum(f.money)as ymoney

from bt_buy_fprecord f

groupby f.detail_id) vf

on d.id = vf.detail_id

orderby b.corp_code  ;

4.修改表的字段允许为空

--修改人:易小群

--修改时间:2014年9月11日

--修改内容:修改表BT_BUY_FPRECORD字段PRODUCE_NAME允许为空

--修改原因:采购合同导入时报PRODUCE_NAME为NULL不能插入

DECLARE

VN_NULLABLE VARCHAR2(1);

BEGIN

SELECT nullable

INTO VN_NULLABLE

FROM user_tab_columns

WHERE table_name =‘BT_BUY_FPRECORD‘

AND column_name =‘PRODUCE_NAME‘;

--如果不允许为空

IF VN_NULLABLE =
‘N‘THEN

--更改为允许为空

EXECUTE IMMEDIATE‘ ALTER TABLE BT_BUY_FPRECORD MODIFY PRODUCE_NAME VARCHAR2(200) NULL ‘;

END IF;

COMMIT;

END;

5.修改字段长度

--修改人:易小群

--修改时间:2014年9月3日

--修改内容:修改表BT_BUY_DETAIL字段PRODUCT_NAME的长度

--修改原因:导入时报其字段的长度不够

altertable BT_BUY_DETAIL modify(PRODUCT_NAME varchar2(500));

--修改产品名称字段,发票表导入报其字段的长度不够

altertable BT_BUY_FPRECORD modify(PRODUCT_NAME  varchar2(500));

commit;

时间: 2024-11-10 14:35:59

Oracle简单脚本示例的相关文章

ORACLE常用脚本示例

create table DBO.INDEX_POLICY_TBL( ID NUMBER(10) NOT NULL PRIMARY KEY, POLICY_ID NUMBER(10,0) default (-1) NOT NULL, ALARM_COUNT NUMBER(10) default (0) NOT NULL); ALTER TABLE DBO.INDEX_POLICY_TBL ADD(C_NAME_1 VARCHAR2(64 CHAR) NOT NULL, C_NAME_2 VARC

shell脚本程序中的部分常用环境变量和参数变量的说明以及简单shell脚本示例

环境变量 $HOME 当前用户的家目录 $PATH 以冒号分隔的用来搜索命令的目录列表 $PS1 命令提示符,通常是$字符,但在bash中,可以使用一些更复杂的值.例如,字符串[\[email protected]\h\w]$就是一个流行的默认值,它给出用户名/机器名和当前的目录名,当然也包括一个$提示符. $PS2 二级提示符,用来表示后续的输入,通常是 > 字符. $IFS 输入域分隔符.当shell读取输入时,它给出用来分隔单词的一组字符,他们通常是空格,制表符和换行符. $0 shell

linux添加开机自启动脚本示例详解

来源: linux添加开机自启动脚本示例详解 linux下(以RedHat为范本)添加开机自启动脚本有两种方法,先来简单的; 一.在/etc/rc.local中添加如果不想将脚本粘来粘去,或创建链接什么的,则:step1. 先修改好脚本,使其所有模块都能在任意目录启动时正常执行;step2. 再在/etc/rc.local的末尾添加一行以绝对路径启动脚本的行;如:$ vim /etc/rc.local#!/bin/sh## This script will be executed *after*

bash颜色、变量、数组、相关脚本示例

下面是bash的相关内容,包括bash的颜色代码.bash的四类文件.bash中变量处理方式.数组变量.shell的过程式编程语言以及部分简单脚本例子. 一.bash的颜色显示规则(颜色代码) bash的颜色代码,是ASCII编码对于颜色进行设置.颜色代码中,字符串\033:表示Ctrl.其中,关于颜色代码的各字符实现的功能如下: [  :控制字符和颜色代码之间的间隔字符 0m:关闭颜色属性的命令 1m:对于显示的文本字符进行加粗 4m:为文本字符加下划线标识 5m:使文本字符闪烁 7m:将背景

JS javascript面向对象的理解及简单的示例

javascript面向对象的理解及简单的示例 一. javascript面向对象概念: 为了说明 JavaScript 是一门彻底的面向对象的语言,首先有必要从面向对象的概念着手 , 探讨一下面向对象中的几个概念: 1.一切事物皆对象 2.对象具有封装和继承特性 3.对象与对象之间使用消息通信,各自存在信息隐藏 以这三点做为依据,C++ 是半面向对象半面向过程语言,因为,虽然他实现了类的封装.继承和多态,但存在非对象性质的全局函数和变量.Java.C# 是完全的面向对象语言,它们通过类的形式组

hydra简单使用示例

本内容为网上收集整理,仅作为备忘!! hydra简单使用示例: 破解https: # hydra -m /index.php -l muts -P pass.txt 10.36.16.18 https 破解teamspeak: # hydra -l 用户名 -P 密码字典 -s 端口号 -vV ip teamspeak 破解cisco: # hydra -P pass.txt 10.36.16.18 cisco # hydra -m cloud -P pass.txt 10.36.16.18 c

Ext简单demo示例

1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> 2 <html> 3 <head> 4 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> 5 <titl

Salesforce用Apex判断Role Hierarchy的简单代码示例

由于role不同于Profile,带有阶层性质,所以有一些自定义功能要依赖于这种阶层的设定.这样就涉及到role hierarchy的判断问题. 我是一个绝懒之人,所以去网上搜了一下,能找到的方案都或多或少有些缺陷 . 我所提供的方案也是如此,但是想比于浪费太多SOQL查询次数来讲,role的数量不超过50000条已经是足够好了.// 这里Update一下,其实根本不会有那么多的Role,因为默认500,向Salesforce技术支持提票才能达到10000. Talk is cheap, sho

数组的简单使用示例

/* ============================================================================ Name : TestArray.c Author : lf Version : Copyright : Your copyright notice Description : 数组的简单使用示例 =======================================================================