国产成人精品18p,天天干成人网,无码专区狠狠躁天天躁,美女脱精光隐私扒开免费观看

sqlite3遷移mysql可能遇到的問(wèn)題有哪些

發(fā)布時(shí)間:2021-08-08 19:37 來(lái)源:億速云 閱讀:0 作者:小新 欄目: Mysql 歡迎投稿:712375056

小編給大家分享一下sqlite3遷移可能遇到的問(wèn)題有哪些,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

問(wèn)題列表

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

2、sqlite數據數據無(wú)法導出隱藏字段rowid

3、sqlite數據庫數據導出格式與其他數據庫不兼容,如單引號、雙引號問(wèn)題

4、導出的sqlite數據不帶列名,如下 INSERT INTO protocol VALUES('大類(lèi)頁(yè)(新)', ' ') 。我們可能需要的是 INSERT INTO protocol('text1','text2') VALUES('大類(lèi)頁(yè)(新)', '刷新頁(yè)')

5、特殊符號處理,如轉義符 "\"

6、表字段長(cháng)度限制不一樣

7、數據量寫(xiě)入效率問(wèn)題

問(wèn)題解決

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

    BEGIN TRANSACTION

    COMMIT

    CREATE UNIQUE INDEX

    PRAGMA foreign_keys=OFF

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

1、解決字段列名沒(méi)有輸出問(wèn)題

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

    0|name|TEXT|0||0

    1|description|TEXT|0||0

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

    假設變量為 COLS = name,description

2、解決單引號、雙引號問(wèn)題

    運行sqlite3命令“  .mode insert && .dump 表名“得到如下輸出內容

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

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

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

    以這種方式可以解決單引號雙引號問(wèn)題,這里直接統一輸出單引號

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

    將當前模式設置為.dump insert 模式

    運行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、通過(guò)shell字符串命令,將之前得到的列名添加到以下sql語(yǔ)句

修改后如下:

    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、轉義符處理

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

此腳本主要解決了以上1~5問(wèn)題,根據需要可以對腳本進(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

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。

成A人片亚洲日本久久| 国产无遮挡无码视频免费软件| 把女的下面扒开添视频| 亚洲国产精品无码久久九九大片| 色久悠悠婷婷综合在线亚洲| 久久天天躁夜夜躁狠狠躁2022|