sql >> データベース >  >> RDS >> Mysql

静的クラスとシングルトンクラスのしくみ(データベース)

    シングルトンデザインパターンを使用してデータベースオブジェクトのインスタンスにアクセスする次の例を検討してください(これの目的は、アプリケーション全体で同じ接続を何度も再利用することです)

    class Database {
    
        protected static $_dbh;
        const HOST = 'localhost';
        const DATABASE = 'dbname';
        const USERNAME = 'username';
        const PASSWORD = 'password';
    
        //declare the constructor as private to avoid direct instantiation.   
        private function __construct() { }
    
        //access the database object through the getInstance method.
        public static function getInstance() {
            if(!isset($_dbh)) {
                #Connection String.
                self::$_dbh = new PDO('mysql:host='.self::HOST.';dbname='.self::DATABASE,self::USERNAME,self::PASSWORD);
                self::$_dbh->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
            }
            return self::$_dbh;
        }
    }
    

    これで、アプリケーションのどこかでクラスを使用する必要がある場合は、このように簡単に実行できます。

    require_once('database.php');
    $dbh = Database::getInstance();
    $sth = $dbh->query('SELECT * FROM sometable');
    $result = $sth->fetchAll(PDO::FETCH_ASSOC);
    

    Database::getInstance();の呼び出し 静的メソッドを使用します。これが基本的に行うことは、コンストラクターをプライベートとして宣言することによってオブジェクトを直接インスタンス化することを制限し、代わりにオブジェクトがすでにインスタンス化されているかどうかをチェックすることです。 trueの場合、すでにインスタンス化されているオブジェクトを返します。それ以外の場合は、新規作成して、新しく作成されたオブジェクトを返します。これにより、同じデータベース接続がアプリケーション全体で再利用されるようになります。




    1. 統計がない日のためにMysqlからデータを取り戻す方法

    2. TO_DAYS()の例– MySQL

    3. asp.net C#からmysqlにアラビア語を挿入する方法

    4. エラーjava.lang.ClassNotFoundException:コマンドラインからJARを実行中にcom.mysql.jdbc.Driver