mysqlクエリ文のユーザー変数の使用コード解析
前の記事ではMySQL最適化のまとめ-全体の数を調べるを紹介しました。この記事では、ユーザー変数のコード解析を利用したクエリー文の他の知識を紹介します。
まずコードをかけましょう
ユーザー名量の設定はset var valueによっても以上の形式で@var:=valを使用することができます。
mysqlの中でifの使用はif(exp 1,exp 2,exp 3)ifの中でexp 1がtrueであればexp 2を実行します。
今以上のコードを見れば簡単に多いかもしれません。上記のコードに基づいて、私はまた自分で簡単なアプリケーションの実例を書き直しました。
締め括りをつける
以上がmysqlクエリ文のユーザー変数の使用コード解析のすべての内容です。興味のある方は引き続き当駅を参照してください。MySQLにおけるor文の使い方例、MySQLデータタイプDECIMAL(N,M)のNとMがそれぞれ表している意味を詳しく説明します。など、何か問題があったらいつでもメッセージを残してください。友達のサポートに感謝します。
まずコードをかけましょう
SELECT `notice`.`id` , `notice`.`fid` , `notice`.`has_read` , `notice`.`notice_time` , `notice`.`read_time` , `f`.`fnum` , `f`.`forg` , `f`.`fdst` , `f`.`actual_parking` AS `parking` , `f`.`scheduled_deptime` , `f`.`estimated_deptime` , `f`.`actual_deptime` , `f`.`scheduled_arrtime` , `f`.`estimated_arrtime` , `f`.`actual_arrtime` , `f`.`is_vip` , `f`.`aoc_notice`
FROM (
select
t.id,
t.fid,
t.has_read,
t.notice_time,
t.read_time
from
(
select
a.id,
a.fid,
a.has_read,
a.notice_time,
a.read_time,
@v_rownum := @v_rownum+1,
if(@v_fid=a.fid,@v_rowid:=@v_rowid+1,@v_rowid:=1 ) as row_count,
@v_fid:=a.fid
from
(
SELECT
id,
fid,
has_read,
notice_time,
read_time
FROM vkm_user_notice_flight
where `notice_type` = 'process_update' and uid=82
order by fid, notice_time desc
) a,
(
select @v_rownum:=0, @v_rowid:=0, @v_fid:=null
) b
) t
where t.row_count =1
) AS `notice`
LEFT JOIN `vkm_flight` AS `f` ON `notice`.`fid` = `f`.`id`
LEFT JOIN `vkm_parking` AS `parking` ON `f`.`actual_parking` = `parking`.`parking_num`
仕事中に友達からこんなsql文が来ました。最初から隠していました。全然分かりませんでした。個人のmysqlもあまり詳しくないので、簡単な添削しかできません。実は、以上のコードは直接的な書き方です。
SELECT `notice`.`id` , `notice`.`fid` , `notice`.`has_read` , `notice`.`notice_time` , `notice`.`read_time` , `f`.`fnum` , `f`.`forg` , `f`.`fdst` , `f`.`actual_parking` AS `parking` , `f`.`scheduled_deptime` , `f`.`estimated_deptime` , `f`.`actual_deptime` , `f`.`scheduled_arrtime` , `f`.`estimated_arrtime` , `f`.`actual_arrtime` , `f`.`is_vip` , `f`.`aoc_notice`
FROM `notice` LEFT JOIN `vkm_flight` AS `f` ON `notice`.`fid` = `f`.`id` LEFT JOIN `vkm_parking` AS `parking` ON `f`.`actual_parking` = `parking`.`parking_num`
しかし、上記のコードの検索効率は本当に違います。具体的に上のコードはまだ分かりません。指導もお願いします。でも、インターネットを利用してください。一つはmysqlの中のifの使用です。もう一つはmysqlの中のユーザー変数の使用です。ユーザー名量の設定はset var valueによっても以上の形式で@var:=valを使用することができます。
mysqlの中でifの使用はif(exp 1,exp 2,exp 3)ifの中でexp 1がtrueであればexp 2を実行します。
今以上のコードを見れば簡単に多いかもしれません。上記のコードに基づいて、私はまた自分で簡単なアプリケーションの実例を書き直しました。
select id,fnum,forg,fdst,@v_rownum:=@v_rownum+1 from vkm_flight,(select @v_rownum:=0) b
これで帰ってきました。rownumの値締め括りをつける
以上がmysqlクエリ文のユーザー変数の使用コード解析のすべての内容です。興味のある方は引き続き当駅を参照してください。MySQLにおけるor文の使い方例、MySQLデータタイプDECIMAL(N,M)のNとMがそれぞれ表している意味を詳しく説明します。など、何か問題があったらいつでもメッセージを残してください。友達のサポートに感謝します。