关于Mysql数据库中数据输入问题

关于数据库中数据输入问题

-------------------SELECT ... INTOOUTFILE 的 LOAD DATA INFILE 的逆操作问题.

一般我们都用insert into table_name values();来给数据表添加记录.这是一种方法. 当然也可以使用mysqlimport实用程序装载数据文件.其实它也是发送local data infile命令到服务器

而在输入大量数据的时候 ,我们可以用load data infile 语法来实现.

之前,我们需要先编辑一个文本文件.录入我们的数据.

load data infile的语法如下:

LOAD DATA [LOW_PRIORITY | CONCURRENT] [LOCAL] INFILE 'file_name.txt' [REPLACE | IGNORE] INTO TABLE tbl_name
[FIELDS
[TERMINATED BY '\t'] ('\t'为制表符)
[[OPTIONALLY] ENCLOSED BY ''] 说明不包括在任何字符里面.
[ESCAPED BY '\\' ] 表明无转义字符
]
[LINES TERMINATED BY '\n'] 这也是它的缺省状态了
[IGNORE number LINES]
[(col_name,...)]

注:local关键字没有被指定的时候 ,文件必须在服务器上.而local被指定时,则可以从客户端读取文件.(在 MySQL 3.23.49 和 MySQL 4.0.2 中,只有当你没有以 --local-infile=0 选项启动 mysqld,或你没有禁止你的客户端程序支持 LOCAL的情况下,LOCAL 才会工作,先于 MySQL 3.23.24 的版本,不能够以 LOAD DATA INFILE 读取)

如果是在服务上读取的时候,则我们需要知道下面三个问题:

1,若以相对路径的形式给出,如"./*.txt",则这个目录是相对服务器的数据目录.

2,若是"*.txt"则是从当前数据库目录下读取的文件.

3,则是完整路径.即绝对路径了!

下面的fields子句,一开始录入的时候,总是报错.是因为我对fields可选项不清晰的理解问题, 其中的terminated by char 指定一个字符,标记分隔列.而enclosed

by char 则指示列值被什么字符所包含.最后的escaped by char则表示用于转义特殊字符的转义符.我第一次录入时,错误的原因是因为不清楚它们三个的缺省状况.上面的语法部分列出的就是它们的缺省状况.见上.

另外当你同时输出文件与读取记录时,即用SELECT ... INTO OUTFILELOAD DATA INFILE 和 LOAD DATA INFILE 时,必须注意两个命令的字段和行处理选项必须匹配.

可能会遇到的问题如下:

data truncation: data truncated for column 'id' at row 3

这种问题是在你没有搞清mysql数据类型的前提下会发生的一种情况,建议基础不好的先看一下sql语言的数据类型.搞清之后就不会发生truncation(断开)问题了。

时间: 2024-11-17 06:44:48

关于Mysql数据库中数据输入问题的相关文章

php 显示mysql数据库中数据

<?php //连接数据库 $link_id = mysql_connect("localhost","root","") or die("连接失败"); if($link_id) {  //选择数据库  mysql_select_db("my_test");  //以上为头部数据库连接部分,为以下公用的部分.  if(!$_GET[id]){   //显示用户列表   $sql = "se

如何在Java程序中访问mysql数据库中的数据并进行简单的操作_Mysql

在上篇文章给大家介绍了Myeclipse连接mysql数据库的方法,通过本文给大家介绍如何在Java程序中访问mysql数据库中的数据并进行简单的操作,具体详情请看下文. 创建一个javaProject,并输入如下java代码: package link; import java.sql.*; /** * 使用JDBC连接数据库MySQL的过程 * DataBase:fuck, table:person: * 使用myeclipse对mysql数据库进行增删改查的基本操作. */ public

保护MySQL数据库中重要数据的注意事项

本文介绍了保护MySQL数据库中重要数据受外部攻击的六个注意事项,以减少面临的风险. 与自动的数据库备份不同,对系统管理员来说,保护数据免受未授权用户的侵犯需要采取一定的行动.如果你用的是MySQL,就可以使用一些方便的功能来保护系统,来大大减少机密数据被未授权用户访问的风险. 企业最有价值的资产通常是其数据库中的客户或产品信息.因此,在这些企业中,数据库管理的一个重要部分就是保护这些数据免受外部攻击,及修复软/硬件故障. 在大多数情况下,软硬件故障通过数据备份机制来处理.多数数据库都自带有内置

MySQL数据库中部分数据损坏恢复过程

前几天因为MySQL数据库部分数据损坏原因,我尝试了下恢复数据,之后整理以下文档,供各位参考,以备各位同事以后如有类似问题,可以少走些弯路,尽快解决问题. 环境:Windows2003 数据库:MySQL 损坏数据文件名:function_products 将数据库内容物理文件直接导入到mysql\data下,每只表各3个文件,依次分别为:.frm .myd .myi.首先我第一想到的是去网上搜索,寻找类似的工具,试图通过工具来恢复已损坏的文件,于是我在google上查找,找到一款名为mysql

Android开发中怎样调用mysql数据库中的数据

问题描述 Android开发中怎样调用mysql数据库中的数据 Android开发中怎样调用mysql数据库中的数据,数据库可以是本地也可以是联网的. 解决方案 Android本地是不能直接调用MySQL的,因为很简单,你的Android手机上面不可能安装MySQL服务的.你只能借助于网络通信, 让手机和电脑通过网络连接起来,这样你想在Android端访问MySQL数据库时,就可以通过一定的方式发送一些网络消息请求, 让电脑端去查询数据库,再通过网络把数据返回给Android端.当然,最简单的网

jsp-java 中JSP 实现把excel表中数据导入到mysql数据库中的表中的具体实现方法

问题描述 java 中JSP 实现把excel表中数据导入到mysql数据库中的表中的具体实现方法 java 中JSP 实现把excel表中数据导入到mysql数据库中的表中的具体实现方法 解决方案 参考:http://blog.csdn.net/casilin/article/details/5750773 解决方案二: 楼主幸苦了!!谢谢分享!!! 解决方案三: jsp导excel到mysql数据库 http://wenku.it168.com/d_000468232.shtml

hbase-如何将mysql数据库中的数据存到hadoop上

问题描述 如何将mysql数据库中的数据存到hadoop上 求助如何将mysql数据库中的数据存到hadoop上,又如何进行查询? 解决方案 http://www.2cto.com/database/201412/359232.html 解决方案二: http://www.iteye.com/news/27625 解决方案三: 可以使用Kettle Spoon对数据进行抽取和转移,是图形化界面,可以支持几乎所有的数据库,包括关系型数据库Oracle.MySQL和非关系型数据库HBase等,也支持

怎么把jsoup抓取到的网页数据放进mysql数据库中,跪大神求详细代码。

问题描述 怎么把jsoup抓取到的网页数据放进mysql数据库中,跪大神求详细代码. package bag; import java.io.IOException; import org.jsoup.Connection; import org.jsoup.Jsoup; import org.jsoup.nodes.Document; import org.jsoup.nodes.Element; import org.jsoup.select.Elements; public class T

使用commandbuilder修改datagridview数据然后更新到mysql数据库中遇到问题

问题描述 使用commandbuilder修改datagridview数据然后更新到mysql数据库中遇到问题 网上说使用commandbuilder需要先设置表的主键?这个有关系? 解决方案 就是因为没有主键.没有主键,当你修改datagridview一条记录的时候,凭什么知道你修改的是数据库中的哪一条呢? 解决方案二: 用修改DataGridView数据并更新数据库