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自定义控件实现温度旋转按钮效果

