数据库
首页 > 数据库> > 【Laravel3.0.0源码阅读分析】SQLite连接类

【Laravel3.0.0源码阅读分析】SQLite连接类

作者:互联网

<?php namespace Laravel\Database\Connectors; use PDO;

class SQLite extends Connector {

	/**
	 * Establish a PDO database connection.
	 * 建立 PDO 数据库连接。
	 * @param  array  $config
	 * @return PDO
	 */
	public function connect($config)
	{
		$options = $this->options($config);

		// SQLite provides supported for "in-memory" databases, which exist only for the
		// lifetime of the request. Any given in-memory database may only have one PDO
		// connection open to it at a time. These are usually for testing.
        // SQLite 为“内存中”数据库提供支持,这些数据库仅在请求的生命周期内存在。
        // 任何给定的内存数据库一次只能打开一个 PDO 连接。 这些通常用于测试。
		if ($config['database'] == ':memory:')
		{
			return new PDO('sqlite::memory:', null, null, $options);
		}

		// SQLite databases will be created automatically if they do not exist, so we
		// will not check for the existence of the database file before establishing
		// the PDO connection to the database.
        // 如果 SQLite 数据库不存在,则会自动创建,因此在建立与数据库的 PDO 连接之前,我们不会检查数据库文件是否存在。
		$path = path('storage').'database'.DS.$config['database'].'.sqlite';

		return new PDO('sqlite:'.$path, null, null, $options);
	}

}

github地址: https://github.com/liu-shilong/laravel3-scr   

标签:SQLite,database,数据库,Laravel3.0,PDO,源码,memory,null
来源: https://blog.51cto.com/u_14097531/2972961