Comparison of MySQL and MS SQL

Download as pdf or txt
Download as pdf or txt
You are on page 1of 7

Accelerat ing t he world's research.

Comparison of MySQL and MS SQL


Server
Justin Ravago

Related papers Download a PDF Pack of t he best relat ed papers 


Comparison of MySQL and MS SQL Server
Justin Alecxander F. Ravago
Lyceum of the Philippines University - Laguna
Km. 54 National Highway, Brgy. Makiling, Calamba, Laguna, Philippines
[email protected]

Abstract— Database management systems vary on the 1995. MySQL AB was later on acquired by Sun which was in
environment wherein its features will be utilized. Each has its own turn acquired by Oracle Corporation, which currently develops,
advantages and disadvantages, as well as its strengths and updates and maintains the current version of this database
weaknesses when it regards to performance and security. This management system.
journal entry provides an overview of details regarding MySQL
and MS SQL, two of the most leading relational database
management systems that currently exist in the market. MySQL is an open-source relational database management
system (RDBMS) that is based on Structured Query Language
(SQL). It runs on all operating systems, such as Linux and
Keywords— MySQL, MS SQL, Database, Servers, Systems Windows. It is commonly used for web applications and online
publishing.
I. INTRODUCTION
[1] Databases are a part of everyday life, usually without These are the advantages of using MySQL:
your knowledge. From obvious applications (like customer
databases for insurance companies) to not-so-obvious uses  It’s easy to use, having said that it is an easy database to
(such as storing actual images within a database for integrate at work;
recognition), database use is pervasive and increasing.  Support is available when needed. Since it is open-source,
there is a huge community of both developers and
Having said above, we must always take note that most enthusiasts are present;
systems being used today require structured set-ups, especially  It’s open source. The base code of MySQL is available
when it comes to data management. Regardless of the for access online should you need it.
application, users should be able to seamlessly manage its data  It’s inexpensive. Implementation could range in price of
from one place to another without any worries in terms of free or more. It’s less expensive than its competitors.
accessibility and security.  Industry Standard. It is one of the most-used database
systems in the world due to compatibility to almost all
Dan Brown laid out principles about Information operating systems.
Architecture Principle. Deriving those principles in database
perspective, every database can be evaluated by six (6) These are the disadvantages of MySQL.
independent objectives:  Stability issues. It struggles on handling routines such as
 Four of these are about the functions of design, auditing, referencing and even transactional management
development and implementation: Usability, per se.
Extensibility, Data Integrity and Performance.  Poor performance scaling. It struggles on handling
 Availability and Security is more on about multiple operations at a given time.
implementation rather than design.  Future improvements are delayed. Since Oracle has
taken over MySQL, progress is now delayed with only
With this, I’ve laid out two of the most handpicked systems one major release for the last seven or eight years.
in the market when it comes to relational database management.  Plug-in dependent. It lacks out-of-the-box functionality
against its competitors.
II. DISCUSSION
Personally, I find MySQL as the least option to select when
For this context, we will be looking at two (2) relational we are going to create scalable applications. It is hard to scale,
database management systems that are commonly used across but not impossible, as it needs some serious engineering prior
the market. to scaling. [3] If you expect your application to grow in size,
you need to consider the decision of using MySQL as your
A. MySQL
database. It may work fine at the beginning, until some day you
[2] MySQL AB, a Swedish company, has been known as the need to scale it. You may want to “shard” the data (distribute
founder of MySQL Database Server. Three engineers: two data from one table to multiple instances and machines, but
Swedish, named David Axmark and Allan Larsson and one MySQL does not support this automatically as you need to
Finn, named Micheal Widenius, commonly known as “Monty” maintain the nodes needed prior to the process manually. We
started work on development of MySQL server on May 23,
cannot implement automatic fail-over at this case. We need (GPL). In general, there’s no need to purchase for license
extra utilities or even write our own script for this one. for MySQL installations.
 Support – will I require support directly for my
installation? Having said that MySQL is handled by
i) Performance: Oracle, assistance is available thru their channels.
 Operating System and Architecture – Which one of the
[4] Nick Berardi, an enthusiast, posted a response on many platforms can MySQL run? For this, see Table I.
stackoverflow regarding MySQL’s performance. According  Development – What applications will I develop using
to him, “...physical database size does not matter. The MySQL? For this, see Table II.
number of records does not matter. It is about the number of  Existing Data – Will I import data from existing database?
queries that the server can handle at a time.” So apart from MySQL supports loading data from delimited text files
database configuration, query execution and construction containing comma-separated-values (CSV). If you’re
matters, too. coming from an older version of MySQL, then
mysqldump is available to use.
About its technical specifications, MySQL runs on any  Management – How do I manage the server and how do
32-bit or 64-bit computers, having at least 32mb of RAM or clients connect to the database? Well, managing the
less. This is a considerable setup in comparison to its server is on the hands of the administrator, which is you.
competitors running on the same specifications. That’s Several tools can be used, such as phpMyAdmin, a web-
why MySQL is often picked for small application based GUI that enables administrators to manage their
development projects, specifically web applications. MySQL databases thru a web application interface.
Connection relies on the settings that can be found on
ii) Security: Table III.

