• SQL基本语句(3) LOAD DATA INFILE


    使用LOAD语句批量录入数据

    语法:

    LOAD DATA [LOW_PRIORITY | CONCURRENT] [LOCAL] INFILE 'file_name'
    
        [REPLACE | IGNORE]
    
        INTO TABLE tbl_name
    
        [CHARACTER SET charset_name]
    
        [{FIELDS | COLUMNS}
    
            [TERMINATED BY 'string']
    
            [[OPTIONALLY] ENCLOSED BY 'char']
    
            [ESCAPED BY 'char']
    
        ]
    
        [LINES
    
            [STARTING BY 'string']
    
            [TERMINATED BY 'string']
    
        ]
    
        [IGNORE number LINES]
    
        [(col_name_or_user_var,...)]
    
        [SET col_name = expr,...]

    LOAD DATA INFILE语句从一个文本文件中以很高的速度读入一个表中。如果指定LOCAL关键词,从客户主机读文件。如果LOCAL没指定,文件必须位于服务器上。

    为了安全原因,当读取位于服务器上的文本文件时,文件必须处于数据库目录或可被所有人读取。另外,为了对服务器上文件使用LOAD DATA INFILE,在服务器主机上你必须有file的权限。

    REPLACE和IGNORE关键词控制对现有的唯一键记录的重复的处理。如果你指定REPLACE,新行将代替有相同的唯一键值的现有行。如果你指定IGNORE,跳过有唯一键的现有行的重复行的输入。如果你不指定任何一个选项,当找到重复键时,出现一个错误,并且文本文件的余下部分被忽略。

    如果你使用LOCAL关键词从一个本地文件装载数据,服务器没有办法在操作的当中停止文件的传输,因此缺省的行为好像IGNORE被指定一样。

    文件的搜

    • 如果给出一个绝对路径名,服务器使用该路径名。
    • 如果给出一个有一个或多个前置部件的相对路径名,服务器相对服务器的数据目录搜索文件。
    • 如果给出一个没有前置部件的一个文件名,服务器在当前数据库的数据库目录寻找文件。

    FIELDSLINES子句的语法

    如果你指定一个FIELDS子句,它的每一个子句(TERMINATED BY, [OPTIONALLY] ENCLOSED BY和ESCAPED BY)也是可选的,除了你必须至少指定他们之一。如果你不指定一个FIELDS子句,缺省值与你这样写的相同:

    FIELDS TERMINATED BY ' ' ENCLOSED BY '' ESCAPED BY '\'

    如果你不指定一个LINES子句,缺省值与你这样写的相同:

    LINES TERMINATED BY ' '

    换句话说,缺省值导致读取输入时,LOAD DATA INFILE表现如下:

    • 在换行符处寻找行边界
    • 在定位符处将行分进字段
    • 不要期望字段由任何引号字符封装
    • 将由“”开头的定位符、换行符或“”解释是字段值的部分字面字符
  • 相关阅读:
    spring bean 循环依赖问题,在本地环境可以,测试环境报循环依赖问题
    mac 使用
    TCP状态
    Flink 学习 — Flink JobManager 高可用性配置
    Flink 学习 — Flink 写入数据到 Kafka
    Flink 学习 — 上传Flink 项目JAR运行
    Flink 学习 — Flink 写入数据到 ElasticSearch
    Redis持久化原理 — RDB与AOF详细解释
    Flink 学习 — Flink 中几种 Time 详解
    Flink 学习 — Flink中的Stream Windows介绍
  • 原文地址:https://www.cnblogs.com/ryansunyu/p/4244342.html
Copyright © 2020-2023  润新知