加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

oracle 导入txt

发布时间:2020-12-12 16:21:40 所属栏目:百科 来源:网络整理
导读:1899800 广东省东莞市 电信 0769 1899801 广东省东莞市 电信 0769 如上,有25w条手机号归属地的记录要入库,文件是excel格式的 首先,建表,4个字段; 然后,将excel另存为txt文件,选择制表符分隔; 在txt文件同一目录,新建文件load.ctl, 字符集ZHS16GBK的
1899800      广东省东莞市        电信      0769  
1899801      广东省东莞市        电信      0769  

如上,有25w条手机号归属地的记录要入库,文件是excel格式的



首先,建表,4个字段;


然后,将excel另存为txt文件,选择制表符分隔;



在txt文件同一目录,新建文件load.ctl,字符集ZHS16GBK的文本文件的控制文件load.ctl的内容如下:

Ctl代码
  1. LOADDATA
  2. CHARACTERSETZHS16GBK
  3. INFILE'data.txt'
  4. intotableT_USER_INFO
  5. (PHONE_SEGMENTCHARterminatedbyx'09'OPTIONALLYENCLOSEDBY'"',
  6. PHONE_DISTRICTCHARterminatedby PHONE_MNOCHARterminatedby PHONE_REGIONcharterminatedbyx'09'OPTIONALLYENCLOSEDBY'"')


这里的字符集名称和数据库的字符集名称一致。如果字符集不匹配,在加载数据进入数据库后,你会发现中文或其他文件的都会是乱码。
如果数据库字符集是ALT32UTF8,那么需要将"CHARACTERSET ZHS16GBK"修改为"CHARACTERSET UTF8"。


字段分隔符说明:
terminated by x'09',指字段以X'09' -- 制表符(TAB)分隔
terminated by ',',指用逗号分隔
terminated by whitespace ,指结尾以空白分隔


最后,cmd打开命令行,切换到load.ctl文件所在目录,执行“sqlldr userid=username/password@databasecontrol=load.ctl”

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读