位置: 编程技术 - 正文

MySQL load语句详细介绍(mysql load local)

编辑:rootadmin

推荐整理分享MySQL load语句详细介绍(mysql load local),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql load null值,mysql load 指定字段,mysql load 命令,mysql中load,mysql load infile,mysql load 命令,mysql load ignore,mysql load ignore,内容如对您有帮助,希望把文章链接给更多的朋友!

load的语法

LOAD DATA INFILE语句用于高速地从一个文本文件中读取行,并装入一个表中。文件名称必须为一个文字字符串。

由character_set_database系统变量指示的字符集被用于解释文件中的信息。SET NAMES和character_set_client的设置不会影响对输入的解释。

典型的示例

如果您只想载入一个表的部分列,则应指定一个列清单:

文件的路径

如果指定了LOCAL,则被认为与连接的客户端有关:

1.如果指定了LOCAL,则文件会被客户主机上的客户端读取,并被发送到服务器。文件会被给予一个完整的路径名称,以指定确切的位置。如果给定的是一个相对的路径名称,则此名称会被理解为相对于启动客户端时所在的目录。

2.如果LOCAL没有被指定,则文件必须位于服务器主机上,并且被服务器直接读取。

当在服务器主机上为文件定位时,服务器使用以下规则:

1).如果给定了一个绝对的路径名称,则服务器使用此路径名称。2).如果给定了带有一个或多个引导组件的相对路径名称,则服务器会搜索相对于服务器数据目录的文件。3).如果给定了一个不带引导组件的文件名称,则服务器会在默认数据库的数据库目录中寻找文件。

注意,这些规则意味着名为./myfile.txt的文件会从服务器数据目录中被读取,而名为myfile.txt的同样的文件会从默认数据库的数据库目录中读取。

从客户端使用绝对路径load数据

从服务器里使用相对路径load数据

下面的LOAD DATA语句会从db1数据库目录中读取文件data.txt,因为db1是当前数据库。即使语句明确把文件载入到db2数据库中的表里,也会从db1目录中读取。

IGNORE number LINES选项

IGNORE number LINES选项可以被用于在文件的开始处忽略行。

您可以使用IGNORE 1 LINES来跳过一个包含列名称的起始标题行:

REPLACE和IGNORE

有些输入记录把原有的记录复制到唯一关键字值上。REPLACE和IGNORE关键字用于控制这些输入记录的操作。

如果您指定了REPLACE,则输入行会替换原有行(换句话说,与原有行一样,对一个主索引或唯一索引具有相同值的行)。

如果您指定IGNORE,则把原有行复制到唯一关键字值的输入行被跳过。

如果您这两个选项都不指定,则运行情况根据LOCAL关键词是否被指定而定。不使用LOCAL时,当出现重复关键字值时,会发生错误,并且剩下的文本文件被忽略。使用LOCAL时,默认的运行情况和IGNORE被指定时的情况相同;这是因为在运行中间,服务器没有办法中止文件的传输

索引的影响

如果您对一个空的MyISAM表使用LOAD DATA INFILE,则所有的非唯一索引会被创建在一个独立批中(对于REPAIR TABLE)。当您有许多索引时,这通常会使LOAD DATA INFILE大大加快。通常,LOAD DATA INFILE的速度会非常快,但是在某些极端情况下,您可以在把文件载入到表中之前使用ALTER TABLE...DISABLE KEYS关闭LOAD DATA INFILE,或者在载入文件之后使用ALTER TABLE...ENABLE KEYS再次创建索引,使创建索引的速度更快。

MySQL load语句详细介绍(mysql load local)

FIELDS和LINES的默认值

如果您不指定FIELDS子句,则默认值为假设您写下如下语句时的值:

如果您不指定LINES子句,则默认值为假设您写下如下语句时的值:

换句话说,当读取输入值时,默认值会使LOAD DATA INFILE按如下方式运行:

相反的,当编写输出值时,默认值会使SELECT...INTO OUTFILE按如下方式运行:

注意,要写入FIELDS ESCAPED BY ‘\',您必须为待读取的值指定两个反斜杠,作为一个单反斜杠使用。

备注:如果您已经在Windows系统中生成了文本文件,您可能必须使用LINES TERMINATED BY ‘rn'来正确地读取文件,因为Windows程序通常使用两个字符作为一个行终止符。部分程序,当编写文件时,可能会使用r作为行终止符。要读取这样的文件,应使用LINES TERMINATED BY ‘r'。

STARTING LINES选项

如果所有您希望读入的行都含有一个您希望忽略的共用前缀,则您可以使用'prefix_string'来跳过前缀(和前缀前的字符)。如果某行不包括前缀,则整个行被跳过。注释:prefix_string会出现在一行的中间。

以下面的test.txt为文件源

使用以下sql导入数据

最后并只得到数据("row",1)和("row",2)。

TERMINATED LINES选项

如果jokes被由%%组成的行分隔,要读取包含jokes的文件,您可以这么操作:

TERMINATED,ENCLOSED,ESCAPED FIELD选项

TERMINATED用于控制字段的分隔符,可以为多个字符。

