PHP laravel实现配置使用多数据库

 更新时间:2022年10月21日 11:29:05   作者:camellia  
有的时候,我们在开发的过程中需要连接多个数据库。Laravel框架中早已为我们想到了这样的需求。这篇文章主要为大家介绍了laravel配置使用多数据库的方法,需要的可以参考一下

有的时候,我们在开发的过程中需要连接多个数据库。

Laravel框架中早已为我们想到了这样的需求。

配置很简单。

在根目录下的/config/database.php文件中配置:

Laravel中为我们提前预设了多种类型的数据库连接

  'connections' => [
  
        'sqlite' => [
            'driver' => 'sqlite',
            'url' => env('DATABASE_URL'),
            'database' => env('DB_DATABASE', database_path('database.sqlite')),
            'prefix' => '',
            'foreign_key_constraints' => env('DB_FOREIGN_KEYS', true),
        ],
  
        'mysql' => [
            'driver' => 'mysql',
            'url' => env('DATABASE_URL'),
            'host' => env('DB_HOST', '127.0.0.1'),
            'port' => env('DB_PORT', '3306'),
            'database' => env('DB_DATABASE', 'forge'),
            'username' => env('DB_USERNAME', 'forge'),
            'password' => env('DB_PASSWORD', ''),
            'unix_socket' => env('DB_SOCKET', ''),
            'charset' => 'utf8mb4',
            'collation' => 'utf8mb4_unicode_ci',
            'prefix' => '',
            'prefix_indexes' => true,
            'strict' => true,
            'engine' => null,
            'options' => extension_loaded('pdo_mysql') ? array_filter([
                PDO::MYSQL_ATTR_SSL_CA => env('MYSQL_ATTR_SSL_CA'),
            ]) : [],
        ],
  
        'pgsql' => [
            'driver' => 'pgsql',
            'url' => env('DATABASE_URL'),
            'host' => env('DB_HOST', '127.0.0.1'),
            'port' => env('DB_PORT', '5432'),
            'database' => env('DB_DATABASE', 'forge'),
            'username' => env('DB_USERNAME', 'forge'),
            'password' => env('DB_PASSWORD', ''),
            'charset' => 'utf8',
            'prefix' => '',
            'prefix_indexes' => true,
            'schema' => 'public',
            'sslmode' => 'prefer',
        ],
  
        'sqlsrv' => [
            'driver' => 'sqlsrv',
            'url' => env('DATABASE_URL'),
            'host' => env('DB_HOST', 'localhost'),
            'port' => env('DB_PORT', '1433'),
            'database' => env('DB_DATABASE', 'forge'),
            'username' => env('DB_USERNAME', 'forge'),
            'password' => env('DB_PASSWORD', ''),
            'charset' => 'utf8',
            'prefix' => '',
            'prefix_indexes' => true,
        ],
  
    ],

默认连接的是mysql配置,配置项是存储在根目录下的.env文件中的。

如果使用多数据连接,则只需要,根据你的数据库类型,在配置你需要的数据库连接就好了。

如下面所示:

我增加了一个mysql数据库连接和oracle数据库连接

