rawphp/raw-database

RawDatabase is a wrapper with useful utility functions around the MySQLi class and is used by RawPHP framework and other applications.

dev-master / 0.x-dev 2015-01-04 03:48 UTC

This package is auto-updated.

Last update: 2024-10-20 08:34:22 UTC


README

Build Status Coverage Status Latest Stable Version Total Downloads Latest Unstable Version License

SensioLabsInsight

Package Features

  • Query your database with query( )
  • Insert records with insert( )
  • Execute commands with execute( )
  • Create and drop tables with createTable( ) and dropTable( )
  • Add and drop columns with addColumn( ) and dropColumn( )
  • Add and drop indexes with addIndex( ) and dropIndex( )
  • Supports INDEX, PRIMARY KEY, UNIQUE, FULLTEXT and SPATIAL index
  • Add and drop foreign keys with addForeignKey( ) and dropForeignKey( )
  • Transaction support with startTransaction( ), commitTransaction( ) and rollbackTransaction( )
  • Lock and unlock tables with lockTables( ) and unlockTables( )

Installation

Composer

RawDatabase is available via Composer/Packagist.

Add "rawphp/raw-database": "0.*@dev" to the require block in your composer.json and then run composer install.

{
        "require": {
            "rawphp/raw-database": "0.*@dev"
        }
}

You can also simply run the following from the command line:

composer require rawphp/raw-database "0.*@dev"

Tarball

Alternatively, just copy the contents of the RawDatabase folder into somewhere that's in your PHP include_path setting. If you don't speak git or just want a tarball, click the 'zip' button at the top of the page in GitHub.

Basic Usage

<?php

use RawPHP\RawDatabase\Database;

// configuration
$config = array(
    'db_name'   => 'database_name',
    'db_user'   => 'user',
    'db_pass'   => 'password',
    'db_host'   => 'localhost',
    'handler'   => 'mysql',
);

// create a new instance of database
$db = new Database( $config );

// query the users table - returns an array of key->value pairs
$results = $db->query( "SELECT * FROM users" );

// insert a record

// escape strings before inserting into the database
$username = $db->prepareString( $user->username );

// insert returns the new record ID
$id = $db->insert( "INSERT INTO users ( user_name ) VALUES ( '$username' )" );

// add table
$result = $db->createTable( 'users', array( 
                'user_id'   => 'INTEGER(11) PRIMARY KEY AUTO_INCREMENT NOT NULL',
                'username   => 'VARCHAR(32) NOT NULL,
            )
);

// drop table
$result = $db->dropTable( 'users' );

// add index
$result = $db->addIndex( 'table_name', array( 'column1', 'column2' ), 'index_name', $index_type );

// drop index
$result = $db->dropIndex( 'table_name', 'index_name' );

License

This package is licensed under the MIT. Read LICENSE for information on the software availability and distribution.

Contributing

Please submit bug reports, suggestions and pull requests to the GitHub issue tracker.

Changelog

02-10-2014

  • Added prepare() and getResults() methods for prepared statements.

22-09-2014

  • Updated for PHP 5.3.
  • Renamed Database to Mysql
  • Added base abstract Database class

20-09-2014

  • Replaced php array configuration with yaml

18-09-2014

  • Updated to work with the latest rawphp/rawbase package.

16-09-2014

  • Replaced query in tableExists() with cleaner solution.

14-09-2014

  • Implemented the hook system.

13-09-2014

  • Moved database initialisation into init()

11-09-2014

  • Initial Code Commit