ホームページ >データベース >mysql チュートリアル >Meituan インタビュー: MySQL を使用しているときに遭遇した落とし穴は何ですか?
インタビュアー: あなたはまだ鍵をよく理解していますね。
新人の私: (答えを表現するためにわずかに微笑みながら)
インタビュアー: MySQL を何年も使ってきましたが、決して忘れられない落とし穴は何ですか。
新人の私: バラバラが話し始めます (面接前にこの種の面接の質問を用意してあるので、水をかけておきます)
以下は私の実戦に基づいています経験 データベース開発の標準化された使用法をいくつかまとめ、6 つの「回避
」でまとめました。
「やってはいけない」という格言があります。つま先を滑らせてください 物事を考えること、それがナオグアジの責任です
」という言葉をデータベース開発で使用すると、データベースに苦手なことをさせないようにすることを意味します。 MySQL
は数学的な演算や論理的な判断が苦手なので、データベース内での演算は避け、複雑な演算はプログラム側の CPU に移すことができます。
かつて、同僚から SQL ステートメントを見てほしいと頼まれたことがあります。 . フロントでのクエリは速いと言われていますが、SQLを取り出してデータベースで実行すると10分実行しても結果が出ません。 SQL を確認した後、最終的にビュー内のサブクエリを見つけました。このサブクエリの SQL テキストは次のとおりです:
## 以下SQL来源于网络 SELECT acinv_07.id_item , SUM(acinv_07.dec_endqty) dec_endqty FROM acinv_07 WHERE acinv_07.fiscal_year * 100 + acinv_07.fiscal_period = ( SELECT DISTINCT ctlm1101.fiscal_year * 100 + ctlm1101.fiscal_period FROM ctlm1101 WHERE flag_curr = 'Y' AND id_oprcode = 'acinv' AND acinv_07.id_wh = ctlm1101.id_table) GROUP BY acinv_07.id_item
acinv_07 テーブルの列 fical_year と列 fical_period にはインデックスが付けられます。ただし、インデックス列に対して操作が実行されると、インデックスを作成できたはずの列に対してインデックスを使用できなくなります。そこで、SQL
## 以下SQL来源于网络 SELECT id_item , SUM(dec_qty) dec_qty FROM dpurreq_03 GROUP BY id_item ) a , ( SELECT a.id_item , SUM(a.dec_endqty) dec_endqty FROM acinv_07 a , ( SELECT DISTINCT ctlm1101.fiscal_year , ctlm1101.fiscal_period , id_table FROM ctlm1101 WHERE flag_curr = 'Y' AND id_oprcode = 'acinv' ) b WHERE a.fiscal_year = b.fiscal_year AND a.fiscal_period = b.fiscal_period AND a.id_wh = b.id_table GROUP BY a.id_item
に書き換えて実行すると、4 秒ほどで結果が得られます。一般に、SQL を作成するときは、絶対に必要な場合を除き、インデックス列に対して計算を実行しないでください。
ページング クエリを実行するとき、常に Select count(# を使用する人がいます) ##) はレコードの総数を取得します。実際、これは効率的なアプローチではありません。なぜなら、クエリはデータを取得するときに一度実行されており、select count() は同じステートメントによるクエリと同等だからです。 2 回実行すると、当然データベースのオーバーヘッドが大きくなりますので、データベースに付属する API やシステム変数を使用してこの作業を完了する必要があります。
NOT NULL デフォルト '。 NULL フィールドを使用すると、クエリの最適化が困難になる、NULL 列にインデックスを追加するには追加のスペースが必要になる、NULL を含む複合インデックスが無効になるなど、多くの悪影響が生じます。
次のケースを見てください:
数据初始化: create table table1 ( `id` INT (11) NOT NULL, `name` varchar(20) NOT NULL ) create table table2 ( `id` INT (11) NOT NULL, `name` varchar(20) ) insert into table1 values (4,"tianweichang"),(2,"zhangsan"),(3,"lisi") insert into table2 values (1,"tianweichang"),(2, null)(1) NOT IN サブクエリは、NULL 値がある場合に常に空の結果を返し、クエリはエラーを起こしやすいです
select name from table1 where name not in (select name from table2 where id!=1)
select * from table2 where name != 'tianweichang'concat
を使用してスプライスする場合、各フィールドは最初に null でないと判断する必要があります。そうでない場合、いずれかのフィールドが空である限り、スプライシング結果は null## になります。 #
select concat("1", null) from dual;
(4) 当计算count时候,name为null 的不会计入统计
select count(name) from table2;
select *
可能会返回不使用的列的数据。它在MySQL
数据库服务器和应用程序之间产生不必要的I/O磁盘和网络流量。select *
并且有人通过添加更多列来更改表格数据时,将会得到一个与预期不同的结果集。select *
可能会将敏感信息暴露给未经授权的用户。图片确实是可以存储到数据库里的,例如通过二进制流将图片存到数据库中。
但是,强烈不建议把图片存储到数据库中!!!!首先对数据库的读/写的速度永远都赶不上文件系统处理的速度,其次数据库备份变的巨大,越来越耗时间,最后对文件的访问需要穿越你的应用层和数据库层。
以上がMeituan インタビュー: MySQL を使用しているときに遭遇した落とし穴は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。