本文整理匯總了PHP中Flight::where方法的典型用法代碼示例。如果您正苦於以下問題:PHP Flight::where方法的具體用法?PHP Flight::where怎麽用?PHP Flight::where使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Flight
的用法示例。
在下文中一共展示了Flight::where方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: calculate_position
public function calculate_position($timestamp = 0)
{
/*
Metoda zwraca id lotniska, w którym znajduje lub będzie się znajdował samolot w danym czasie (timestamp).
Pozycja 0 oznacza, że samolot jest w powietrzu.
*/
if ($timestamp == 0) {
$timestamp = time();
}
$flights = Flight::where('airplane_id', $this->id)->get();
foreach ($flights as $flight) {
$departure_timestamp = strtotime($flight->departure_time);
$arrival_timestamp = strtotime($flight->arrival_time);
if ($departure_timestamp < $timestamp and $timestamp < $arrival_timestamp) {
//Ten lot właśnie trwa
return false;
//samolot w powietrzu
}
}
//Samolot nie jest w powietrzu, sprawdzamy więc lotnisko na którym obecnie stoi
$last_flight = Flight::where('airplane_id', $this->id)->where('departure_time', '<', date('Y-m-d H:i:s', $timestamp))->orderBy('departure_time', 'desc')->first();
if (!$last_flight) {
//Ten samolot nigdy nie leciał, wiec stoi w bazie, wiec zwracamy lotnisko-bazę
return $this->airline->headquarter;
} else {
return $last_flight->destination;
}
//dd($last_flight);
}
示例2: account
public function account()
{
//Spaghetti code!!!
//TODO: Refactor this method (move all logic from controller to models!!!)
$arrived_and_not_accounted_flights = Flight::where('arrival_time', '<', DB::raw('UTC_TIMESTAMP()'))->where('accounted', 0)->get();
$accounted = 0;
//TODO: Improve tickets cost, based on real flight prices:
// http://www.pasazer.com/news/7538/raport,ile,naprawde,kosztuje,lot.html
foreach ($arrived_and_not_accounted_flights as $flight) {
$fuel_price_litre = 1.18;
$fuel = -1 * ((strtotime($flight->arrival_time) - strtotime($flight->departure_time)) / 3600 * $flight->airplane->model->fuel_usage * $fuel_price_litre);
$taxes = 0;
echo $flight;
foreach ($flight->airline->deals as $deal) {
if ($deal->pivot->airport_id == $flight->origin_airport_id || $deal->pivot->airport_id == $flight->destination_airport_id) {
$taxes -= $deal->pivot->operation_fee;
$taxes -= $deal->pivot->passenger_fee * ($flight->passengers_economy + $flight->passengers_buissnes + $flight->passengers_firstclass);
}
}
echo 'TAXES: ' . $taxes . '$<hr>';
//MVC violation!!! Move this to View
$tickets = round(($flight->passengers_economy * 0.26 + $flight->passengers_buissnes * 0.86 + $flight->passengers_firstclass * 1.59) * $flight->distance);
$bilance = $tickets + $fuel + $taxes;
DB::table('airlines')->where('id', $flight->airline_id)->increment('funds', $bilance);
//Repository Pattern violation!!!
App::make('FinanceOperationsController')->create($flight->airline_id, 'flight', $bilance);
$flight->bilance_tickets = $tickets;
$flight->bilance_fuel = $fuel;
$flight->bilance_taxes = $taxes;
$flight->accounted = 1;
$flight->save();
$accounted++;
}
return $accounted . ' flights accounted.';
}
示例3: index
function index()
{
$q = trim(Input::get('q'));
if (empty($q) || !Input::has('q')) {
return Redirect::home();
}
if (!Input::has('guess') || Input::get('guess') != 'no') {
$regex = array('pilot' => '[0-9]+', 'airport' => '[A-Z0-9]{4}', 'airline' => '[A-Z0-9]{3}', 'airportIata' => '[A-Z0-9]{3}', 'citypair' => '([A-Z0-9]{3,4})(?:(?:\\s*?[-|>]\\s*?)|\\s+to\\s+|\\s+)([A-Z0-9]{3,4})', 'callsign' => '.*');
$search = new Search($q);
foreach ($regex as $type => $pattern) {
if (preg_match('/^' . $pattern . '$/i', $q, $matches) && ($match = $search->quick($type, $matches))) {
Messages::info('You were redirected here by a best guess of the search system. <a href="' . URL::route('search', array('q' => $q, 'guess' => 'no')) . '" class="alert-link">Return to search results.</a>');
return $match;
}
}
}
$pilots = Pilot::where(function ($search) use($q) {
$search->where('vatsim_id', '=', $q);
$search->orWhere(function ($name) use($q) {
$name->where('name', 'LIKE', '%' . $q . '%');
$name->where('anonymous', '=', false);
});
})->where('vatsim_id', '!=', 0)->get();
$flights = Flight::where('callsign', '=', $q)->orderBy('departure_time', 'desc')->get();
$airlines = Airline::where('icao', '=', $q)->orWhere('name', 'LIKE', '%' . $q . '%')->get();
$airports = Airport::where('icao', '=', $q)->orWhere('iata', '=', $q)->orWhere('name', 'LIKE', '%' . $q . '%')->orWhere('city', 'LIKE', '%' . $q . '%')->get();
$this->autoRender(compact('q', 'flights', 'pilots', 'airlines', 'airports'), 'Search');
}
示例4: fire
function fire($job, $data)
{
Log::info('queue:legacy[' . $job->getJobId() . '] - started airline ' . $data['airline']);
$running = Cache::get('legacy.airlines.' . $data['airline'], false);
if ($running != $job->getJobId() && $running !== false) {
Log::info('queue:legacy[' . $job->getJobId() . '] - already running ' . $data['airline']);
Cache::forget('legacy.airlines.' . $data['airline']);
$job->delete();
return;
} else {
Cache::forever('legacy.airlines.' . $data['airline'], $job->getJobId());
}
$flights = Flight::where('callsign', 'LIKE', $data['airline'] . '%')->whereState(2)->whereProcessed(false)->take($this->take)->get();
$totalFlights = $flights->count();
Log::info('queue:legacy[' . $job->getJobId() . '] - selected flights ' . $totalFlights);
if ($flights->count() == 0) {
Log::info('queue:legacy[' . $job->getJobId() . '] - no more flights for ' . $data['airline']);
$airline = Airline::whereIcao($data['airline'])->first();
$airline->duration = $airline->flights()->whereState(2)->sum('duration');
$airline->save();
return $this->finishJob($job, $data['airline']);
}
$job->delete();
if ($job->attempts() > 1) {
return;
}
DB::statement("create temporary table if not exists flights_temp (\n\t\t\t`id` int(10) unsigned NOT NULL,\n\t\t\t`callsign_type` tinyint(1) NOT NULL DEFAULT '0',\n\t\t\t`airline_id` varchar(10) COLLATE utf8_unicode_ci DEFAULT NULL,\n\t\t\t`duration` smallint(6) NOT NULL DEFAULT '0',\n\t\t\t`distance` smallint(6) NOT NULL DEFAULT '0',\n\t\t\tPRIMARY KEY (`id`)\n\t\t)");
Log::info('queue:legacy[' . $job->getJobId() . '] - created temp table');
foreach ($flights as $i => $flight) {
$callsign = str_replace('-', '', strtoupper($flight->callsign));
if (preg_match('/^' . $data['airline'] . '[0-9]{1,5}[A-Z]{0,2}$/', $flight->callsign)) {
// Airline
$flight->isAirline($data['airline']);
} elseif (!is_null($registration = $this->getRegistrations($callsign))) {
$flight->isPrivate($registration->country_id);
unset($registration);
} else {
$flight->airline_id = null;
}
if (!is_null($flight->departure_time) && !is_null($flight->arrival_time)) {
$duration = $this->duration($flight->departure_time, $flight->arrival_time);
$flight->duration = $duration;
unset($duration);
}
// $distance = 0;
// foreach($flight->positions as $key => $position) {
// if($key > 0) $distance += $this->distance($position->lat, $position->lon, $previous->lat, $previous->lon);
// $previous = $position;
// }
// $flight->distance = $distance;
// $flight->processed = true;
// $flight->save();
$newFlights[] = array('id' => $flight->id, 'callsign_type' => $flight->callsign_type, 'airline_id' => $flight->airline_id, 'duration' => $flight->duration, 'distance' => $flight->distance);
unset($flight, $i, $newFlight);
}
Log::info('queue:legacy[' . $job->getJobId() . '] - processed flights');
unset($flights);
$remaining = count($newFlights);
$step = 0;
do {
Log::info('queue:legacy[' . $job->getJobId() . '] - inserted flights - ' . $remaining);
DB::table('flights_temp')->insert(array_slice($newFlights, 100 * $step, 100));
$remaining -= 100;
$step++;
} while ($remaining > 0);
Log::info('queue:legacy[' . $job->getJobId() . '] - inserted flights - done');
DB::statement("update flights dest, flights_temp src set\n\t\t\tdest.callsign_type = src.callsign_type,\n\t\t\tdest.airline_id = src.airline_id,\n\t\t\tdest.duration = src.duration,\n\t\t\tdest.processed = 2\n\t\twhere dest.id = src.id\n\t\t");
Log::info('queue:legacy[' . $job->getJobId() . '] - updated flights');
Log::info('queue:legacy[' . $job->getJobId() . '] - finished airline ' . $data['airline']);
Cache::forget('legacy.airlines.' . $data['airline']);
}
示例5: pilots
/**
* Processes the flights in the datafeed, both new and existing
* in the database. As well as any flights in the database that
* have not arrived yet but are missing from the datafeed.
*
* @return void
*/
protected function pilots()
{
$this->elevations();
// First we will select all flights from the database which
// have not yet been marked as arrived and are not missing.
$database = Flight::where('state', '!=', '2')->get();
$insert = array();
$update = array();
$default = array('route' => '', 'remarks' => '', 'altitude' => '', 'speed' => '', 'flighttype' => 'I', 'last_lat' => '0', 'last_lon' => '0', 'last_altitude' => '0', 'last_speed' => '0', 'last_heading' => '0', 'missing' => '0', 'startdate' => date('Y-m-d'), 'revision' => '0', 'callsign' => '', 'callsign_type' => '0', 'airline_id' => null, 'vatsim_id' => '', 'aircraft_code' => '', 'aircraft_id' => null, 'departure_id' => '', 'arrival_id' => '', 'state' => '4', 'departure_time' => null, 'arrival_time' => null, 'departure_country_id' => '', 'arrival_country_id' => '', 'created_at' => Carbon::now(), 'updated_at' => Carbon::now());
foreach ($this->pilots as $entry) {
try {
// Find the flight in the data we fetched using the callsign
// and vatsim id of the pilot. If the flight does not exist
// in the database we will create a new one.
$flightKey = null;
$flight = $database->first(function ($key, $flight) use($entry, &$flightKey) {
if (str_replace('-', '', $flight->callsign) == str_replace('-', '', $entry['callsign']) && $flight->vatsim_id == $entry['cid']) {
$flightKey = $key;
return true;
}
return false;
}, new Flight());
// Some data will have to be refreshed with every update of
// the datafeed. Pilots have the ability to update the route,
// remarks, altitude and speed at all times using a new flight plan.
$flight->route = $entry['planned_route'];
$flight->remarks = $entry['planned_remarks'];
$flight->altitude = $entry['planned_altitude'];
$flight->speed = $entry['planned_tascruise'];
$flight->flighttype = $entry['planned_flighttype'];
// Update last known coordinates
$flight->last_lat = $entry['latitude'];
$flight->last_lon = $entry['longitude'];
$flight->last_altitude = $entry['altitude'];
$flight->last_speed = $entry['groundspeed'];
$flight->last_heading = $entry['heading'];
// We also need to ensure that the flight is not marked as missing,
// now that we have a record of the flight again.
$flight->missing = 0;
// If the flight does not exist we need to load the basic
// data, such as date, pilot, callsign, aircraft, etc.
if (!$flight->exists) {
$flight->startdate = Carbon::createFromFormat('YmdHis', $entry['time_logon'], 'UTC')->toDateString();
$flight->revision = $entry['planned_revision'];
$callsign = $this->callsign($entry['callsign']);
$flight->callsign = $callsign['callsign'];
$flight->callsign_type = $callsign['callsign_type'];
$flight->airline_id = $callsign['airline_id'];
$flight->vatsim_id = $entry['cid'];
$flight->aircraft_code = $entry['planned_aircraft'];
$flight->aircraft_id = $this->aircraft($entry['planned_aircraft']);
$flight->departure_id = $entry['planned_depairport'];
$flight->arrival_id = $entry['planned_destairport'];
$flight->state = 4;
$this->vatsimUser($entry['cid']);
try {
if ($entry['planned_deptime'] > 0 && $entry['planned_deptime'] < 2359 && !empty($entry['planned_deptime'])) {
$date = $flight->startdate;
list($hour, $minute) = str_split(str_pad($entry['planned_deptime'], 4, '0', STR_PAD_LEFT), 2);
$flight->departure_time = Carbon::createFromFormat('Y-m-d H:i', $date . ' ' . $hour . ':' . $minute, 'UTC');
}
} catch (InvalidArgumentException $e) {
Log::warning($entry['planned_deptime']);
Log::warning($e);
}
} else {
// Update distance
try {
$flight->distance += acos(sin(deg2rad($flight->getOriginal('last_lat'))) * sin(deg2rad($entry['latitude'])) + cos(deg2rad($flight->getOriginal('last_lat'))) * cos(deg2rad($entry['latitude'])) * cos(deg2rad($flight->getOriginal('last_lon')) - deg2rad($entry['longitude']))) * 6371;
} catch (ErrorException $e) {
Log::debug($e);
}
// Add the position report
$this->positionReport($entry, $flight->id);
// Only allow the departure airport/time to be updated if the
// current state is preparing(4) or departing(0). If done after
// that it's technically too late since they have already departed.
if (in_array($flight->state, [0, 4]) && $entry['planned_deptime'] > 0 && $entry['planned_deptime'] < 2359 && !empty($entry['planned_deptime'])) {
$date = $flight->startdate;
list($hour, $minute) = str_split(str_pad($entry['planned_deptime'], 4, '0', STR_PAD_LEFT), 2);
$flight->departure_time = Carbon::createFromFormat('Y-m-d H:i', $date . ' ' . $hour . ':' . $minute, 'UTC');
}
$flight->departure_id = $entry['planned_depairport'];
$flight->arrival_id = $entry['planned_destairport'];
}
// Update the arrival time to always be the planned flight time
// from the departure time.
if (!is_null($flight->departure_time)) {
$flight->arrival_time = Carbon::instance($flight->departure_time)->addHours($entry['planned_hrsenroute'])->addMinutes($entry['planned_minenroute']);
} else {
$flight->arrival_time = null;
}
// Workflow processes
//.........這裏部分代碼省略.........