[5] The MySQL Database has become the world’s most TABLE I
popular open-source database because of its consistent level MYSQL OPERATING SYSTEMS AND ARCHITECTURE SUPPORT
of fast performance, high reliability, and ease of use. As most
products do, it comes out of the box. Usually, security is not Operating System Available?
AIX 4.x Yes
a major consideration when installing this kind of product, Amiga Yes
but for this case, here’s what we I can share about security BeOS Soon
regarding MySQL. BSDi 2.x-4.x Yes
DEC UNIX 4.x Yes
Both the server (the unit where the software is installed) FreeBSD 2.x – 4.x Yes
HP-UX 10.20 – 11.x Yes
and software (MySQL) should be configured in a way that Linux (Kernel 2.0 or later) Yes
they are both secured from external entities, as well as MacOS Yes
unexpected events. NetBSD Yes
OpenBSD Yes
OS/2 Yes
SCO OpenServer Yes
Usually the security of MySQL relies on the configuration.
Solaris Yes
For example, the access for root user should be secured with SunOS Yes
complex passwords and should not be given to anyone unless Tru64 Yes
it is required. However, setting credentials for MySQL Windows Yes
should be done on a Command-Line Interface (CLI), usually
provided upon installation. Having said that, it is a must to MySQL in Linux is the most popular installation amongst all
change the root password before anything else. these, followed by Windows. Take note that there are additional
tools needed or components based on the installation that you
Personally, when I’m using MySQL, I don’t change the are currently doing. These can be found on the MySQL website.
default root password set upon installation (the default is
1234, or sometimes I leave it blank when asked upon TABLE II
installation) for easier debugging and publishing of updated DEVELOPMENT PLATFORMS THAT MYSQL SUPPORT
solutions. However, I repeat, that this is not a good practice.
Development Platform Available?
C Yes
C++ Yes
iii) Installation Requirements: Eiffel Yes
You will need to consider some items before installing Java Yes
MySQL. To help you out, here’s some of the items: ODBC Yes
 Licensing – will I be required to purchase a license? Well, Perl Yes
PHP Yes
MySQL is covered by GNU General Public License Python Yes
TCL Yes  Industry standard. Yes, it is- SQL server is being used by
small stores up to enterprise AND complex systems.
TABLE V  Ongoing development. Microsoft is investing
DEFAULT PORTS FOR COMMON MYSQL SERVICE enormously on new features in preparation for future
needs of Database Developers and Administrators.
Service Description Port
MySQL Port Default TCP 3306
These are the disadvantages of MS SQL:
 Price. It is made for enterprise companies that store
Should all items have been answered, then you can now
proceed on the installation per se. For this article, I’d millions of data. Since the accommodation level is robust
included a sample screenshot of MySQL installation under and high, Enterprise editions of MS SQL costs double
Windows (see Fig. A-1) than its competitors, excluding the server wherein the
database will be hosted.
 Usability. MS SQL Server uses a core language, which
is different from its competitors. Database Programmers
need to study an additional set of guidelines and setup for
its environment.
 Hardware. Newer versions of MS SQL require more
powerful hardware setups as new iterations feature jam-
packed capabilities as well. It also requires the .NET
Framework that should be installed on the server- a
separate component used by developers and users.
 Large database size. DBAs should consider a reasonable
amount of space for the database engine and its
components.

I have read some articles and personally, I support the


