nutter-nut / mongodb-sqlquery
Mongodb using SQL style
v1.0.3-beta
2020-06-30 15:45 UTC
Requires
- php: >=7.2.0
- mongodb/mongodb: ^1.6
This package is auto-updated.
Last update: 2024-04-29 04:40:10 UTC
README
Mongodb using SQL style
- Configuraton add setting in config/database.php of laravel
'mongodb' => [
'driver' => 'mongodb',
'host' => env('MONGO_DB_HOST', '127.0.0.1'),
'port' => env('MONGO_MONGO_DB_PORT', 27017),
'database' => env('MONGO_DB_DATABASE', 'marcompany'),
'username' => env('MONGO_MONGO_DB_USERNAME', 'maradmin'),
'password' => env('MONGO_DB_PASSWORD', 'password'),
'options' => [
'database' => env('DB_AUTHENTICATION_DATABASE', 'admin'),
],
],
- Using Laravel for SQL query style example below
- Create Model - using command
php artisan make:model UserDbModel
at laravel root project and insertuse Nantaburi\Mongodb\MongoNativeDriver\Model
on top
- Create Model - using command
use Nantaburi\Mongodb\MongoNativeDriver\Model
class UserDbModel extends Model {
protected $collection = "users" ;
protected $database = "marcompany" ;
}
- Create Laravel controller
- using command
php artisan make:controller --model=Userdatabase
at laravel root project - then edit and insert basic SQL example :
select * from user where username like 'suphacha%' and age > 18 or mooban = 'Pangpoi' ;
- using SQL transform showing below :
- using command
use App\UserDbModel ;
$users= UserDbModel::query()
->where("username" , "like" , "suphacha%" )
->andwhere("age" ,">", 18)
->orwhere("mooban" ,"=" ,"Pangpoi" )
->get() ;
return view('userlist')->with("users",$users) ;
- insert Data to collection
- Model file in app/UserModel.php
<?php
namespace App;
use Nantaburi\Mongodb\MongoNativeDriver\Model as NanModel ;
class UserModel extends NanModel
{
/*
* @override $collection to all stack extends back to -> Class Model -> Class Connection( Using)
*
*/
protected $collection = "users" ;
protected $database = "customer" ;
protected $fillable = [ "username","email","first_name","last_name","password",
"plan","services","server-reference","client-address",
"server-req-time"
];
}
- Controller
- insert prepare code example below
- once field data isn't in fillable member insert will reject and has error
$prepairinsertServices["username"] = $request->input('username') ;
$prepairinsertServices["email"] = $request->input('email') ;
$prepairinsertServices["first_name"] = $request->input('first_name') ;
$prepairinsertServices["last_name"] = $request->input('last_name') ;
$prepairinsertServices["password"] = $request->input('psswd') ;
$prepairinsertServices["plan"] = $request->input('radioplan') ;
$prepairinsertServices["services"] = [ ] ;
// Get data from Check box
if ( null != $request->input('service-ecom') )
array_push ( $prepairinsertServices["services"] ,[ "service-ecom" , $request->input('service-ecom') ]) ;
if ( null != $request->input('service-chat') )
array_push ( $prepairinsertServices['services'], ["service-chat", $request->input('service-chat')]);
if ( null != $request->input('service-email') )
array_push ( $prepairinsertServices['services'],["service-email" , $request->input('service-emai)') ]);
$prepairinsertServices["server-reference"] = $_SERVER['HTTP_REFERER'] ;
$prepairinsertServices["client-address"] = $_SERVER['REMOTE_ADDR'] ;
$prepairinsertServices["server-req-time"] = $_SERVER['REQUEST_TIME'] ;
$resultInsert = UserModel::insert( $prepairinsertServices ) ;
// Handle insert error !
if ( $resultInsert[0] == 0 ) {
return redirect()->back() ->with('alert', $resultInsert[1] );
}else { sleep(1) ; }
$users = UserModel::all() ;
return view('usermanage',compact('users') ) ;
}
- Handle insert error in view
- add script below into your view file.blade.php
<script>
var msg = '{{Session::get('alert')}}';
var exist = '{{Session::has('alert')}}';
if(exist){
alert(msg);
}
</script>