sqlite迁移到mysql脚本的方法

发布时间 - 2026-01-11 02:41:04    点击率:

废话不多说了,直接给大家贴代码了,具体代码如下所示:

#! /usr/bin/perl
#
# based on https://stackoverflow.com/a/87531/5742651
# usage: sqlite3 .dump database_name.sqlite3 | perl sqlite2mysql.pl | mysql -u root -p $import_database_name
#
# ignore follow lines:
#  BEGIN TRANSACTION 
#  COMMIT 
#  sqlite_sequence 
#  CREATE UNIQUE INDEX
#  PRAGMA foreign_keys=OFF
# "tablename/field" => `tablename/field`
# booleans 't' and 'f' => 1 and 0
# AUTOINCREMENT => AUTO_INCREMENT
# varchar => varchar(255)
# CREATE TABLE table... => DROP TABLE table; CREATE TABLE table...
# Merge insert sqls into multiple insert to speed up
#  INSERT INTO table VALUES('val1');
#  INSERT INTO table VALUES('val2');  => INSERT INTO table VALUES('val1'), ('val2'), ('val3');
#  INSERT INTO table VALUES('val3');
my $open=0;
my $line_cache = '';
# For speed up
print "SET GLOBAL max_allowed_packet=209715200;\n";
#print "SET AUTOCOMMIT=0;\n";
while ($line = <>){
  if (($line !~ /PRAGMA foreign_keys=OFF/) && ($line !~ /BEGIN TRANSACTION/) && ($line !~ /COMMIT/) && ($line !~ /sqlite_sequence/) && ($line !~ /CREATE UNIQUE INDEX/)){
   if ($line =~ /CREATE TABLE \"([a-z_0-9]*)\"(.*)/){
   $name = "\`$1\`";
   $sub = $2;
   $sub =~ s/varchar([^(])/varchar(255)$1/g;
   $line = "DROP TABLE IF EXISTS $name;\nCREATE TABLE $name$sub\n"; 
   }
   elsif ($line =~ /CREATE VIEW ([a-z_0-9]*)(.*)/){
   $name = "\`$1\`";
   $sub = $2;
   $line = "DROP VIEW IF EXISTS $name;\nCREATE VIEW $name$sub\n";
   }
   elsif ($line =~ /INSERT INTO \"([a-z_]*)\" VALUES(.*);/){
        if ($open == 0) {
          $open = 1;
       $line_cache .= "INSERT INTO \`$1\` VALUES $2";
        } else {
          $line_cache .= ", $2";
        }
        next;
   }else{
   $line =~ s/\'\'/\\\'/g;
   }
    if ($open == 1) {
       $open = 0;
       $line = $line_cache.";\n".$line;
       $line_cache = '';
    }
   $line =~ s/\"/`/g;
   $line =~ s/([^\\'])\'t\'(.)/$1THIS_IS_TRUE$2/g;
   $line =~ s/THIS_IS_TRUE/1/g;
   $line =~ s/([^\\'])\'f\'(.)/$1THIS_IS_FALSE$2/g;
   $line =~ s/THIS_IS_FALSE/0/g;
   $line =~ s/AUTOINCREMENT/AUTO_INCREMENT/g;
   print $line;
  }
}
#print "SET AUTOCOMMIT=1;\n";

总结

以上所述是小编给大家介绍的sqlite迁移到mysql脚本的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# sqlite迁移到mysql  # sqlite  # mysql  # SQLite 实现if not exist 类似功能的操作  # listview与SQLite结合实现记事本功能  # sQlite常用语句以及sQlite developer的使用与注册  # 微信使用 SQLite 保存聊天记录的原因分析  # 给大家  # 小编  # 在此  # 说了  # 不多  # 所示  # 所述  # 给我留言  # 感谢大家  # 疑问请  # 有任何  # lines  # follow  # COMMIT  # TRANSACTION  # ignore  # pl  # import_database_name  # root 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Windows11怎样设置电源计划_Windows11电源计划调整攻略【指南】  如何在建站宝盒中设置产品搜索功能?  php 三元运算符实例详细介绍  Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】  Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)  如何快速使用云服务器搭建个人网站?  如何获取免费开源的自助建站系统源码?  Laravel API资源类怎么用_Laravel API Resource数据转换  如何用AI一键生成爆款短视频文案?小红书AI文案写作指令【教程】  Python3.6正式版新特性预览  Laravel Pest测试框架怎么用_从PHPUnit转向Pest的Laravel测试教程  html如何与html链接_实现多个HTML页面互相链接【互相】  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  如何在腾讯云服务器快速搭建个人网站?  VIVO手机上del键无效OnKeyListener不响应的原因及解决方法  Laravel如何连接多个数据库_Laravel多数据库连接配置与切换教程  Win11怎样安装网易有道词典_Win11安装词典教程【步骤】  Laravel的契約(Contracts)是什么_深入理解Laravel Contracts与依赖倒置  Laravel如何使用Passport实现OAuth2?(完整配置步骤)  Laravel队列由Redis驱动怎么配置_Laravel Redis队列使用教程  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  html5如何设置样式_HTML5样式设置方法与CSS应用技巧【教程】  Laravel如何实现用户密码重置功能?(完整流程代码)  如何做网站制作流程,*游戏网站怎么搭建?  JavaScript如何实现倒计时_时间函数如何精确控制  如何在Windows 2008云服务器安全搭建网站?  高配服务器限时抢购:企业级配置与回收服务一站式优惠方案  Laravel用户认证怎么做_Laravel Breeze脚手架快速实现登录注册功能  如何快速搭建高效服务器建站系统?  DeepSeek是免费使用的吗 DeepSeek收费模式与Pro版本功能详解  Javascript中的事件循环是如何工作的_如何利用Javascript事件循环优化异步代码?  Edge浏览器如何截图和滚动截图_微软Edge网页捕获功能使用教程【技巧】  香港服务器选型指南:免备案配置与高效建站方案解析  Laravel的辅助函数有哪些_Laravel常用Helpers函数提高开发效率  怎么用AI帮你为初创公司进行市场定位分析?  打开php文件提示内存不足_怎么调整php内存限制【解决方案】  如何快速搭建虚拟主机网站?新手必看指南  Midjourney怎么调整光影效果_Midjourney光影调整方法【指南】  Edge浏览器提示“由你的组织管理”怎么解决_去除浏览器托管提示【修复】  INTERNET浏览器怎样恢复关闭标签页_INTERNET浏览器标签恢复快捷键与方法【指南】  如何用景安虚拟主机手机版绑定域名建站?  微信公众帐号开发教程之图文消息全攻略  Laravel如何使用Scope本地作用域_Laravel模型常用查询逻辑封装技巧【手册】  猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?  标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南  如何正确下载安装西数主机建站助手?  iOS正则表达式验证手机号、邮箱、身份证号等  详解CentOS6.5 安装 MySQL5.1.71的方法  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  Android自定义控件实现温度旋转按钮效果