writer’s take regarding SQL and its disadvantage when it
has been implemented on a production setup: [8] Older
Fig. A-1 Sample configuration of ports and services on a Windows machine
versions of SQL Server may install on older hardware
equipment, but never releases of the application require
more advanced technologies to support the resources
needed by the database.
B. MS SQL Server
[6] In the year 1987, Microsoft joined hands with Sybase iv) Performance:
Solutions in order to develop a database management system, Performance varies both on host and SQL editions that
which could compete with the existing giants like IBM and have been configured for the system. Having said that, if the
Oracle. It have been decided that Sybase would have all the server is intended to serve complex applications (for
selling rights and profit earned from the product version example, a data warehouse type of application or an ERP
designed for the Non-Microsoft platform while Microsoft will application), then a more powerful hardware setup is
have exclusive rights of the database product designed for recommended for the system to perform well.
Microsoft Platforms. Hence, the first database server product
was released around 1989. Later on, Sybase sold all the rights [9] Newest version of SQL server compares their current
to Microsoft and now the product name was changed to MS setup to this metaphor: “Imagine you’ve just bought a super
SQL Server. Until now, around 15 versions of this product had powerful car with built-in advanced technology to make it
been released. perform at its highest. You want to take full advantage of
that horsepower and even turbocharge it, while at the same
MS SQL’s position in the database market industry has time get great mileage. That is what we get when you run
consistently grown over time. It remains the strong choice for SQL Server 2016 on Windows Server 2016 (both are the
data management, business analytics and computing along with latest versions of Server and RDBMS setups from
the strength of its community. It offers a mix of performance, Microsoft): unmatched performance at the lowest cost.
reliability, convenient application management. [7] It is a
dream system for a database developer.
v) Security:
These are the advantages of using MS SQL:
 It is designed to work in a set-based manner.
Given that SQL Server is owned by Microsoft, security is

 Scalable Performance. Usually, enterprise databases are


one of the one of the criteria that they consider when
delivering solutions is about security. Most complex systems
huge – and SQL Server is somewhat used to it as it in the market today are powered by Microsoft SQL Server
regularly runs databases on about one (1) terabyte in size.
Enterprise Editions, delivering top-notch security and good Business Intelligence Development
customer support. Studio : 2145MB
Operating System 64-bit and 32-bit (WOW64)
Windows Server 2008 R2 SP1
SQL Server implements authentication as primary Windows Server 2008 SP2
security handler. There are two types: Windows 7 SP1
 Windows-based authentication, wherein users that are Windows Vista SP2
Framework .NET Framework 3.5 SP1
connecting into the server should be a member of a .NET Framework 4.1
domain or an address that the server can recognize or is SQL Server Native Client
connected into; and SQL Server Setup Support Files
 SQL Authentication, wherein users are being
authenticated using the registered username and As part of deployment and security process, you also need
password stored on the server itself. to check these ports to the system. Allow inbound and
outbound connections to these ports so that SQL server can
Personally, I prefer SQL Authentication so that it is not use them.
dependent on the active directory services that Microsoft is
currently implementing as the first security filter across their TABLE V
servers. DEFAULT PORTS FOR COMMON SQL SERVER SERVICES

Service Description Port


vi) Installation Requirements:
SQL Server Database Default Instance TCP 1433
The installation process for SQL Server (in this case, Services Default Admin TCP 1434
version 2012) is straightforward and relatively simple with Connection
the new included tools and resources bundled to assess its SQL Server Analysis Default Instance TCP 2383
deployment, whether it is an upgrade from a previous Services
SQL Server Default TCP 135
installation or completely a new setup. For the get-go, Integration Services
consider these things:
 Hardware
