mysql使用LOAD语句批量录入数据

来源:asp之家 时间:2010-03-18 16:19:00 

本章的前面讨论如何使用SQL向一个表中插入数据。但是,如果你需要向一个表中添加许多条记录,使用SQL语句输入数据是很不方便的。幸运的是,MySQL提供了一些方法用于批量录入数据,使得向表中添加数据变得容易了。本节以及下一节,将介绍这些方法。本节将介绍SQL语言级的解决方法。

1、基本语法

语法:LOAD DATA [LOCAL] INFILE 'file_name.txt' [REPLACE | IGNORE] INTO TABLE tbl_name LOAD DATA INFILE语句从一个文本文件中以很高的速度读入一个表中。如果指定LOCAL关键词,从客户主机读文件。如果LOCAL没指定,文件必须位于服务器上。(LOCAL在MySQL3.22.6或以后版本中可用。)

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

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

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

2、文件的搜寻原则

当在服务器主机上寻找文件时,服务器使用下列规则:

如果给出一个绝对路径名,服务器使用该路径名。

如果给出一个有一个或多个前置部件的相对路径名,服务器相对服务器的数据目录搜索文件。

如果给出一个没有前置部件的一个文件名,服务器在当前数据库的数据库目录寻找文件。

注意这些规则意味着一个像“./myfile.txt”给出的文件是从服务器的数据目录读取,而作为“myfile.txt”给出的一个文件是从当前数据库的数据库目录下读取。也要注意,对于下列哪些语句,对db1文件从数据库目录读取,而不是db2:

mysql> USE db1;mysql> LOAD DATA INFILE "./data.txt" INTO TABLE db2.my_table;

3、FIELDS和LINES子句的语法

如果你指定一个FIELDS子句,它的每一个子句(TERMINATED BY, [OPTIONALLY] ENCLOSED BY和ESCAPED BY)也是可选的,除了你必须至少指定他们之一。

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

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

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

LINES TERMINATED BY '\n'

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

在换行符处寻找行边界

在定位符处将行分进字段

不要期望字段由任何引号字符封装

将由“\”开头的定位符、换行符或“\”解释是字段值的部分字面字符

标签:mysql,批量,数据,LOAD
0
投稿

猜你喜欢

  • python3下载抖音视频的完整代码

    2023-12-24 01:10:42
  • javascript常见数字进制转换实例分析

    2024-04-30 10:08:48
  • sql server 2008数据库连接字符串大全

    2024-01-18 13:42:09
  • 使用JavaScript获取地址栏参数的方法

    2024-04-28 10:18:25
  • python多进程实现文件下载传输功能

    2022-06-27 02:22:41
  • Ajax request response 乱码解决方法

    2024-06-05 09:21:52
  • Python字符串格式化f-string多种功能实现

    2021-01-09 22:56:45
  • Python selenium的基本使用方法分析

    2021-11-04 10:01:30
  • goland使用go mod模式的步骤详解

    2024-05-25 15:16:35
  • SQL Server免费版的安装以及使用SQL Server Management Studio(SSMS)连接数据库的图文方法

    2024-01-15 03:45:14
  • 超全面python常见报错以及解决方案梳理必收藏

    2022-02-14 16:33:17
  • Python魔法方法 容器部方法详解

    2021-02-05 19:25:43
  • python实现linux下抓包并存库功能

    2022-12-23 20:22:06
  • Python利用PyPDF2快速拆分PDF文档

    2021-11-06 09:39:23
  • JavaScript中var let const的用法有哪些区别

    2024-05-09 15:06:33
  • Vue3+Vite实现动态路由的详细实例代码

    2023-07-02 16:58:37
  • Python的Bottle框架基本知识总结

    2023-10-09 09:29:24
  • python中.format()方法使用详解

    2021-07-19 03:38:07
  • python爬虫中抓取指数的实例讲解

    2022-02-18 04:59:58
  • PHP中error_reporting()函数的用法(修改PHP屏蔽错误)

    2023-11-20 01:08:17
  • asp之家 网络编程 m.aspxhome.com