shell脚本导入数据到Oracle
时间: 2023-10-17 07:02:55 浏览: 161
以下是一个示例脚本,演示如何将数据从一个文本文件导入Oracle数据库中的表中:
```
#!/bin/bash
# 数据库连接信息
DB_USER=username
DB_PASS=password
DB_SID=oracle_sid
# 待导入的文件路径和表名
FILE_PATH=/path/to/data.txt
TABLE_NAME=my_table
# 使用SQL Loader导入数据
sqlldr ${DB_USER}/${DB_PASS}@${DB_SID} control=loader.ctl data=${FILE_PATH} log=loader.log bad=loader.bad
# 打印导入结果
if [ $? -eq 0 ]; then
echo "Data loaded successfully!"
else
echo "Data load failed. Please check loader.log and loader.bad for details."
fi
```
上述脚本使用SQL Loader工具导入数据。这需要一个控制文件(loader.ctl)来指定数据文件的格式和如何映射到表中的列。以下是一个示例控制文件:
```
LOAD DATA
INFILE '${FILE_PATH}'
APPEND
INTO TABLE ${TABLE_NAME}
FIELDS TERMINATED BY ','
TRAILING NULLCOLS
(
COLUMN1,
COLUMN2,
COLUMN3
)
```
其中,`${FILE_PATH}`和`${TABLE_NAME}`是在脚本中定义的变量。`${DB_USER}`、`${DB_PASS}`和`${DB_SID}`是连接Oracle数据库所需的用户名、密码和实例名。在控制文件中,每个列都映射到数据文件中的一列,其中用逗号分隔字段。`TRAILING NULLCOLS`指定在数据文件中的行末可以有空字段。
使用该脚本时,只需要替换变量的值,并确保数据文件和控制文件存在并具有正确的格式。然后运行该脚本即可将数据导入Oracle表中。
阅读全文