mysql列宽设置,mysql – 从.csv文件确定最佳列宽

我想将.CSV文件导入MySQL表.我想根据CSV文件中包含的实际数据确定要使用的最佳列宽.是否有任何脚本或实用程序来完成此任务?

解决方法:

如果可能,最好避免尝试猜测适当的列长度 – 如果您可以获取CSV的来源以更详细地指定预期的格式(列X将包含不超过Y个字符),那么尝试一下.

我建议最初使用长可变长度类型 – 这可能比更多约束类型效率更低但是如果某些字段比预期更大,则会确保您不会在以后的导入中出错(或者更糟糕的是,由于mysql默默地截断某些字段而无法丢失数据).在这种情况下,MSSQL文本字段需要是nvarchar(max)或varchar(max),除非它们需要成为索引的一部分,在这种情况下它们需要更多约束(没有索引可以超过900) MSSQL下的数据字节).除非你能从源头获得更多数据格式,这是最安全的方式,当然你可以使用一些猜测(例如,包含国家保险号的字段不应超过11个字符,但是小心,因为字段可能被错误地命名为nad /或重载以存储除了其名称之外的其他内容.

如果你真的别无选择,只能猜测并且使用较大的类型对你来说效率太低,那么为了帮助guestimating过程将你所拥有的文件导入到一个表中,其中所有字段都是最大长度可变文本类型,然后执行一些粗鲁的分析例如SELECT MAX(LEN(< field1>)),MAX(LEN(< field2>))FROM< table>得到基于猜测的指示,对于非字符串字段,您可以使用更复杂的模式匹配来确定预期范围(即字段X始终是ISO格式的数据,字段Y是介于-500和45,123之间的数字,以及小数点后两位,等等.

关于“最优”:虽然使用较大固定长度的较大可变长度类型可能效率较低,但效率和最佳效果并不一定相同:如果您遇到错误或丢失数据,那么效率会很低意外地将类型设置得过于严格.

标签:mysql,import,datatypes

来源: https://codeday.me/bug/20190806/1595095.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值