以下のように表示されます。
表 a の列 a1 と a2 を加算して新しい列 a を作成し、列 a1 と a2 を乗算して新しい列 b を作成します。注: 除算を行う場合は型変換を行う必要があります。そうしないと結果は 0 になります。
これは 2 つの異なるテーブルの列間の操作です。 補足知識:異なるレコード内の同じ属性列の差を計算するSQL文 使用されるテーブルの具体的な構造は下の図に示すとおりです。 テーブルの主キーは (plateNumber+currentTime) です。 実装するクエリは次のとおりです。 ナンバープレート番号とクエリ時間間隔を指定して、指定された時間間隔に含まれるレコードの currentTime の差をクエリし、AverageSpeed と差の積を計算し、この期間中の最高速度 (HighestSpeed) を見つけて、それを異なるタイプの値に従って分割します。 –>(型値は0と1の2つの値のみを持ちます) 主なアイデアは、まず、指定された時間間隔内で同じ種類の同じナンバープレート番号(つまり、同じ車両)の currentTime の差、たとえば currentTime でソートされた 2 つの隣接するレコードの currentTime の差を取得できることです。これが取得されたら、残りは集計関数を通じて取得できます。 ナンバープレートの番号「京A111111」を例にとり、下の図に示すようにテストケースを設計します。 ナンバープレート番号「京A111111」の車両には6件の記録があり、そのうちタイプ0の記録が2件、タイプ1の記録が4件あることがわかります。 まず時間差を計算し、SQL ステートメントは次のように記述されます。 SELECT a.platenumber、 a.現在の時刻、 a.タイプ、 a.平均速度、 a.最高速度、 現在の時刻 - (現在の時刻を選択 carmultispeedinfoより ここで、プレート番号 = a.プレート番号 AND タイプ = a.type AND 現在の時刻 < a.現在の時刻 ORDER BY 現在の時刻 DESC 制限 1)AS 時間差 carmultispeedinfoより Navicat を使用すると、次の図に示すようにクエリ結果を確認できます。 timediff の値が正しいことを確認してから、それに基づいてコンテンツを追加できます。 完全な SQL ステートメントは次のとおりです。 SELECT Sum(aa.averagespeed * aa.timediff) AS milesdiff、 Max(aa.highestspeed) AS 最高速度、 合計(aa.timediff) AS timediff、 aa.タイプ FROM (SELECT a.platenumber, a.現在の時刻、 a.タイプ、 a.平均速度、 a.最高速度、 現在の時刻 - (現在の時刻を選択 carmultispeedinfoより ここで、プレート番号 = a.プレート番号 AND タイプ = a.type AND 現在の時刻 < a.現在の時刻 ORDER BY 現在の時刻 DESC 制限 1) AS 時間差 carmultispeedinfoより a)aa ここで、aa.platenumber = '京A111111' かつ、aa.currenttime >= 1521790124670 かつ、aa.currenttime <= 1521790125685 GROUP BY aa.type 結果は次のとおりです。 確認後、希望通りの結果が得られました。次に、mybatis マッパー ファイルに対応する SQL を置き換えます。 <記録、メモ> 今後、理解が深まったら更新していきます。皆様、ありがとうございます、参考になれば幸いです、そして123WORDPRESS.COMを応援していただければ幸いです。 以下もご興味があるかもしれません:
|
>>: Windows 10 で Hyper-V サービスをシャットダウンするいくつかの方法
数日前、バスで仕事に行きました。バスのカードリーダーの実際の使用シーンを実際に見て、カードリーダーの...
ミックスインは、コンポーネントに分散された再利用可能な機能を柔軟な方法で提供します。 Mixin オ...
この記事の例では、ショッピングカートの計算を実装するためのjsの具体的なコードを参考までに共有してい...
画像をダウンロード docker プル mysql:5.7 docker pull php:7.2-...
問題の説明MySQL が正常に起動しました。以下に示すように、 ps -ef |grep mysql...
この記事では、React Native の基本をすでに理解していることを前提とし、ネイティブと Ja...
フロントエンドテストページコード: <テンプレート> <div> <i...
この記事では、vueカードスタイルのクリックして切り替える画像コンポーネントを参考までに紹介します。...
この質問は、MySQL の権限に関する WeChat グループのネットユーザー間の議論です。次のよう...
効果効果は以下のとおりです実装のアイデアbox-shadow プロパティを使用して、複数の灰色の円...
【はじめに】: Handtrack.jsは、ブラウザ上で直接リアルタイムの手の動きの追跡と検出を実...
一般的に、データ テーブル内の列を ID 列として設定すると、ID 列の表示値を手動で ID 列に挿...
Tomcatログの関係一枚の写真は千の言葉に値する! localhost.{yyyy-MM-dd}....
Dockerコンテナのマウントディレクトリ情報のみを表示する docker 検査 --format ...
CentOS 8をインストールした後、ネットワークを再起動すると次のエラーが表示されますエラーメッセ...