找回密码
 立即注册
欢迎中测联盟老会员回家,1997年注册的域名
查看: 2130|回复: 0
打印 上一主题 下一主题

mysql常用命令

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-13 16:32:24 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
启动: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
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表