SQL Server Non-SSL (http://) TCP 80
Reporting Services SSL (https://) TCP 443
 Operating System SQL Server Service Default TCP 4022
 Collation
Broker
 Edition
SQL Server Browser Default UDP 1434

 License
Service TCP 2382

 Accounts Next, you should consider on selecting the appropriate


Let’s say that you’ve considered the items above, then let’s edition to use. Usually it is tied up based on what type of
proceed. Take note that this does not end on this point- we must application the server will host, from small point-of-sale
think about scalability in a sense. What is the current need of systems up to large CRM (Customer Relationship
the server itself, and the anticipation of its needs in the future is Management) systems.
a must!
TABLE IV TABLE VI
SYSTEM REQUIREMENTS FOR MS SQL SERVER SQL SERVER EDITION MATRIX
Component Requirement Edition Description
Processor 64-bit installations: Enterprise Provides the highest level of
Speed: 1.4GHz or higher; scalability for large mission-
AMD Opteron, Athlon 64, Intel critical applications
Pentium IV, Xeon with intel Standard Tailored for small-to-mid sized
EM64T support organizations
Web Cost-effective database application
32-bit installations:
to support web applications,
Speed: 1.0GHz or higher;
websites and web services
Pentium III compatible
Developer Includes all functionalities of
Memory 1GB (512mb for Express Editions)
Enterprise Edition, but is not
Storage Installer: 4.0GB recommended for production
Database Engine Services: 986MB environments.
Integration Services: 304MB Evaluation Includes all functionalities of
Analysis Services: 517MB
Enterprise Edition for 180 days.
Master Data Services: 243MB
Express Free redistributable for learning,
Reporting Services (Native Mode):
managing and developing small
1022MB
database applications. It is limited
Reporting Services (SharePoint
to 10GB of storage per database.
Integrated Module): 129MB
Express LocalDB A new, free, lightweight version of
Management Tools (Complete):
Express Edition that has fast zero-
1551MB
configuration installation and
fewer prerequisites. Runs in user
mode and includes all features of Development Ada C++
Express edition. Platforms C Delphi
Compact Free redistributable edition that C# Go
can be embedded into mobile C++ Java
devices, desktops and web clients D JavaScript
Delphi PHP
Eiffel Python
Should you have been decided, you can now proceed on Erlang R
installing MS SQL Server. You can install it with a graphical Haskell Ruby
user interface, using the SQL Server Installation Centre (see Java Visual Basic
Fig. B-1). Instructions are pretty straightforward, and some of JavaScript
Objective-C
the configuration is automatically set for the user. OCamp
Perl
PHP
Python
Ruby
Scheme
TCL

Using the table above, we can compare the two based on the
particulars that we are going to consider when we develop a
solution, specifically about operating systems and development
platforms. Systems should be flexible today, as technology is
rapidly progressing to its peak – we must consider that our
database should be able to adjust regardless of the situation.
Now, as we observe the table above, it’s clear to us that
MySQL has twice the coverage against MS SQL, given that it
Fig. B-1 Sample screenshot of SQL Server Installation Centre lives inside an open-source setup. It can also run on multiple
operating systems, while SQL Server is only limited to
Windows.
But that doesn’t mean that SQL Server is left behind,
because MS SQL is commonly picked for commercial setups
III. COMPARISON because of enhanced security and data integrity. It also has
Comparing the two is not easy, because they both dominate wider coverage of APIs compared to MySQL which extends it
the database market with exquisite ratings on all key useability and flexibility across existing applications.
performance indicators mentioned above. Having said that, we
will then use a comparison table (see Table VII) so that we can [10] In terms of security, it is a major concern for data
see their similarities and differences on a requirement management. Both MS SQL and MySQL are EC2 complaint,
perspective: meaning they both make sure that they have adequate security
support for building government applications.
TABLE VII
COMPARISON TABLE – MYSQL VERSUS MS SQL

Database Management Systems IV. CONCLUSIONS


Particulars MySQL MS SQL
Description Widely used open- Microsoft Relational In the end, the database that you will consider remains on the
source RDBMS RDBMS type of the solution that you are going to develop. Both are
Developer Oracle Microsoft excellent on the field, but what really matters are planning
Initial Release 1989 1995 behind before the implementation. Should you want less
Current Release MySQL 5.7.18 SQL Server 2016
License Open Source Commercial
configuration and easy setup before the get-go, I suggest that
Cloud-based No No you go with MySQL- Hence, should you and your team are
Operating FreeBSD Windows planning to deliver a complex solution that requires sturdy
Systems Linux security setup, most especially if it is an Enterprise Application,
OSX then I suggest that you go with MS SQL.
Solaris
Windows
Data Scheme Yes Yes
SQL Yes Yes ACKNOWLEDGMENT
Supported APIs ADO.NET OLEDB I would first like to thank our God, the creator, who made all
(Application JDBC Tabular Data Stream
Programming ODBC ADO.NET
things possible, including this journal entry. I also wanted to
Interfaces) JDBC acknowledge Ms. Jonalyn Ebron, from LPU Laguna, for
ODBC
providing the guidelines and mentorship regarding this journal [4] “How big can a MySQL database get before performance starts to
degrade", Stackoverflow.com, 2017
entry writing.
[5] “MySQL Database Security Best Practices”, HexaTier, 2017
[6] “MS SQL Server History and Advantages", ByteScout, 2014
Finally, I must express my very profound gratitude to all my [7] A. Jorgensen, J. Segarra, P. LeBlanc, J. Chinchilla and A.
classmates at Advanced Database, LPU-Laguna, to my parents, Nelson, Microsoft SQL Server 2012 Bible, 1st ed. Indianapolis: John
Wiley & Sons, Inc., 2012, p. Introduction (xxix).
and to everyone who shared their ideas regarding my topic.
[8] “MySQL Database Security Best Practices”, Hexatier.com, 2015.
[9] “Five reasons to run SQL Server 2016 on Windows
REFERENCES Server”, Blogs.technet.microsoft.com, 2017
[1] S. Suehring, MySQL Bible, 1st ed. New York, NY: Wiley Publishing, [10] “Microsoft SQL Server vs. MySQL Comparison”, Db-engines.com,
Inc., 2002, p. 3. 2017.
[2] “MySQL Server History and Advantages", ByteScout, 2014
[3] “The advantages and disadvantages of MySQL", Makble.com, 2017

You might also like