好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識(shí)庫 > sqlite3遷移mysql可能遇到的問題集合

sqlite3遷移mysql可能遇到的問題集合

熱門標(biāo)簽:真人語音電話機(jī)器人 怎么在地圖標(biāo)注位置生成圖片 騰訊地圖標(biāo)注提升 電銷卡外呼系統(tǒng)供應(yīng)商 美國反騷擾電話機(jī)器人 銅陵防封電銷卡 悟空科技電話機(jī)器人 福建外呼系統(tǒng)定制化 400電話可以免費(fèi)申請(qǐng)嗎

簡述

適合閱讀對(duì)象:移動(dòng)開發(fā)

sqlite3數(shù)據(jù)遷移到mysql會(huì)遇到許多語法問題,想要一下列出所有問題會(huì)力所不及,本文會(huì)盡量多的列出可能會(huì)遇到的問題,因?yàn)槊總€(gè)人遇到的問題都不一樣。讀者根據(jù)此文可以提前預(yù)知是否有自己會(huì)面臨到的問題,做到心中有數(shù)才能避免或減少遷移數(shù)據(jù)后會(huì)發(fā)生意料之外的問題。根據(jù)問題列表可以了解自己需要解決哪些問題,我這里同時(shí)會(huì)給出一個(gè)解決方案供大家參考。遷移這個(gè)問題不會(huì)有一個(gè)萬能的方案的,因?yàn)槊總€(gè)人遇到的問題不同,如果一些互相沖突的問題同時(shí)存在解決方案中反而就變成了一個(gè)問題。

好了,開門見山!

問題列表

1、sqlite3 dump出的各種變量在mysql不識(shí)別,如(BEGIN TRANSACTION、COMMIT等等)

2、sqlite數(shù)據(jù)庫數(shù)據(jù)無法導(dǎo)出隱藏字段rowid

3、sqlite數(shù)據(jù)庫數(shù)據(jù)導(dǎo)出格式與其他數(shù)據(jù)庫不兼容,如單引號(hào)、雙引號(hào)問題

4、導(dǎo)出的sqlite數(shù)據(jù)不帶列名,如下 INSERT INTO protocol VALUES('大類頁(新)', ' ') 。我們可能需要的是 INSERT INTO protocol('text1','text2') VALUES('大類頁(新)', '刷新頁')

5、特殊符號(hào)處理,如轉(zhuǎn)義符 "\"

6、表字段長度限制不一樣

7、數(shù)據(jù)量寫入效率問題

問題解決

首先不能使用sqliteStudio、Navicat等工具,這里采用shell命令的方式,直接避免一下內(nèi)容生成,

    BEGIN TRANSACTION

    COMMIT

    CREATE UNIQUE INDEX

    PRAGMA foreign_keys=OFF

同時(shí)使用shell方式可以用很少的代碼量實(shí)現(xiàn)。

1、解決字段列名沒有輸出問題

    運(yùn)行sqlite3命令“ pragma table_info(表名); “得到以下輸出內(nèi)容

    0|name|TEXT|0||0

    1|description|TEXT|0||0

    再通過字符串替換得到列名,如下:

    假設(shè)變量為 COLS = name,description

2、解決單引號(hào)、雙引號(hào)問題

    運(yùn)行sqlite3命令“  .mode insert .dump 表名“得到如下輸出內(nèi)容

    INSERT INTO表名VALUES('test',' test');

    INSERT INTO表名VALUES('test','test');

    INSERT INTO表名VALUES('test','test');

    以這種方式可以解決單引號(hào)雙引號(hào)問題,這里直接統(tǒng)一輸出單引號(hào)

3、解決sqlite3默認(rèn)字段rowid無法顯示問題,這里直接將rowid改為id

    將當(dāng)前模式設(shè)置為.dump insert 模式

    運(yùn)行sqlite3命令“ select rowid as id,$COLS from 表名“得到如下輸出

    INSERT INTO表名VALUES(1,'test',' test');

    INSERT INTO表名VALUES(2,'test','test');

    INSERT INTO表名VALUES(3,'test','test');

