項目需要批量導(dǎo)入excel文件,如果里面有重復(fù)的數(shù)據(jù)要怎么處理呢?每插入一次數(shù)據(jù)都要到數(shù)據(jù)庫查詢么?
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:域名注冊、網(wǎng)絡(luò)空間、營銷軟件、網(wǎng)站建設(shè)、麟游網(wǎng)站維護(hù)、網(wǎng)站推廣。
回復(fù)內(nèi)容:
項目需要批量導(dǎo)入excel文件,如果里面有重復(fù)的數(shù)據(jù)要怎么處理呢?每插入一次數(shù)據(jù)都要到數(shù)據(jù)庫查詢么?
1、如果里面有重復(fù)的數(shù)據(jù)要怎么處理呢?
1
code可以先判斷數(shù)據(jù)庫是否有該數(shù)據(jù)。/code
2、每插入一次數(shù)據(jù)都要到數(shù)據(jù)庫查詢么
1
code是的。/code
先去重得到?jīng)]有重復(fù)的數(shù)據(jù),再批量插入數(shù)據(jù)庫。也可以嘗試MYSQL中的insert ignore into或 replace into
如果查詢比較慢,對不能重復(fù)的字段加唯一鍵,然后用INSERT IGNORE INTO
php批量導(dǎo)入數(shù)據(jù)出錯
我現(xiàn)在要做的是,把一個產(chǎn)品數(shù)據(jù)從EXCEL中導(dǎo)入到PHP的MYSQL中,導(dǎo)入的過程中,總是會提示“Allowed memory size of 167772160 bytes exhausted (tried to allocate 689919 bytes) in D:\wamp\www\Company\product\admin\uploadOrder.php on line 167”這個錯誤,然后我分成第100條導(dǎo)入時,就不會提示這個錯誤,這個是不是內(nèi)存溢出,有沒有好的解決方法呢?
------解決方案--------------------
php.ini中講memory_limit選項設(shè)置大一點,然后重啟apache或nginx就行了
------解決方案--------------------
文件太大了,這樣的話可以用source命令直接導(dǎo)入!
------解決方案--------------------
源碼大還是數(shù)據(jù)庫的sql文件大,如果是限制了上傳文件大小,虛擬空間就要問問你的空間商怎么改,如果自己的服務(wù)器可以修改php.ini文件,默認(rèn)是2或者8m ,數(shù)據(jù)庫大其實這樣導(dǎo)入容易出錯,可以用帝國備份試試
修改PHP.ini
文件
修改最大上傳值,最大POST值,最大執(zhí)行超時時間值。
如果沒有辦法更改PHP.ini,把數(shù)據(jù)結(jié)構(gòu)和數(shù)據(jù)記錄分開,數(shù)據(jù)記錄文件,手動調(diào)整到2M
以內(nèi)
在使用PhpMyAdmin的時候經(jīng)常用到數(shù)據(jù)的導(dǎo)入和導(dǎo)出(Export/Import),但是在導(dǎo)入大數(shù)據(jù)的時候由于php上傳文件的限制和腳本響應(yīng)時間的限制,導(dǎo)致phpMyAdmin無法導(dǎo)入大數(shù)據(jù)。很多時候都是由于文件過大,從本地瀏覽上傳導(dǎo)入,容易中斷失敗,有沒有更好的方法呢?
方法:
在phpMyAdmin的目錄下,找到根目錄的config.inc.php文件,
打開config.inc.php文件,查找$cfg['UploadDir'],這個參數(shù)就是設(shè)定導(dǎo)入文件存放的目錄,這里把值設(shè)定為:ImportSQLFile。
在phpMyAdmin目錄下,建立以ImportSQLFile命名的文件夾,
把我們需要導(dǎo)入的數(shù)據(jù)文件,放到ImportSQLFile文件夾下面,非常簡單,
登入phpMyAdmin,選擇需要導(dǎo)入的數(shù)據(jù),點擊導(dǎo)航條上面的“導(dǎo)入”按鈕,
選中“從網(wǎng)站服務(wù)器上傳文件夾ImportSQLFile/中選擇:”選項,并需要導(dǎo)入的數(shù)據(jù)文件,
最后點擊“執(zhí)行”,即可導(dǎo)入成功。
注意事項
如果在config.inc.php文件,沒有找到$cfg['UploadDir'],可以自己在文件中添加上去即可。
1、首先我們準(zhǔn)備一個含有數(shù)據(jù)的Excel表格,表頭和數(shù)據(jù)表中的表字段相對應(yīng)。
2、在ThinkPHP中引入PHPExcel類庫。
3、然后我們編寫導(dǎo)入的PHP代碼。
4、然后我們編寫導(dǎo)出的PHP代碼。
5、然后我們進(jìn)行導(dǎo)出測試發(fā)現(xiàn)可以導(dǎo)出即可。