図書館について:
[必須]ライブラリ名は32文字以内に制御しなければならない、英語はすべて小文字。
[必須]ライブラリ名形式:ビジネスシステムの名称_サブシステム名はshulanプレフィックスをお勧めしません。
[必須]ライブラリ名のみで、文字、数字、アンダースコア、および英語の手紙。
明示的にデータベースの文字セットを指定する必要があります作成するために、[強制]、およびのみUTF8文字セットまたはutf8mb4をすることができます。データベースのSQLの例を作成します。データベースDB1のデフォルト・キャラクタ・セットUTF8を作成します。
[案]一時的なライブラリ、テーブル名
tmp_
接頭辞と接尾辞日に、テーブルへのバックアップリポジトリとしてbak_
現在までの接頭辞と接尾辞として。鄭州3人の不妊の病院ます。http://mobile.zzfkyy120.com/
表について
テーブル名と列名は、32文字以内に制御されなければならない[必須]、テーブル名のみ、すべて小文字の文字、数字、アンダースコアを使用することができます。
[必須]モジュール名テーブル名は強い相関モジュールは、統一された接頭辞を使用するために、同じテーブル名を使用していますが必要です。
あなたは[力へ]テーブルを作成するときは、明示的にUTF8またはutf8mb4に文字セットを指定する必要があります。
[列名](などの種類、順序、など)のキーワードを強制しようとしないでください。
[強制]とき表は、明示的に特別な必要がある場合は、すべてのInnoDBのために、テーブルを作成するために、ストレージエンジンのタイプを指定する必要があります。
コメントを持っている必要がありますテーブルを構築するために、[強制]。http://www.chacha8.cn/detail/1132398236.html
テーブルを変更し、大きなテーブルの行のために100W以上に[強制]、それはDBAによってレビュー、およびビジネス・ピーク期間を実行する必要があり、より一緒に変更する必要があります。
テーブルはすべてのテーブルを作成するための期間をブロックし、ロックを持っていますので、テーブルを変更し、ビジネスのための抜本的な影響を与える可能性があります。[テーブルの主キーに関する勧告は、建物場合:テーブルは、主キー有していなければならない
(1)主キー必須ID、int型またはBIGINTを、符号なし符号なしAUTO_INCREMENTを使用することが推奨されます。(2)それが等USER_ID、ORDER_ID、などの他の分野に推奨され、主キーを設定しない、ユニークなキーのインデックスを確立するために、メインテーブルのフィールドの各行を識別する。
それは主キーとして提供され、マスターキーがランダムに挿入された場合、ページのInnoDB内部分割及びランダムI / O、性能劣化の多数を引き起こすであろう。(ユーザテーブルなど)提案中のコアテーブルは問題に見やすいデータと最終更新時間フィールドUPDATE_TIMEの時間フィールドCREATE_TIME列を作成しておく必要があります。
必要に応じて[案]テーブル可能な限りすべてのフィールドがNULL属性ではありません、DEFAULTのビジネス価値を定義することができます。
各行は、追加の記憶空間、データ移行エラープローン、集約関数の変動、および他の計算を占めるため、NULL値が存在することになるからです。中間結果セットを保持するために使用されるテーブルの[提案中ミドルネームがなければならない
tmp_
から始まります。バックアップ用またはソーステーブル名のスナップショットをつかむバックアップの表は、しなければならないbak_
で始まります。バックアップテーブルの真ん中とテーブルは定期的に掃除しました。[デモンストレーション] table文のより標準化建設:
CREATE TABLE user_info (
`id` int unsigned NOT NULL AUTO_INCREMENT COMMENT '自增主键',
`user_id` bigint(11) NOT NULL COMMENT '用户id',
`username` varchar(45) NOT NULL COMMENT '真实姓名',
`email` varchar(30) NOT NULL COMMENT '用户邮箱',
`nickname` varchar(45) NOT NULL COMMENT '昵称',
`birthday` date NOT NULL COMMENT '生日',
`sex` tinyint(4) DEFAULT '0' COMMENT '性别',
`short_introduce` varchar(150) DEFAULT NULL COMMENT '一句话介绍自己,最多50个汉字',
`user_resume` varchar(300) NOT NULL COMMENT '用户提交的简历存放地址',
`user_register_ip` int NOT NULL COMMENT '用户注册时的源ip',
`create_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`update_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '修改时间',
`user_review_status` tinyint NOT NULL COMMENT '用户资料审核状态,1为通过,2为审核中,3为未通过,4为还未提交审核',
PRIMARY KEY (`id`),
UNIQUE KEY `uniq_user_id` (`user_id`),
KEY `idx_username`(`username`),
KEY `idx_create_time_status`(`create_time`,`user_review_status`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='网站用户基本信息'
インデックスについて
[]のInnoDBテーブルには主キーのid int型/ BIGINTのAUTO_INCREMENTを強制する必要があり、更新主キーが禁止されています。
[必須]のInnoDBとMyISAMストレージエンジンのテーブル、インデックス・タイプはBTREEでなければなりません。
主キーの[案]名前
pk_
初めにのみキーuniq_
またはuk_
で冒頭に、一般的な指標idx_
始まり、常に接尾辞として名前または省略形フィールドに小文字を使用しています。[単一のテーブルのインデックス番号に関する提言が8を超えることはできません。
インデックスの[提案]が、関節インデックスフィールドの前面に区別の最高度の確立を検討します。カラムをUSERID分化選択数(異なるユーザーID)の程度から計算することができます。
マルチテーブルにSQLをジョイン[提案]、インデックス駆動テーブル上の保証は、列に参加するので、最高の効率を結合します。
【建议】建表或加索引时,保证表里互相不存在冗余索引。
对于MySQL来说,如果表里已经存在key(a,b),则key(a)为冗余索引,需要删除。
SQL编写
【强制】程序端SELECT语句必须指定具体字段名称,禁止写成 *。
【强制】程序端insert语句指定具体字段名称,不要写成insert into t1 values(…)。
【强制】除静态表或小表(100行以内),DML语句必须有where条件,且使用索引查找。
【强制】where条件里等号左右字段类型必须一致,否则无法利用索引。
【强制】WHERE 子句中禁止只使用全模糊的LIKE条件进行查找,必须有其他等值或范围查询条件,否则无法利用索引。
【强制】索引列不要使用函数或表达式,否则无法利用索引。如where length(name)=’Admin’或where user_id+2=10023。
【建议】insert into…values(XX),(XX),(XX).. 这里XX的值不要超过5000个。
值过多虽然上线很很快,但会引起主从同步延迟。【建议】SELECT语句不要使用UNION,推荐使用UNION ALL,并且UNION子句个数限制在5个以内。 郑州看不孕不育哪家好:http://yyk.39.net/zz3/zonghe/1d427.html
因为union all不需要去重,节省数据库资源,提高性能。【强制】禁止跨db的join语句。
【建议】不建议使用子查询,建议将子查询SQL拆开结合程序多次查询,或使用join来代替子查询。
【建议】线上环境,多表join不要超过5个表。
【建议】在多表join中,尽量选取结果集较小的表作为驱动表,来join其他表。
【建议】批量操作数据时,需要控制事务处理间隔时间,进行必要的sleep。
建议】事务里包含SQL不超过5个
因为过长的事务会导致锁数据较久,MySQL内部缓存、连接消耗过多等问题。【建议】事务里更新语句尽量基于主键或unique key,如update … where id=XX;
否则会产生间隙锁,内部扩大锁定范围,导致系统性能下降,产生死锁。【建议】减少使用order by,和业务沟通能不排序就不排序,或将排序放到程序端去做。Order by、group by、distinct这些语句较为耗费CPU,数据库的CPU资源是极其宝贵的。
【建议】order by、group by、distinct这些SQL尽量利用索引直接检索出排序好的数据。如where a=1 order by b可以利用key(a,b)。
【建议】包含了order by、group by、distinct这些查询的语句,where条件过滤出来的结果集请保持在1000行以内,否则SQL会很慢。