4、通過shell字符串命令,將之前得到的列名添加到以下sql語句

修改后如下:

    INSERT INTO表名('name',' description')VALUES(1,'test',' test');

    INSERT INTO表名('name',' description')VALUES(2,'test','test');

    INSERT INTO表名('name',' description')VALUES(3,'test','test');

5、轉(zhuǎn)義符處理

如果數(shù)據(jù)庫里的數(shù)據(jù)存在轉(zhuǎn)義符,如: {\"lastname\":\\"天津\\"} 。這種數(shù)據(jù)如果不處理,那么將數(shù)據(jù)insert到數(shù)據(jù)庫時(shí)會(huì)變成{"lastname":\"天津\"} 。所以需要對(duì)轉(zhuǎn)義符做下處理,用shell命令處理很簡單,如命令:sed 's#\\#\\\\#g'
方案實(shí)現(xiàn)

此腳本主要解決了以上1~5問題,根據(jù)需要可以對(duì)腳本進(jìn)行修改

 #!/bin/sh
 SQLITE=sqlite3
 if [ -z "$1" ] ; then
   echo usage: $0 sqlite3.db
   exit
 fi
 DB="$1"
 TABLES=`"$SQLITE" "$DB" .tables`
 for TABLE in $TABLES ; do
   CREATE=`"$SQLITE" "$DB" "SELECT sql FROM sqlite_master WHERE type=\"table\" AND name = \"$TABLE\";"`
   echo $CREATE";" |
   cut -d'=' -f2 |
   sed "s/^CREATE TABLE $TABLE (/CREATE TABLE $TABLE (id int auto_increment primary key ,/g"
   COLS=`"$SQLITE" "$DB" "pragma table_info($TABLE)" | cut -d'|' -f2 `
   COLS_CS=`echo $COLS | sed 's/ /,/g'`
   echo ".mode insert \n.header on \n select rowid as id,$COLS_CS from $TABLE;\n" |
   "$SQLITE" "$DB" |
   sed "s/^INSERT INTO \"table\"/INSERT INTO $TABLE /g" |
   sed 's#\\#\\\\#g'
 done

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。

您可能感興趣的文章:
  • 將 Ghost 從 SQLite3 數(shù)據(jù)庫遷移到 MySQL 數(shù)據(jù)庫

標(biāo)簽:云浮 聊城 烏海 臨汾 武威 白銀 湖南 湖北

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《sqlite3遷移mysql可能遇到的問題集合》,本文關(guān)鍵詞  sqlite3,遷移,mysql,可能,遇到,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《sqlite3遷移mysql可能遇到的問題集合》相關(guān)的同類信息!
  • 本頁收集關(guān)于sqlite3遷移mysql可能遇到的問題集合的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 成年男人露蛋无遮挡| 中文字幕精品一区人妻| 欧美bbwbbwbbwxxxx免费| 国产91刺激对白在线播放| 久久只这里是精品66| gaysexxx| 欧美日韩亚洲精品瑜伽裤 | 色01视频| 色夜夜摸狠狠摸日日视频 | 伊人成色综合人夜夜久久| 男女在床羞羞的免费视频| 穿成小奶娃各种做肉高h| 刘晓庆把奶罩脱了让人摸| 美女胸又www又黄的网站视频 | 色欲久久久天天综合网精品88| 大乳尤物冰露| 日本欧美大码a在线视频播放| 亚洲天堂在线视频观看| 人蛇狂欢高h文女主婉清| 国产AV在线播| 精品国产福利第一区二区三区| 黄app免费下载| 把老公撩硬的表情包图片| 91久久精品日日躁夜夜躁欧美 | 韩国免费一级a一片在线播放| 国产精品??????可站| 越南一级片| 公车调教香艳调教| 114毛片| 国产精品久久久久久久久九色| 一级二级调色大片区别在什么方面| 性,国产三级在线| 野生po糙汉| AV国産精品毛片一区二区| 国产又粗又硬又长又爽的演员| 亚洲第十色| 欧美第一区| 日本无码亚洲精品无码网站老牛| 我把护士日出了水| 24小时日本影院www| 521国产精品视频|