第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

MySQL從CSV數(shù)據(jù)加載NULL值

MySQL從CSV數(shù)據(jù)加載NULL值

MySQL從CSV數(shù)據(jù)加載NULL值我有一個(gè)文件,可以包含3到4列數(shù)字,用逗號(hào)分隔。當(dāng)空字段位于行的末尾時(shí),將定義空字段:1,2,3,4,51,2,3,,51,2,3下表是在MySQL中創(chuàng)建的:+ ------- + -------- + ------ + ------ + --------- + ------- +| 領(lǐng)域| 輸入| 空| 鑰匙| 默認(rèn)| 額外的|+ ------- + -------- + ------ + ------ + --------- + ------- +| 一個(gè)| int(1)| 是的| | NULL | || 兩個(gè)| int(1)| 是的| | NULL | || 三個(gè)| int(1)| 是的| | NULL | || 四個(gè)| int(1)| 是的| | NULL | || 五| int(1)| 是的| | NULL | |+ ------- + -------- + ------ + ------ + --------- + ------- +我正在嘗試使用MySQL LOAD命令加載數(shù)據(jù):LOAD DATA INFILE '/tmp/testdata.txt' INTO TABLE moo FIELDS TERMINATED BY "," LINES TERMINATED BY "\n";結(jié)果表:+ ------ + ------ + ------- + ------ + ------ +| 一個(gè)| 兩個(gè)| 三個(gè)| 四個(gè)| 五|+ ------ + ------ + ------- + ------ + ------ +| 1 | 2 | 3 | 4 | 5 || 1 | 2 | 3 | 0 | 5 || 1 | 2 | 3 | NULL | NULL |+ ------ + ------ + ------- + ------ + ------ +問(wèn)題在于,當(dāng)原始數(shù)據(jù)中的字段為空且未定義時(shí),MySQL由于某種原因不使用列默認(rèn)值(即NULL)并使用零。當(dāng)字段完全丟失時(shí),正確使用NULL。不幸的是,我必須能夠在這個(gè)階段區(qū)分NULL和0,所以任何幫助將不勝感激。謝謝S.編輯SHOW WARNINGS的輸出:+ --------- + ------ + -------------------------------- ------------------------ +| 等級(jí)| 代碼| 消息|+ --------- + ------ + -------------------------------- ------------------------ +| 警告| 1366 | 不正確的整數(shù)值:''對(duì)于第2行的第4列'| 警告| 1261 | 第3行不包含所有列的數(shù)據(jù)| 警告| 1261 | 第3行不包含所有列的數(shù)據(jù)+ --------- + ------ + -------------------------------- ------------------------ +
查看完整描述

3 回答

?
largeQ

TA貢獻(xiàn)2039條經(jīng)驗(yàn) 獲得超8個(gè)贊

這將做你想要的。它將第四個(gè)字段讀入局部變量,然后將實(shí)際字段值設(shè)置為NULL,如果局部變量最終包含空字符串:


LOAD DATA infile '/tmp/testdata.txt'

INTO TABLE moo

fields terminated BY ","

lines terminated BY "\n"

(one, two, three, @vfour, five)

SET four = nullif(@vfour,'')

;

如果它們都可能是空的,那么你將它們?nèi)孔x入變量并有多個(gè)SET語(yǔ)句,如下所示:


LOAD DATA infile '/tmp/testdata.txt'

INTO TABLE moo

fields terminated BY ","

lines terminated BY "\n"

(@vone, @vtwo, @vthree, @vfour, @vfive)

SET

one = nullif(@vone,''),

two = nullif(@vtwo,''),

three = nullif(@vthree,''),

four = nullif(@vfour,'')

;


查看完整回答
反對(duì) 回復(fù) 2019-07-26
?
吃雞游戲

TA貢獻(xiàn)1829條經(jīng)驗(yàn) 獲得超7個(gè)贊

MySQL手冊(cè)說(shuō):

使用LOAD DATA INFILE讀取數(shù)據(jù)時(shí),使用''更新空列或缺少列。如果要在列中使用NULL值,則應(yīng)在數(shù)據(jù)文件中使用\ N. 在某些情況下也可以使用文字“NULL”。

所以你需要用\ N替換空白像這樣:

1,2,3,4,51,2,3,\N,51,2,3


查看完整回答
反對(duì) 回復(fù) 2019-07-26
?
達(dá)令說(shuō)

TA貢獻(xiàn)1821條經(jīng)驗(yàn) 獲得超6個(gè)贊

根據(jù)數(shù)據(jù)庫(kù)配置,行為會(huì)有所不同。在嚴(yán)格模式下,這會(huì)拋出錯(cuò)誤,否則會(huì)發(fā)出警告。以下查詢可用于標(biāo)識(shí)數(shù)據(jù)庫(kù)配置。

mysql> show variables like 'sql_mode';


查看完整回答
反對(duì) 回復(fù) 2019-07-26
  • 3 回答
  • 0 關(guān)注
  • 1119 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)