SlideShare a Scribd company logo
Drupal database Mssql
to MySQL migration
Anton Ivanov
Customer choice

Nginx + MySQL + PHP

or

IIS + Mssql + PHP

??
What we need first

Working Mssql server

&

Working MySQL server
Mssql server on Linux

Docker container

or

Local installation
Installation process

Go to Microsoft site

Use HowTo

Command line tools

Test site …
But site not works :(

SQLSTATE[HY010]: [unixODBC]
[Driver Manager] Function sequence
error: …
But site not works :(

SQLSTATE[HY010]: [unixODBC]
[Driver Manager] Function sequence
error: …

Because PHP driver not stable
Use Windows, Luke

Machine with Windows or VM:
οƒ˜
Mssql Server Express
οƒ˜
SQL Server Management Studio SSMS
οƒ˜
WAMP + Fresh sqlsrv drivers
οƒ˜
Comment wincache_*() calls
Converting database

2 separated ways available:
οƒ˜
for Drupal 7
οƒ˜
for Drupal 8
MySQL Workbench

Simple multistep form

Result: Converted database

But not works with Drupal 7
(unserialization error)
DBTNG Migrator

Simple module
(Schema API + DBTNG)

Actual Schema in code

Result: Converted database

But not works with Drupal 8
(no Drupal 8 version)
Conclusion

Drupal 7:
οƒ˜
DBTNG Migrator

Drupal 8:
οƒ˜
??
Conclusion

Drupal 7:
οƒ˜
DBTNG Migrator

Drupal 8:
οƒ˜
MySQL Workbench
Helpful info
Tricks

SQL Server authentication
(don't use Windows authentication)

use Adminer
(to test connection and structure)

in Drupal 7 comment wincache_*()
(/includes/database/sqlsrv/database.inc)
Importing dump with sqlcmd

sqlcmd -H localhost -U SA

RESTORE FILELISTONLY FROM DISK = '/path/to/dump.bak'
οƒ˜
Drupal_Data01 ... H:PROD_DATADrupal_Site_Data01.mdf
οƒ˜
Drupal_Data02 ... H:PROD_DATADrupal_Site_Data02.ndf
οƒ˜
Drupal_TLog01 ... J:PROD_LOGDrupal_Site_TLog01.ldf

RESTORE DATABASE Drupal_Site FROM DISK='/path/to/dump.bak'
WITH MOVE 'Drupal_Data01' to '/var/opt/mssql/data/drupal_data01.mdf',
MOVE 'Drupal_Data02' to '/var/opt/mssql/data/drupal_data02.ndf',
MOVE 'Drupal_TLog01' to '/var/opt/mssql/data/drupal_tlog01.ldf'
GO
Useful links, Linux
Download Mssql server :
https://www.microsoft.com/en-us/sql-server/sql-server-2017#resource
SQL Server command-line tools :
https://docs.microsoft.com/en-us/sql/linux/sql-server-linux-setup-tools
Mssql backup and restore db :
https://docs.microsoft.com/en-us/sql/linux/sql-server-linux-backup-an
Mssql PHP driver for Linux :
https://github.com/Microsoft/msphpsql
Useful links, Windows
Download Mssql server Express edition :
https://www.microsoft.com/en-us/sql-server/sql-server-editions-expres
Download SQL Server Management Studio (SSMS) :
https://docs.microsoft.com/en-us/sql/ssms/download-sql-server-manag
Restore database from dump with SSMS :
https://www.howtogeek.com/50354/restoring-a-sql-database-backup-u
Mssql PHP driver for Windows :
https://github.com/Microsoft/msphpsql
(php_pdo_sqlsrv_7_ts.dll, php_sqlsrv_7_ts.dll)
Useful links, Tools
DBTNG Migrator : https://www.drupal.org/project/dbtng_migrator
Download MySQL Workbench :
https://dev.mysql.com/downloads/workbench
Migrate with MySQL Workbench :
http://mysqlworkbench.org/2012/07/migrating-fro
Thank you! Questions?
Anton Ivanov

More Related Content

PPT
Headless drupal + react js Oleksandr Linyvyi
ODP
Drupal database Mssql to MySQL migration
PPTX
Learn AJAX at ASIT
Β 
PPTX
The hitchhiker's guide to the Webpack - Sara Vieira - Codemotion Amsterdam 2017
PDF
React Lifecycle and Reconciliation
PPTX
Getting Reactive with Cycle.js and xstream
PDF
React redux
PPTX
Powershell For Developers
Headless drupal + react js Oleksandr Linyvyi
Drupal database Mssql to MySQL migration
Learn AJAX at ASIT
Β 
The hitchhiker's guide to the Webpack - Sara Vieira - Codemotion Amsterdam 2017
React Lifecycle and Reconciliation
Getting Reactive with Cycle.js and xstream
React redux
Powershell For Developers

What's hot (20)

PDF
Google App Engine Developer - Day4
PDF
React&redux
PPTX
001. Introduction about React
PPTX
Mule esb db_2
PDF
A quick tour of Mysql 8 roles
PPT
9\9 SSIS 2008R2_Training - Package Reliability and Package Execution
PPTX
Ajax ppt - 32 slides
PDF
React + Redux for Web Developers
PPTX
MongoDB's New Aggregation framework
PDF
Workshop React.js
PPTX
Node js for enterprise
PDF
Intro to Scala.js - Scala UG Cologne
PPTX
Continuous DB Changes Delivery With Liquibase
PDF
Node.js Crash Course
KEY
20120514 nodejsdublin
PPTX
Grails and Ajax
PDF
Perl Tools for Productivity
PDF
Play Framework
PPTX
Scylla Summit 2018: What's New in Scylla Manager?
Google App Engine Developer - Day4
React&redux
001. Introduction about React
Mule esb db_2
A quick tour of Mysql 8 roles
9\9 SSIS 2008R2_Training - Package Reliability and Package Execution
Ajax ppt - 32 slides
React + Redux for Web Developers
MongoDB's New Aggregation framework
Workshop React.js
Node js for enterprise
Intro to Scala.js - Scala UG Cologne
Continuous DB Changes Delivery With Liquibase
Node.js Crash Course
20120514 nodejsdublin
Grails and Ajax
Perl Tools for Productivity
Play Framework
Scylla Summit 2018: What's New in Scylla Manager?
Ad

Similar to Mssql to mysql - Anton Ivanov (20)

PDF
Upgrading from WinS 2008/2008 R2 to WinS 2012
PDF
Deskpool making vdi cost effective for smb
PDF
07 automate windowsenvironmentswithansibleanddsc
PPTX
Upgrade, Migrate and Virtualisation with SharePoint 2010
PDF
Akmal Khaleeq Waheed - Challenge 3
Β 
PPTX
The future of ASP.NET / CodeCamp/Iasi 25 Oct 2014
PPTX
ASPNET-in-Production.pptx
Β 
PDF
Single page apps with drupal 7
PDF
Building a Headless Shop
PDF
Sprint 17
PPTX
Building production websites with Node.js on the Microsoft stack
PPTX
NodeJS & Socket IO on Microsoft Azure Cloud Web Sites - DWX 2014
PPT
SQL Server 2008 Integration Services
PDF
Future of Serverless
PPTX
Top 10 PowerShell Features in Server 2012
PDF
Windows Loves Drupal
Β 
PPT
Php Asp Net Interoperability Rc Jao
Β 
PPTX
Improve your Web Development using Visual Studio 2010
PPTX
ChinaNetCloud - Using Zabbix Monitoring at Scale - Zabbix Conference 2014
ODP
HTTP, JSON, JavaScript, Map&Reduce built-in to MySQL
Upgrading from WinS 2008/2008 R2 to WinS 2012
Deskpool making vdi cost effective for smb
07 automate windowsenvironmentswithansibleanddsc
Upgrade, Migrate and Virtualisation with SharePoint 2010
Akmal Khaleeq Waheed - Challenge 3
Β 
The future of ASP.NET / CodeCamp/Iasi 25 Oct 2014
ASPNET-in-Production.pptx
Β 
Single page apps with drupal 7
Building a Headless Shop
Sprint 17
Building production websites with Node.js on the Microsoft stack
NodeJS & Socket IO on Microsoft Azure Cloud Web Sites - DWX 2014
SQL Server 2008 Integration Services
Future of Serverless
Top 10 PowerShell Features in Server 2012
Windows Loves Drupal
Β 
Php Asp Net Interoperability Rc Jao
Β 
Improve your Web Development using Visual Studio 2010
ChinaNetCloud - Using Zabbix Monitoring at Scale - Zabbix Conference 2014
HTTP, JSON, JavaScript, Map&Reduce built-in to MySQL
Ad

More from DrupalCamp Kyiv (20)

PDF
Speed up the site building with Drupal's Bootstrap Layout Builder
PDF
Performance Monitoring with Google Lighthouse
PPTX
Oleg Bogut - Decoupled Drupal: how to build stable solution with JSON:API, Re...
PDF
Acquia BLT for the Win, or How to speed up the project setup, development an...
PDF
Upgrading to Drupal 9
PDF
THE INTERNET OF THINGS IS GETTING REAL
PDF
FRONT-END COMPONENTS IN DRUPAL THEME. "KAIZEN" - DRUPAL 8 THEME FROM SKILLD
PDF
DRUPAL AND ELASTICSEARCH
PDF
WHAT WE LEARNED FROM OPEN SOCIAL IN 3 YEARS, MOVING FROM AN AGENCY TO A PRODU...
PDF
Blackfire Workshop
PDF
DRUPAL 8 STORAGES OVERVIEW
PPTX
ONE MORE TIME ABOUT CODE STANDARDS AND BEST PRACTICES
DOCX
1-1 MEETING: STEP-BY-STEP-HOW-TO
PPTX
UX DURING MODULE INSTALLATION AND CONFIGURATION
PDF
SWITCHING FROM QA ENGINEER TO PROJECT MANAGER - LEVEL UP OR DOWN?
PDF
TECHNOLOGIES-POWERED WEB AND THE POST-BROWSER ERA
PPTX
PROTECTED CONTENT: END-TO-END PGP ENCRYPTION FOR DRUPAL
PDF
DRUPAL AUDITS MADE FASTR
PDF
FROM DISTRO TO CUSTOM - HOW WE CREATE GREAT COMMUNITIES FOR EVERY ORGANIZATIO...
PDF
SEARCH API: TIPS AND TRICKS - FROM BEGINNING TO CUSTOM SOLUTIONS
Speed up the site building with Drupal's Bootstrap Layout Builder
Performance Monitoring with Google Lighthouse
Oleg Bogut - Decoupled Drupal: how to build stable solution with JSON:API, Re...
Acquia BLT for the Win, or How to speed up the project setup, development an...
Upgrading to Drupal 9
THE INTERNET OF THINGS IS GETTING REAL
FRONT-END COMPONENTS IN DRUPAL THEME. "KAIZEN" - DRUPAL 8 THEME FROM SKILLD
DRUPAL AND ELASTICSEARCH
WHAT WE LEARNED FROM OPEN SOCIAL IN 3 YEARS, MOVING FROM AN AGENCY TO A PRODU...
Blackfire Workshop
DRUPAL 8 STORAGES OVERVIEW
ONE MORE TIME ABOUT CODE STANDARDS AND BEST PRACTICES
1-1 MEETING: STEP-BY-STEP-HOW-TO
UX DURING MODULE INSTALLATION AND CONFIGURATION
SWITCHING FROM QA ENGINEER TO PROJECT MANAGER - LEVEL UP OR DOWN?
TECHNOLOGIES-POWERED WEB AND THE POST-BROWSER ERA
PROTECTED CONTENT: END-TO-END PGP ENCRYPTION FOR DRUPAL
DRUPAL AUDITS MADE FASTR
FROM DISTRO TO CUSTOM - HOW WE CREATE GREAT COMMUNITIES FOR EVERY ORGANIZATIO...
SEARCH API: TIPS AND TRICKS - FROM BEGINNING TO CUSTOM SOLUTIONS

Recently uploaded (20)

PDF
APNIC Update, presented at PHNOG 2025 by Shane Hermoso
Β 
PPTX
Funds Management Learning Material for Beg
PPTX
presentation_pfe-universite-molay-seltan.pptx
PDF
Tenda Login Guide: Access Your Router in 5 Easy Steps
PPTX
introduction about ICD -10 & ICD-11 ppt.pptx
PDF
An introduction to the IFRS (ISSB) Stndards.pdf
PPTX
INTERNET------BASICS-------UPDATED PPT PRESENTATION
PPTX
June-4-Sermon-Powerpoint.pptx USE THIS FOR YOUR MOTIVATION
PDF
The New Creative Director: How AI Tools for Social Media Content Creation Are...
PDF
Automated vs Manual WooCommerce to Shopify Migration_ Pros & Cons.pdf
PDF
How to Ensure Data Integrity During Shopify Migration_ Best Practices for Sec...
PDF
πŸ’° π”πŠπ“πˆ πŠπ„πŒπ„ππ€ππ†π€π πŠπˆππ„π‘πŸ’πƒ π‡π€π‘πˆ 𝐈𝐍𝐈 πŸπŸŽπŸπŸ“ πŸ’°
Β 
PDF
FINAL CALL-6th International Conference on Networks & IOT (NeTIOT 2025)
PPTX
Introuction about ICD -10 and ICD-11 PPT.pptx
PPTX
Introduction to Information and Communication Technology
PPTX
international classification of diseases ICD-10 review PPT.pptx
PPT
isotopes_sddsadsaadasdasdasdasdsa1213.ppt
PDF
SASE Traffic Flow - ZTNA Connector-1.pdf
PPT
Design_with_Watersergyerge45hrbgre4top (1).ppt
PPTX
Digital Literacy And Online Safety on internet
APNIC Update, presented at PHNOG 2025 by Shane Hermoso
Β 
Funds Management Learning Material for Beg
presentation_pfe-universite-molay-seltan.pptx
Tenda Login Guide: Access Your Router in 5 Easy Steps
introduction about ICD -10 & ICD-11 ppt.pptx
An introduction to the IFRS (ISSB) Stndards.pdf
INTERNET------BASICS-------UPDATED PPT PRESENTATION
June-4-Sermon-Powerpoint.pptx USE THIS FOR YOUR MOTIVATION
The New Creative Director: How AI Tools for Social Media Content Creation Are...
Automated vs Manual WooCommerce to Shopify Migration_ Pros & Cons.pdf
How to Ensure Data Integrity During Shopify Migration_ Best Practices for Sec...
πŸ’° π”πŠπ“πˆ πŠπ„πŒπ„ππ€ππ†π€π πŠπˆππ„π‘πŸ’πƒ π‡π€π‘πˆ 𝐈𝐍𝐈 πŸπŸŽπŸπŸ“ πŸ’°
Β 
FINAL CALL-6th International Conference on Networks & IOT (NeTIOT 2025)
Introuction about ICD -10 and ICD-11 PPT.pptx
Introduction to Information and Communication Technology
international classification of diseases ICD-10 review PPT.pptx
isotopes_sddsadsaadasdasdasdasdsa1213.ppt
SASE Traffic Flow - ZTNA Connector-1.pdf
Design_with_Watersergyerge45hrbgre4top (1).ppt
Digital Literacy And Online Safety on internet

Mssql to mysql - Anton Ivanov

  • 1. Drupal database Mssql to MySQL migration Anton Ivanov
  • 2. Customer choice  Nginx + MySQL + PHP  or  IIS + Mssql + PHP  ??
  • 3. What we need first  Working Mssql server  &  Working MySQL server
  • 4. Mssql server on Linux  Docker container  or  Local installation
  • 5. Installation process  Go to Microsoft site  Use HowTo  Command line tools  Test site …
  • 6. But site not works :(  SQLSTATE[HY010]: [unixODBC] [Driver Manager] Function sequence error: …
  • 7. But site not works :(  SQLSTATE[HY010]: [unixODBC] [Driver Manager] Function sequence error: …  Because PHP driver not stable
  • 8. Use Windows, Luke  Machine with Windows or VM: οƒ˜ Mssql Server Express οƒ˜ SQL Server Management Studio SSMS οƒ˜ WAMP + Fresh sqlsrv drivers οƒ˜ Comment wincache_*() calls
  • 9. Converting database  2 separated ways available: οƒ˜ for Drupal 7 οƒ˜ for Drupal 8
  • 10. MySQL Workbench  Simple multistep form  Result: Converted database  But not works with Drupal 7 (unserialization error)
  • 11. DBTNG Migrator  Simple module (Schema API + DBTNG)  Actual Schema in code  Result: Converted database  But not works with Drupal 8 (no Drupal 8 version)
  • 15. Tricks  SQL Server authentication (don't use Windows authentication)  use Adminer (to test connection and structure)  in Drupal 7 comment wincache_*() (/includes/database/sqlsrv/database.inc)
  • 16. Importing dump with sqlcmd  sqlcmd -H localhost -U SA  RESTORE FILELISTONLY FROM DISK = '/path/to/dump.bak' οƒ˜ Drupal_Data01 ... H:PROD_DATADrupal_Site_Data01.mdf οƒ˜ Drupal_Data02 ... H:PROD_DATADrupal_Site_Data02.ndf οƒ˜ Drupal_TLog01 ... J:PROD_LOGDrupal_Site_TLog01.ldf  RESTORE DATABASE Drupal_Site FROM DISK='/path/to/dump.bak' WITH MOVE 'Drupal_Data01' to '/var/opt/mssql/data/drupal_data01.mdf', MOVE 'Drupal_Data02' to '/var/opt/mssql/data/drupal_data02.ndf', MOVE 'Drupal_TLog01' to '/var/opt/mssql/data/drupal_tlog01.ldf' GO
  • 17. Useful links, Linux Download Mssql server : https://www.microsoft.com/en-us/sql-server/sql-server-2017#resource SQL Server command-line tools : https://docs.microsoft.com/en-us/sql/linux/sql-server-linux-setup-tools Mssql backup and restore db : https://docs.microsoft.com/en-us/sql/linux/sql-server-linux-backup-an Mssql PHP driver for Linux : https://github.com/Microsoft/msphpsql
  • 18. Useful links, Windows Download Mssql server Express edition : https://www.microsoft.com/en-us/sql-server/sql-server-editions-expres Download SQL Server Management Studio (SSMS) : https://docs.microsoft.com/en-us/sql/ssms/download-sql-server-manag Restore database from dump with SSMS : https://www.howtogeek.com/50354/restoring-a-sql-database-backup-u Mssql PHP driver for Windows : https://github.com/Microsoft/msphpsql (php_pdo_sqlsrv_7_ts.dll, php_sqlsrv_7_ts.dll)
  • 19. Useful links, Tools DBTNG Migrator : https://www.drupal.org/project/dbtng_migrator Download MySQL Workbench : https://dev.mysql.com/downloads/workbench Migrate with MySQL Workbench : http://mysqlworkbench.org/2012/07/migrating-fro