MySQL++

Artifact [a185c73f1f]
Login

Artifact a185c73f1ffda2066bd479b380cfd01ab2419ee68501d62087b61b020e254592:

Wiki page [MySQL++] by tangent 2017-11-21 16:16:26.
D 2017-11-21T16:16:26.285
L MySQL++
N text/x-markdown
P 89937ea080c3ff0d19b7197a62373901a5df3be78da2390fdb8b40d7f8b517f8
U tangent
W 5300
<img src="https://tangentsoft.com/mysqlpp/bitmaps/logo-small.jpg" alt="MySQL++ rocks" width="300" height="142" style="float:right; margin-left:20px" />

MySQL++ is a C++ wrapper for [MySQL](http://mysql.com/)’s C API. It is built around the same principles as the Standard C++ Library, to make dealing with the database as easy as dealing with STL containers. In addition, MySQL++ provides facilities that let you avoid the most repetitive sorts of SQL within your own code, providing native C++ interfaces for these common tasks.

If you have questions about this project and can’t find an answer in the [documentation](/wiki?name=Documentation) or the [mailing list archives](http://lists.mysql.com/plusplus/), you should [ask it on the list](http://lists.mysql.com/plusplus/). Everyone active in MySQL++’s development monitors that mailing list, and the library’s primary maintainer responds to almost every question posted there. By posting to the mailing list, your question and any answers are archived
for future developers to find, and you reach a wider audience than is possible with personal email.


## <a name="stable"></a>Latest Stable Version

Before upgrading an existing version of MySQL++, please scan through the [change log](/file/ChangeLog) first. If you’re coming from a much older version, better read through the “[Incompatible Library Changes](doc/html/userman/breakages.html)” chapter in the [user manual](doc/html/userman/) instead. 


### <a name="source"></a>Source Code

[mysql++-3.2.3.tar.gz](releases/mysql++-3.2.3.tar.gz) (416 KB, 2016.12.31) — Library source code. If you aren’t sure which file to download, download this.

[mysql++-3.2.3-1.src.rpm](releases/mysql++-3.2.3-1.src.rpm) (3.1 MB, 2016.12.31) — Source RPM, for those that need to build their own binary RPMs. To do this, run this command as root:

    # rpmbuild --rebuild /wherever/it/is/mysql++-3.2.3-1.src.rpm

The resulting `mysql++`, `mysql++-devel` and `mysql++-manuals` RPMs will be in a distribution-dependent directory, typically somewhere under `/usr/src`.

You may also want to [clone our Fossil repository](/doc/trunk/HACKERS.md).


### <a name="binary"></a>Binary Packages

MySQL++ has been picked up by many package distros. It’s been spotted in the [Debian](http://packages.debian.org/search?searchon=sourcenames&keywords=mysql%2B%2B), [Fedora](https://admin.fedoraproject.org/pkgdb/package/rpms/mysql++/),
[FreeBSD](http://www.freshports.org/databases/mysql++3/), [Gentoo](http://packages.gentoo.org/package/dev-db/mysql++?arches=all), [Homebrew](https://github.com/Homebrew/homebrew-core/blob/master/Formula/mysql++.rb),
[RHEL (EPEL)](https://fedoraproject.org/wiki/EPEL), and [Ubuntu](https://launchpad.net/ubuntu/+source/mysql%2B%2B) package
systems. Since these first-party packages are properly integrated into their host distributions, there is no point offering competing binary packages here.

If you want something different in your binary package than you get in the standard package distro for your OS, you should build it from [source](#source) on the target OS, or else you are likely to have [problems](#segfaults).


## <a name="oldver"></a>Old Versions

If you need a particular older version of MySQL++, you can either grab the raw source code for it from the [Fossil tag list page](/taglist) or you can [browse](/releases) the old version archive.

Those still needing MySQL++ 2.x might be interested in the [`v2.3.2-modern`](https://tangentsoft.com/mysqlpp/timeline?r=v2.3.2-modern) branch, which makes minimal changes to version 2.3.2 — the last release in the 2.x line — to allow it to build on modern systems. Essentially, it contains build fixes analogous to those we've done in the 3.x line without backporting any actual features or behavior changes from 3.x. This branch is unlikely to ever be released, but it is intended to be "stable" at all times.


## <a name="docs"></a>Documentation

The user and reference manuals are shipped in the source code tarball above. They are also [available online](/doc/).


## <a name="faq"></a>Frequently-Asked Questions

The [FAQ list](/wiki?name=FAQ) answers many commonly-asked questions about MySQL++.


## <a name="contrib"></a>Contributing to the Effort

The easiest thing to do if you want to help out with the MySQL++ development effort is to participate on the [mailing list](http://lists.mysql.com/plusplus/). We could use help answering questions, and it’s frequently helpful to have different voices contributing to discussions about the library’s future.

If you want to participate in the coding effort, the MySQL++ development project is hosted right here, by [Fossil](http://fossil-scm.org/), a distributed version control similar to Git, but much easier to use. See [the Hackers file](/file/HACKERS.md) for instructions on working with Fossil and the MySQL++ source code.

For a great source of projects to tackle, see [the Wishlist file](/file/Wishlist).

If you just want to keep up on the in-progress developments, see [the project timeline](/timeline), which is also available in [RSS form](/timeline.rss) for those who want MySQL++ changes to appear in their feed reader.



<div style="height:400px"/>
Z ec28d70876407c8e25a95a8b500ce078