ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

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

2021-07-03 14:56:59  阅读:225  来源: 互联网

标签:SQLite database 数据库 Laravel3.0 PDO 源码 memory null


<?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

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有