Skip to content

Adapts your codeigniter 3 project that was built on mysql to postgresql

License

Notifications You must be signed in to change notification settings

R-N/codeigniter-3-mysql-to-postgre-adapter

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

CodeIgniter 3 MySQL to PostgreSQL adapter

Adapts your codeigniter 3 project that was built on mysql to postgresql

Usage

  1. Migrate your database to postgresql (I recommend to use pgloader). Your old database name should be the new schema name.
  2. Copy applications folder onto yours
  3. Add "postgre" to your helpers autoload (in applications/config/autoload.php)
  4. Modify your database configuration to use postgres (in applications/config/database.php). Example:
$db['default'] = array(
    'dsn'   => '',
    'hostname' => 'localhost',
    'port'     => 5432,
    'username' => 'postgres',
    'password' => '',
    'database' => 'postgres',
    'schema'   => 'public',
    'dbdriver' => 'postgre',
    'sslmode' => 'allow',
    ...
);
  1. PostgreSQL converts names to lowercase unless you use double quotes in the SQL, so modify your code to access database values in lowercase. If you want compatibility with mysql, convert the mysql database to lowercase too. The names include database name, schema name, table and view name, column name, returned column/value aliases.

Migration

You can use the migrate.lisp with pgloader.

  1. Modify it to use your datbase URL
  2. Run pgloader migrate.lisp
  3. Views, triggers, procedures, and functions don't get migrated. Recreate them through SQL

pgloader for windows

They don't ship pgloader binaries for Windows. Either you build them yourself, or use the linux one through WSL. Binaries built for windows are tied to your machine, idk if it's the architecture or whatever, but the one I found on the internet didn't work for me.

  1. Install cygwin64, choose the following packages: image
  2. Download CCL. Extract it somewhere. Preferably close to where you would clone the pgloader project.
  3. Download dblib_0.95.zip. Copy all the files to cygwin64/bin.
  4. Duplicate dblib.dll and rename it to sybdb.dll
  5. Download sqlite3.dll. Copy it to cygwin64/bin.
  6. Clone the pgloader repo git clone https://github.com/dimitri/pgloader.git
  7. Open cygwin64 terminal.
  8. Change directory to the pgloader project directory.
  9. Compile pgloader. [your ccl.exe location] --no-init --load ./src/save.lisp.
  10. In build/bin, there will be a pgloader file . Rename it to pgloader.exe
  11. run pgloader.exe, when it popped out the error, type :GO

Reference thread for building pgloader

Releases

No releases published

Packages

No packages published