ENCLOSED BY用于用于控制字段的引号,必须为单一字符,如果您忽略了词语OPTIONALLY,则所有的字段都被包含在ENCLOSED BY字符串中,如果您指定了OPTINALLY,则ENCLOSED BY字符只被用于包含具有字符串数据类型(比如CHAR, BINARY, TEXT或ENUM)的列中的值.

SELECT...INTO OUTFILE导出数据,ENCLOSED BY '"',忽略OPTIONALLY

SELECT...INTO OUTFILE导出数据,ENCLOSED BY '"',指定OPTIONALLY

ESCAPED BY用于转义,FIELDS ESCAPED BY值必须为单一字符。

如果FIELDS ESCAPED BY字符为空字符,则没有字符被转义,并且NULL被作为NULL输出,而不是N。去指定一个空的转义符不是一个好办法,特别是如果数据的字段值包含任何刚给定的清单中的字符时,更不能这么做。

如果在字段值内出现ENCLOSED BY字符,则通过使用ESCAPED BY字符作为前缀,对ENCLOSED BY字符进行转义。

MySQL远程访问设置终极方法 数据库对于服务端开发人员来说,几乎就是左膀右臂。几乎每一个服务端开发人员都要和数据库打交道。而MySQL又以其开源免费,小巧玲珑,简单易用,

mysql获取group by总记录行数的方法 本文实例讲述了mysql获取groupby总记录行数的方法,分享给大家供大家参考。具体方法分析如下:一般来说,mysql获取groupby内部可以获取到某字段的记录

mysql设置指定ip远程访问连接实例 本文实例讲述了mysql设置指定ip远程访问连接的方法,分享给大家供大家参考。具体实现方法如下:1.授权用户root使用密码gimoo从任意主机连接到mysql服务

标签: mysql load local

本文链接地址:https://www.jiuchutong.com/biancheng/321342.html 转载请保留说明!

上一篇:mysql insert语句操作实例讲解

下一篇:MySQL远程访问设置终极方法(mysql开启远程访问权限)

  • 子公司把利润给母公司怎么做账
  • 税收实体法和程序法分类
  • 参加会议培训的好处
  • 车间购买灯会计怎么做账
  • 贴现利息支付方式
  • 出口退税金额和进项税额不一致
  • 工程发票的备注栏
  • 学校有没有纳税人识别号
  • 教育咨询发票怎么开具
  • 进项发票里的印花税如何做账?
  • 应收账款负数可以调到哪个科目
  • 公司培训餐费计入什么费用
  • 超市库存商品分为哪几类
  • 下列各项支出中,允许用现金支付的有
  • 企业支付微信认证怎么弄
  • 如何在excel中链接图片对方能显示
  • 三证合一后的税务登记证查询方法
  • 360tray.exe损坏文件怎么修复
  • win11测试版和正式版区别
  • php源码怎么上传到服务器
  • win10桌面图标怎么随意摆放
  • 盘点的原则包括
  • 筹建期间发生的开办费属于什么费用
  • mediacache是什么文件夹
  • 置换土地如何做账务处理
  • 存货怎么预估
  • 其他应付款转营业外收入摘要
  • 旅游企业会计ppt
  • vue跳转到外部链接且带上参数
  • uniapp相关面试题
  • js设置input值
  • 补发工资怎么做账
  • 上市公司分红派股
  • 在筹建期间发生的开办费
  • 深度学习中的注意力机制模型及代码实现(SE Attention、CBAM Attention)
  • 税务局什么情况下可以停供发票
  • 程序员后续发展
  • 外包食堂可以开专票吗
  • 研发费用资本化计入什么科目
  • vue注册用户名和密码
  • 将自产产品用于建造厂房
  • 购买商标入账
  • 手机银行对公账户转账要手续费吗
  • 主营业务成本结转本年利润会计分录
  • 其他应收款增加现金流量表怎么填
  • MYSQL数据库技术基础
  • 银行存款期初余额调整会计分录
  • 开发成本期末有余额吗
  • 会计账簿登记错误
  • 银行电子承兑到期后怎么操作
  • 进口代理费取费标准
  • 退回多交的所得税抵欠税怎么做账
  • 购买原材料无法准确划分用途的进项税额怎么抵扣
  • 支付行业培训流程
  • 间接费用的分配公式
  • 购买超市购物卡有优惠吗
  • win10简单版
  • Windows Server 2008如何设置自动获取ip?设置自动获取ip教程
  • windowsxp关闭窗口操作方法有哪些
  • pcs system
  • win7任务管理器怎么打开
  • 苹果mac系统怎么用
  • linux系统中的文件
  • apache zipfile
  • android滑动选择
  • unity shader cull off
  • 搭建安卓开发环境必须的工具
  • python的判断
  • vue自定义过滤器的语法
  • Node.js中的什么模块是用于处理文件和目录的
  • angular卸载
  • 异步任务管理器
  • 防止shell脚本重复执行
  • 手机android版本强制升级
  • python源码分析工具
  • 税务局的经济类型
  • 文化事业建设税减免政策2023
  • 财政短信是什么意思
  • 智能财税证书含金量
  • 抄税失败是怎么回事
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设