- 使用
selectRaw或者DB::raw函数查询时,如果当前数据库是忽略大小写的,一律返回小写字段名,
修改部分适配 Laravel
- 适配 InsertGetId,当表主键非 id 时,需要指定主键列名
- 修复 DmBuilder 中 DmAutoIncrementHelper 引用
- 适配 withCount, 主要是 x_table as y 情况 前缀补充,原包,没有在 y 前面追加前缀,和 Laravel 不兼容
- 适配 cast json ,数组参数转 json 入库
- 兼容 mysql group_concat 函数,内部转化为 wm_concat 函数
- 修复表单验证中 exists 和 unique,去除对 getCount 和 getMultiCount 的重写。原包是对 oracle 进行大小写不敏感设置,但是达梦数据库不支持
- 修复自动递增,匹配 laravel migration。原包中将 migration 中的 int 和 bigint 均转化为 number 无法使 auto_increment 生效
Laravel-DM8 is an Dm Database Driver package for Laravel. Laravel-DM8 is an extension of Illuminate/Database that uses DM8 extension to communicate with Dm. Thanks to @yajra.
- You will find user-friendly and updated documentation here: Laravel-DM8 Docs
- All about dm and php:The Underground PHP and Dm Manual
| Laravel | Package | 
|---|---|
| 5.1.x | 5.1.x | 
| 5.2.x | 5.2.x | 
| 5.3.x | 5.3.x | 
| 5.4.x | 5.4.x | 
| 5.5.x | 5.5.x | 
| 5.6.x | 5.6.x | 
| 5.7.x | 5.7.x | 
| 5.8.x | 5.8.x | 
| 6.x.x | 6.x.x | 
| 7.x.x | 7.x.x | 
| 8.x.x | 8.x.x | 
| 9.x.x | 9.x.x | 
composer require maxlcoder/laravel-dm8Once Composer has installed or updated your packages you need to register Laravel-DM8. Open up config/app.php and find the providers key and add:
LaravelDm8\\Dm8\\Dm8ServiceProvider::class,Finally you can optionally publish a configuration file by running the following Artisan command.
If config file is not publish, the package will automatically use what is declared on your .env file database configuration.
php artisan vendor:publish --tag=dmThis will copy the configuration file to config/dm.php.
Then, you can set connection data in your
.envfiles:
DB_CONNECTION=dm
DB_HOST=dm.host
DB_PORT=5236
DB_DATABASE=xe
DB_USERNAME=hr
DB_PASSWORD=hr
DB_CHARSET=UTF8Then run your laravel installation...
The MIT License (MIT). Please see License File for more information.