'connections' => [
  
        'sqlite' => [
            'driver' => 'sqlite',
            'url' => env('DATABASE_URL'),
            'database' => env('DB_DATABASE', database_path('database.sqlite')),
            'prefix' => '',
            'foreign_key_constraints' => env('DB_FOREIGN_KEYS', true),
        ],
  
        // 本地数据库,存储本地数据
        'mysql' => [
            'driver' => 'mysql',
            'url' => env('DATABASE_URL'),
            'host' => env('DB_HOST', 'xxxxx'),
            'port' => env('DB_PORT', '3306'),
            'database' => env('DB_DATABASE', xxxx),
            'username' => env('DB_USERNAME', xxxx),
            'password' => env('DB_PASSWORD', xxxxxxx'),
            'unix_socket' => env('DB_SOCKET', ''),
            'charset' => 'utf8mb4',
            'collation' => 'utf8mb4_unicode_ci',
            'prefix' => '',
            'prefix_indexes' => true,
            'strict' => false,
            'engine' => null,
            'options' => extension_loaded('pdo_mysql') ? array_filter([
                PDO::MYSQL_ATTR_SSL_CA => env('MYSQL_ATTR_SSL_CA'),
            ]) : [],
        ],
  
        // 线上数据库,将本地数据,同步至线上数据
        'mysql_base' => [
            'driver' => 'mysql',
            'read' => [
                'host' => env('DB_HOST_BASE', 'xxxxx'),
            ],
            'write' => [
                'host' => env('DB_HOST_BASE', 'xxxxx')
            ],
            'port' => env('DB_PORT_BASE', xxxx),
            'database' => env('DB_DATABASE_BASE', xxxx),
            'username' => env('DB_USERNAME_BASE', xxxxxx),
            'password' => env('DB_PASSWORD_BASE', 'xxxxx'),
            'unix_socket' => env('DB_SOCKET', ''),
            'charset' => 'utf8mb4',
            'collation' => 'utf8mb4_unicode_ci',
            'prefix' => '',
            'strict' => false,
            'engine' => null,
        ],
  
        'pgsql' => [
            'driver' => 'pgsql',
            'url' => env('DATABASE_URL'),
            'host' => env('DB_HOST', '127.0.0.1'),
            'port' => env('DB_PORT', '5432'),
            'database' => env('DB_DATABASE', 'forge'),
            'username' => env('DB_USERNAME', 'forge'),
            'password' => env('DB_PASSWORD', ''),
            'charset' => 'utf8',
            'prefix' => '',
            'prefix_indexes' => true,
            'schema' => 'public',
            'sslmode' => 'prefer',
        ],
  
        'sqlsrv' => [
            'driver' => 'sqlsrv',
            'url' => env('DATABASE_URL'),
            'host' => env('DB_HOST', 'localhost'),
            'port' => env('DB_PORT', '1433'),
            'database' => env('DB_DATABASE', 'forge'),
            'username' => env('DB_USERNAME', 'forge'),
            'password' => env('DB_PASSWORD', ''),
            'charset' => 'utf8',
            'prefix' => '',
            'prefix_indexes' => true,
        ],
         // oracle 数据库连接
        'oracle' => [
            'driver' => 'oracle',
            'host' => '210.30.64.37',
            'port' => xxx,
            'database' => '',
            'service_name' => xxxxx,
            'username' => xxx_xxxx,
            'password' => xxxx_xxxx,
            'charset' => 'AL32UTF8',
            'prefix' => '',
        ]
  
    ],

我们在使用其余的数据库连接,如下方所示:

1:使用原生sql

DB::connection('oracle')->select("SELECT * from  xxxxx WHERE XH = '{$personal_id}' AND XM = '{$name}'")

2:使用laravel封装的数据库方法:

$userinfo = DB::connection('mysql_base')->table('user')
                                                ->where('personal_id', '=', $data['personal_id'])
                                                ->where('name', '=', $data['name'])
                                                ->where('school_id', '=', $data['school_id'])
                                                ->select('id', 'type', 'school_id', 'personal_id', 'name', 'email', 'ilab_user', 'ilab_pwd')
                                                ->first();

最后,还是强调一句,数据库连接相关的用户名,连接,密码之类的,一般还是写在.env文件中的,方便我们统一管理。

以上就是PHP laravel实现配置使用多数据库的详细内容,更多关于PHP laravel配置多数据库的资料请关注脚本之家其它相关文章!

相关文章

  • PHP防盗链的基本思想 防盗链的设置方法

    PHP防盗链的基本思想 防盗链的设置方法

    网站盗链会大量消耗被盗链网站的带宽,而真正的点击率也许会很小,严重损害了被盗链网站的利益。本文主要介绍用PHP实现防盗链的方法以及基本思想,希望对你有帮助,一起来看。
    2015-09-09
  • PHP构造函数与析构函数用法示例

    PHP构造函数与析构函数用法示例

    这篇文章主要介绍了PHP构造函数与析构函数用法,简单讲述php中构造函数与析构函数的定义与使用方法,并结合实例形式演示了构造函数与析构函数的执行顺序,需要的朋友可以参考下
    2016-09-09
  • PHP中英混合字符串截取函数代码

    PHP中英混合字符串截取函数代码

    今天在遇到了一个中英字符串截取的问题,在gbk里中文里每个字占两字节,如果全是中文的话,用substr()函数就可以实现了,但中英都有的话就麻烦了,在以前收藏的代码里找到了一个不错的函数,很好的实现了截取的功能
    2011-07-07
  • PHP操作文件类的函数代码(文件和文件夹创建,复制,移动和删除)

    PHP操作文件类的函数代码(文件和文件夹创建,复制,移动和删除)

    PHP操作文件类(文件和文件夹创建,复制,移动和删除) ,使用也比较方便,需要的朋友可以参考下。
    2011-11-11
  • PHP好看的版权信息注释图型实例详解

    PHP好看的版权信息注释图型实例详解

    这篇文章主要介绍了PHP好看的版权信息注释图型实例详解,这是一个福利,有需要的同学抓紧来看看
    2021-03-03
  • PHP实现的浏览器检查类

    PHP实现的浏览器检查类

    这篇文章主要介绍了PHP实现的浏览器检查类,结合实例形式详细分析了PHP浏览器操作的相关技巧,非常简单实用,需要的朋友可以参考下
    2016-04-04
  • PHP curl CURLOPT_RETURNTRANSFER参数的作用使用实例

    PHP curl CURLOPT_RETURNTRANSFER参数的作用使用实例

    这篇文章主要介绍了PHP curl CURLOPT_RETURNTRANSFER参数的作用使用实例,CURLOPT_RETURNTRANSFER参数的作用是把CRUL获取的内容赋值到变量,需要的朋友可以参考下
    2015-02-02
  • PHP动态生成指定大小随机图片的方法

    PHP动态生成指定大小随机图片的方法

    这篇文章主要介绍了PHP动态生成指定大小随机图片的方法,涉及PHP根据传入参数动态生成图片的相关技巧,需要的朋友可以参考下
    2016-03-03
  • 利用Dockerfile文件部署php项目的全过程

    利用Dockerfile文件部署php项目的全过程

    环境部署一直是一个很大的问题,无论是开发环境还是生产环境,但是Docker将开发环境和生产环境以轻量级方式打包,提供了一致的环境,下面这篇文章主要给大家介绍了关于利用Dockerfile文件部署php项目的相关资料,需要的朋友可以参考下
    2022-07-07
  • PHP应用代码复杂度检测使用方法

    PHP应用代码复杂度检测使用方法

    这篇文章主要为大家介绍了PHP应用代码复杂度检测使用方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-06-06

最新评论