启动:net start mySql;
& Q0 l# o9 U5 o$ ?( m 进入:mysql -u root -p/mysql -h localhost -u root -p databaseName;
7 z' G6 \7 [7 ? 列出数据库:show databases;
& N0 j8 F0 q. d 选择数据库:use databaseName;! O3 i" j/ Y0 c0 w0 U" Q: w
列出表格:show tables;
5 M0 x) b- r$ V* `' Y; A H 显示表格列的属性:show columns from tableName;
% @) R- {$ d- e% l @+ c4 t 建立数据库:source fileName.txt;5 b2 U- r: Y5 ]0 m( e* K0 d6 [, q/ I) o
匹配字符:可以用通配符_代表任何一个字符,%代表任何字符串;5 O4 |6 W7 w$ Y( w4 s2 R
增加一个字段:alter table tabelName add column fieldName dateType; k, e0 H' A( T: g; t% n, o
增加多个字段:alter table tabelName add column fieldName1 dateType,add columns fieldName2 dateType;
& F7 Z# G' [' [8 W* f 多行命令输入:注意不能将单词断开;当插入或更改数据时,不能将字段的字符串展开到多行里,否则硬回车将被储存到数据中;% ?0 D8 x: I+ M
增加一个管理员帐户:grant all on *.* to user@localhost identified by "password";
% k# p$ x8 h: w1 n+ L5 ~ 每条语句输入完毕后要在末尾填加分号';',或者填加'\g'也可以;
' e/ s2 N) c5 H S. M; \ 查询时间:select now();
- N# v2 m$ c6 n+ z# T+ j; _: U. P- o 查询当前用户:select user();5 @. Z& `. i& |# `
查询数据库版本:select version();
] u7 m, [2 l8 j: g 查询当前使用的数据库:select database();
' N- S; I/ C& V6 A9 e, E- g 8 S% Y' N0 x7 u# y& g1 T1 L$ ~: s
1、删除student_course数据库中的students数据表: d5 ^% i# p7 A* ~$ o* g; G
rm -f student_course/students.*$ y" T/ g% F9 c/ A& O$ G8 z$ I- K9 S
6 Z4 ?: X) H1 f" \$ B
2、备份数据库:(将数据库test备份), z% K2 v9 {: S4 h: i0 z' ^
mysqldump -u root -p test>c:\test.txt
+ I- Z5 d0 Z9 L. w# C 备份表格:(备份test数据库下的mytable表格); Z) X: M, F; T
mysqldump -u root -p test mytable>c:\test.txt
2 f9 _* B2 @* p 将备份数据导入到数据库:(导回test数据库)2 e [; O- q9 u: L# ^/ r$ X4 Q: `
mysql -u root -p test<c:\test.txt6 ~% x( P/ r: _6 S
0 [: B3 x9 J; Z" v
3、创建临时表:(建立临时表zengchao)
) @+ j% R/ |$ z& t create temporary table zengchao(name varchar(10));
: J! W: \, }6 U5 \/ Y) N0 r$ g( o
2 h6 U& J% K O 4、创建表是先判断表是否存在, S5 p) B% A$ S$ _* f
create table if not exists students(……);; H' l6 i9 U' W9 h( \
, F# K. S9 ~- F5 j, [. W 5、从已经有的表中复制表的结构7 Q1 j. R0 l) m8 I# _' G
create table table2 select * from table1 where 1<>1;9 r" T, M( T( g; w* f# T# H
- c& c: s; `. E4 N+ U9 s# W& [ 6、复制表8 g# m" X6 D& Y6 W$ ?3 C" L' l8 h( h
create table table2 select * from table1;
5 I* K/ g6 d8 l9 P8 P
; o }( F2 j* f! U7 T2 `9 K 7、对表重新命名9 x1 Z$ [! m9 H2 N7 H
alter table table1 rename as table2;
* X- E& \4 K" n4 g9 D
( a1 |% W3 y2 X. K$ O7 m8 S 8、修改列的类型
) G+ _1 u$ Y z* L* c$ m4 ? alter table table1 modify id int unsigned;//修改列id的类型为int unsigned
4 Q6 I. U( j: u6 \ alter table table1 change id sid int unsigned;//修改列id的名字为sid,而且把属性修改为int unsigned
! |1 J# t: {2 G8 D+ U
V" q \' @ W 9、创建索引
( g8 u) o+ A0 F8 k& I" u$ u alter table table1 add index ind_id (id);2 M0 I9 q b# Z. u
create index ind_id on table1 (id);
8 o6 o! @0 t$ U( h+ H2 h5 b create unique index ind_id on table1 (id);//建立唯一性索引
- @3 M( t' o9 c* C& A3 l3 I; Z$ S
2 v m8 _; Y1 v4 t 10、删除索引' C: H! D' ]% I1 i) l
drop index idx_id on table1;
- J: E5 z8 I. s* I alter table table1 drop index ind_id;
' p; Y& J! E- E8 `( c# U+ D
+ k) F' c4 C0 Z0 i 11、联合字符或者多个列(将列id与":"和列name和"="连接)4 [" T7 H+ a3 W8 p
select concat(id,':',name,'=') from students;2 M7 D) T9 E, H, T+ C$ B
9 V: w, _( c1 ]/ N
12、limit(选出10到20条)<第一个记录集的编号是0>
* R# l& X7 b3 ]! u9 P. S8 M6 k$ O select * from students order by id limit 9,10;" z* A5 t3 B5 R; ~; Y( E& J
/ S& q0 m+ Z4 Z- e- T# R 13、MySQL不支持的功能6 M/ Y0 k3 W- T4 t, R8 l
事务,视图,外键和引用完整性,存储过程和触发器: I6 O9 O0 S, J. g
3 n9 S, ]) {( F7 |3 \" [% e8 O
9 Y4 d4 r+ O" T; M- }" r* j: B) o3 S) j
14、MySQL会使用索引的操作符号
" v9 o i4 g0 ~ <,<=,>=,>,=,between,in,不带%或者_开头的like
% z7 Z( K5 T0 E# N& s
* {# ~- z; `4 V1 m% M8 @) r- b 15、使用索引的缺点
2 O9 ~0 H( u% k3 v 1)减慢增删改数据的速度;
& ^! _" E, Y0 | 2)占用磁盘空间;
2 L3 Q8 [( v. G6 z7 }8 Z, n 3)增加查询优化器的负担;
% f& c( N# g7 w h 当查询优化器生成执行计划时,会考虑索引,太多的索引会给查询优化器增加工作量,导致无法选择最优的查询方案;" f" v7 x# A" O
% O; j# d5 Y3 g( S: U/ ^$ V$ j 16、分析索引效率* D) L- V5 D! y- Q# Z
方法:在一般的SQL语句前加上explain;2 T7 |# r5 g, j* |- D3 R
分析结果的含义:
' Y( Q0 ]( } q* Y- `2 B, p7 @* o 1)table:表名;& U; r$ L4 [3 d# [0 v3 K5 I% K5 {
2)type:连接的类型,(ALL/Range/Ref)。其中ref是最理想的;& m5 |. _+ q6 Y# m7 d; ?7 p) i
3)possible_keys:查询可以利用的索引名; u) I% h" m7 i, e* k1 E
4)key:实际使用的索引;4 [% t9 S: @6 q0 E6 M4 I
5)key_len:索引中被使用部分的长度(字节);
7 G1 `; G' _1 C0 E- P5 N 6)ref:显示列名字或者"const"(不明白什么意思);$ M7 N7 p }5 A# V/ d/ ?/ j
7)rows:显示MySQL认为在找到正确结果之前必须扫描的行数;
" z$ D5 M1 w; \7 ] 8)extra:MySQL的建议;" w/ O4 e! }; K& D9 w" x% S
8 P |/ r$ c% P3 j* I C9 A9 j& I1 o 17、使用较短的定长列/ Z' ]- J, O6 C: E0 x
1)尽可能使用较短的数据类型;' @4 @( F7 A9 W! c8 p2 t
2)尽可能使用定长数据类型;( u* D8 D) Y5 q# G
a)用char代替varchar,固定长度的数据处理比变长的快些;2 X, B9 H9 t& d
b)对于频繁修改的表,磁盘容易形成碎片,从而影响数据库的整体性能;
6 h0 S/ E9 ^" U! J1 h: a% h c)万一出现数据表崩溃,使用固定长度数据行的表更容易重新构造。使用固定长度的数据行,每个记录的开始位置都是固定记录长度的倍数,可以很容易被检测到,但是使用可变长度的数据行就不一定了;
/ Q( U5 K/ U- i+ v) S6 F d)对于MyISAM类型的数据表,虽然转换成固定长度的数据列可以提高性能,但是占据的空间也大;4 {- d. W4 A2 O
( |0 x+ T5 Q! Q& @
18、使用not null和enum n( m* h" j9 x% n/ e; i- l
尽量将列定义为not null,这样可使数据的出来更快,所需的空间更少,而且在查询时,MySQL不需要检查是否存在特例,即null值,从而优化查询;8 H/ I( @# M/ R: d! v0 s
如果一列只含有有限数目的特定值,如性别,是否有效或者入学年份等,在这种情况下应该考虑将其转换为enum列的值,MySQL处理的更快,因为所有的enum值在系统内都是以标识数值来表示的;
% N& z4 o+ j# w8 r: ^ , `7 C0 u& L$ x+ O7 N
19、使用optimize table
; {% \& g* w) @' }3 ~$ l" r 对于经常修改的表,容易产生碎片,使在查询数据库时必须读取更多的磁盘块,降低查询性能。具有可变长的表都存在磁盘碎片问题,这个问题对blob数据类型更为突出,因为其尺寸变化非常大。可以通过使用optimize table来整理碎片,保证数据库性能不下降,优化那些受碎片影响的数据表。 optimize table可以用于MyISAM和BDB类型的数据表。实际上任何碎片整理方法都是用mysqldump来转存数据表,然后使用转存后的文件并重新建数据表;7 ]- ~( `0 r: U2 c* s7 |8 W
1 x! w# Z/ P9 ]8 z7 V }. } 20、使用procedure analyse()& y9 ~/ {% ?0 s
可以使用procedure analyse()显示最佳类型的建议,使用很简单,在select语句后面加上procedure analyse()就可以了;例如:
9 P+ o! e' _7 P1 G9 j select * from students procedure analyse();5 E. ^, ]. e8 n* H0 Q6 [
select * from students procedure analyse(16,256);
3 M3 a* ^$ l$ o* [4 j8 B2 T 第二条语句要求procedure analyse()不要建议含有多于16个值,或者含有多于256字节的enum类型,如果没有限制,输出可能会很长;8 t6 X; x) a6 R
" `. [: b2 G' o5 ] 21、使用查询缓存7 @4 ]( w# j% E b2 w; I" ?0 R5 y
1)查询缓存的工作方式:- Y2 f1 G* e2 U2 L- z4 r
第一次执行某条select语句时,服务器记住该查询的文本内容和查询结果,存储在缓存中,下次碰到这个语句时,直接从缓存中返回结果;当更新数据表后,该数据表的任何缓存查询都变成无效的,并且会被丢弃。3 \" w. b3 }( }
2)配置缓存参数:
" d- ?/ I6 P6 B7 s 变量:query_cache _type,查询缓存的操作模式。有3中模式,0:不缓存;1:缓存查询,除非与select sql_no_cache开头;2:根据需要只缓存那些以select sql_cache开头的查询;query_cache_size:设置查询缓存的最大结果集的大小,比这个值大的不会被缓存。
U4 z9 o8 h7 S( x7 E) `
# a7 H2 |/ J& g. \3 H2 ^ 22、调整硬件8 R' v' _: n$ \2 R
1)在机器上装更多的内存;$ C0 x9 }7 v* S1 h! y$ o
2)增加更快的硬盘以减少I/O等待时间;
$ o5 i. x9 ?/ q 寻道时间是决定性能的主要因素,逐字地移动磁头是最慢的,一旦磁头定位,从磁道读则很快;5 f" {' S/ L5 T2 N1 R# H
3)在不同的物理硬盘设备上重新分配磁盘活动;& @2 v* w% h/ y& g
如果可能,应将最繁忙的数据库存放在不同的物理设备上,这跟使用同一物理设备的不同分区是不同的,因为它们将争用相同的物理资源(磁头)。
% H4 W' R3 k( P* m/ L |