如何在C 中用程序执行指定的SQL脚本文件,实

如何在C 中用程序执行指定的SQL脚本文件,实,第1张

1、用cmd命令打开DOS命令行窗口

2、用sqlplus命令进入SQL命令状态,命令行如下:c:\sqlplus/nolog

3、用如下命令连接数据库:connect 数据库用户名/密码@sid_ip,如:sql>connectionljm/ljm@ljm_localhost(本机数据库)

4、用如下命令执行脚本文件sql>@完整路径文件名

5、如果要导入SEQUENCE的话,可以用toad工具先生成SEQ脚本文件,再用如上命令导入

有两种方法:

1。在A2.c中有完整的函数定义,在A1.c中添加一下要用到的函数原型(声明)就可以了,例如:

在A2.c中:有函数void A2(){...}

在A1.c中:在文件前头增加一行:void A2()就可以了

2。把A2.c中完整定义的函数的原型,写到一个A2.h文件中,然后在A1.c的文件头增加#include "A2.h"就可以了

以上两种方法,在A1.c中都可以正常的调用,就跟在A2.c中调用一样。

其实函数默认是外部的,只要在其他文件中声明就能使用; 但是注意如果在前面加上static , 就只能在本文件中使用了, 不能再被其他的文件调用。

使用pl/sql 的export user objects可以只导出表结构,但是如果导入这个sql脚本时,如使用打开sql文件,然后执行的方式会导致comment出错,原因是添加注释时,表还未创建。

百度一下,有人说要把建表和注释两个sql分开执行,但是我这有好几百个表啊,幸好发现可以用command的方式执行sql脚本文件:

导入的sql内容:

prompt

prompt Creating table DF_T_CODEVALUE

prompt =============================

prompt

create table SGDC_PMS2.DF_T_CODEVALUE

(

pkidVARCHAR2(50) not null,

valueid VARCHAR2(50),

nameVARCHAR2(100) not null,

parent_id VARCHAR2(50),

sortid NUMBER,

notes VARCHAR2(100),

codeid VARCHAR2(50) not null,

pathnameVARCHAR2(200),

is_do CHAR(1),

dept_code VARCHAR2(20),

tab_yearVARCHAR2(4),

tab_month VARCHAR2(2),

tab_day VARCHAR2(2),

uptime DATE,

recordtimestamp DATE,

recordstatusVARCHAR2(42),

sjztNUMBER(2)

)

tablespace TS_ODS

pctfree 10

initrans 1

maxtrans 255

storage

(

initial 64K

next 1M

minextents 1

maxextents unlimited

)

comment on table SGDC_PMS2.DF_T_CODEVALUE

is '隐患基础数据信息'

comment on column SGDC_PMS2.DF_T_CODEVALUE.pkid

执行方式:

从.sql脚本文件读取数据到数据库

1.新建Command Windows

2.执行:SQL>@C:\XX.sql


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9902097.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存