linux / java / mysql / svn / apache / tomcat

Mysql数据库学习

上一篇 / 下一篇  2006-12-31 12:15:05 / 个人分类:Database

转自:http://www.matrix.org.cn/blog/wenic705/archives/001511.htmlLinux宝库[/P/r2X@;\I"W

W BcLhuu0Mysql数据库学习
l#K}rn k-YTz0
F _Z6f.R g\ Y$G{3?M0写程序经常用到,写个接连就完事了,没去好好动过Mysql数据库。Linux宝库#mH-B5l2N+o\
今天有空仔细学习Mysql,做个笔记,自己以后看
7}\ZD&\U0Linux宝库8Fh ^$E)\ @
我是在linix下操作数据库的,window下也差不多,不过在windows有人写好数据库管理软件,下一个窗口化操作很方便。Linux宝库!q9Z*Vp[7?u},[
连接数据库:命令: mysql [host] –u [user] –p 提示密码输入后输入正确密码,OK,登陆进来了。
R/K%eeD@0Linux宝库Mir+},HaU x%g)a,X!f
我事先不清楚这个数据库里有些什么,只好一个一个命令敲了。
$rI9?;Jr1@3h Zx o0
1D8w'ylcS9s*k0查看数据库:命令: show databases 列出数据库服务器上所有数据库;Linux宝库s]$`C*Q:vyH
使用数据库:命令: use [database name] 切换到需要操作的数据库;
F5a?D{~"z0查看表: 命令: show tables 列出该数据库的所有表;
"h0V3P ?J$^ xm0查看表结构:命令:describe [table name] 查看表结构;
LU$[G3X MQ0
EZ5lZ|,KRhv0表结构清楚了,那就可以开始进行操作了。
J^1T#A:D q"z0
H*O2B8x2z'Scs0下面是基础资料:Linux宝库R]V k9b.f#SvF
  (一)字段类型
4b^H [X4];r;vg0  1.INT[(M)]
B;@m8P+fV+x0Linux宝库+lh'jDG
  正常大小整数类型Linux宝库p |.V)hbZ`_
  2.DOUBLE[(M,D)] [ZEROFILL]Linux宝库*Y:p+p5bB ~}w
  正常大小(双精密)浮点数字类型
9h$@NM$I1[L$Ay0  3.DATE
f1I2i%RF0  日期类型。支持的范围是'1000-01-01'到'9999-12-31'。MySQL以'YYYY-MM-DD'格式来显示DATE值,但是允许你使用字符串或数字把值赋给  DATE列
`%W \J R{l2L0  4.CHAR(M)Linux宝库&kQv(lf/O/fJ1H/[@(\
  定长字符串类型,当存储时,总是是用空格填满右边到指定的长度Linux宝库5y9{ Ou6W/_
  5.BLOB TEXT   BLOB或TEXT类型,最大长度为65535(2^16-1)个字符。Linux宝库IFr i:b ^z:C
  6.VARCHAR  变长字符串类型,最常用的类型。
x&u.cL9NNS5{@1U0  (二)基本操作
r!hJ,}Ut0  1:显示数据库
|q@ kS2D0   mysql>SHOW DATABASES;
C;z$a;q t0  2:当前选择的数据库,
$?!jD gV'j)b{-~0   mysql> SELECT DATABASE();
;ke yl6@?'^0   +------------+Linux宝库rg`5kF&S s
   | DATABASE() |
AMS9v,]2@)i0   +------------+
T+i8S g`9Jm0   | test |
#tS.qcL?2PF0   +------------+
c(?-Q#{A2k/{$bhC0  3.当前数据库包含的表信息:Linux宝库 kT)BNUBI)US R']
   mysql> SHOW TABLES;Linux宝库 SD)E X3R%@7N
   +---------------------+Linux宝库*KQvH G:D
   | Tables in test |
fw0A Er{2|sk7B0   +---------------------+Linux宝库d"qhL5y\
   | mytable1 |Linux宝库IU*~Qyl
   | mytable2 |Linux宝库w(r ` cwPy9k
   +---------------------+Linux宝库 D V.W,Gr3ULAaH
  4.获取表结构Linux宝库*rY"`WD\&V
   mysql> desc mytable1;
]o_nV0   +---------+-------------+------+-----+---------+-------+
C-w\!L f3uT1I0   | Field | Type | Null | Key | Default | Extra |Linux宝库"h5v5wzH~Zt
   +---------+-------------+------+-----+---------+-------+
q2Q"LH u1Zd"?0   | s1 | varchar(20) | YES | | NULL | |
^,I`8n](n4ny0   +---------+-------------+------+-----+---------+-------+
e?bH6h0t`9F P0  5.创建表Linux宝库g8ew2LCgO1x
  表是数据库的最基本元素之一,表与表之间可以相互独立,也可以相互关联。创建表的基本语法如下:
&u8q ^S1_+v9C8Z/q P0   create table table_nameLinux宝库J,y+r I"Ko
   (column_name datatype {identity |null|not null},Linux宝库xe(wk^ y {P4B
   …)Linux宝库JU m(nj-N0f _.q
  其中参数table_name和column_name必须满足用户数据库中的识别器(identifier)的要求,参数datatype是一个标准的SQL类型或由用户数  据库提供的类型。用户要使用non-null从句为各字段输入数据。Linux宝库FS x1O ^.c.h [
  create table还有一些其他选项,如创建临时表和使用select子句从其他的表中读取某些字段组成新表等。还有,在创建表是可用PRIMARY   KEY、KEY、INDEX等标识符设定某些字段为主键或索引等。书写上要注意:在一对圆括号里的列出完整的字段清单。字段名间用逗号隔开  。字段名间的逗号后要加一个空格。最后一个字段名后不用逗号。所有的SQL陈述都以分号";"结束。
"cfoj|M!a%i0  例:
v.Zt8Rm x"P7G7C Cl0   mysql>CREATE TABLE guest (name varchar(10),sex varchar(2),age int(3),career varchar(10));
6}[1`*Y8|DJ0  6.创建索引
0Lw ~N&gC0  索引用于对数据库的查询。一般数据库建有多种索引方案,每种方案都精于某一特定的查询类。索引可以加速对数据库的查询过程。创建  索引的基本语法如下:Linux宝库 d b7Z9N~*t%R
   create index index_nameLinux宝库x_6s;~dCm&w0Gbr
   on table_name (col_name[(length)],... )
pnn:zambGFx0  例:
Aw#Y m.L\D0   mysql> CREATE INDEX number ON guest (number(10));Linux宝库b0Bo-S@j3]
  7.执行查询
K5l9kS"sYi*Z0  查询是使用最多的SQL命令。查询数据库需要凭借结构、索引和字段类型等因素。大多数数据库含有一个优化器(optimizer),把用户的查  询语句转换成可选的形式,以提高查询效率。
xv&LZ,N5t^0  值得注意的是MySQL不支持SQL92标准的嵌套的where子句,即它只支持一个where子句。其基本语法如下:
/gR$cF;g4J9w0   SELECT [STRAIGHT_JOIN] [SQL_SMALL_RESULT] [SQL_BIG_RESULT] [HIGH_PRIORITY]Linux宝库 D.}T&g7S
   [DISTINCT | DISTINCTROW | ALL]Linux宝库/o\ H je
   select_expression,...
X3v/ES^0   [INTO {OUTFILE | DUMPFILE} 'file_name' export_options]Linux宝库u(`z \ k.pE#Jf
   [FROM table_references
_I]8q*w{:k},t K0   [WHERE where_definition]Linux宝库?mL?)[ag:F5D|
   [GROUP BY col_name,...]Linux宝库PW;x;M1m
   [HAVING where_definition]Linux宝库5D:x5]k SA!h*Z~8pBX"f
   [ORDER BY {unsigned_integer | col_name | formula} [ASC | DESC] ,...]Linux宝库5Y-e v [5m,sh
   [LIMIT [offset,] rows] //分页Linux宝库S qx"O6[;{9[5@%G
   [PROCEDURE procedure_name] ]
y ]R \UE(H ^0  其中where从句是定义选择标准的地方,where_definition可以有不同的格式,但都遵循下面的形式:Linux宝库V;fc1r^v;}
  字段名操作表达式Linux宝库sj4y;Ep0hw&e
  字段名操作字段名
Ge~7X4aXr!{/\0  在第一种形式下,标准把字段的值与表达式进行比较;在第二种形式下,把两个字段的值进行比较。根据所比较的数据类型,       search_condition中的操作可能选以下几种:Linux宝库)oYRd%h%U9FdfA
   =检查是否相等
?*Sso'b5t UZ9Z0   !=检查是否不等Linux宝库/l"fkSG6X
   > (或>=)检查左边值是否大于(或大于等于)右边值
Qj:wnAB1H0   < (或<=)检查左边值是否小于(或小于等于)右边值Linux宝库HC c2F~3^&T
   [not] between检查左边值是否在某个范围内
Cbpj;X e/Z.D0   [not] in检查左边是否某个特定集的成员
ugKrkVK_0   [not] like检查左边是否为右边的子串
Q X:~1pIa["b0   is [not] null检查左边是否为空值Linux宝库'v@d5c.Q/m-s
  在这里,可以用通配符_代表任何一个字符,%代表任何字符串。使用关键字、和可以生成复杂的词,它们运行检查时使用  布尔表达式的多重标准集。Linux宝库-_ F;v5KN+o
  例:Linux宝库A0\of([h
   mysql> select t1.name, t2.salary from employee AS t1, info AS t2swherest1.name = t2.name;
[ ^t\ij*u2_0   mysql> select college, region, seed from tournamentLinux宝库yqEOS'P:IEj
   ORDER BY region, seed;
7B{h-s&G0   mysql> select col_name from tbl_nameswherescol_name > 0;
*?-h8n"L4wD!_\;g0  8.改变表结构
,rfL8p'? CsZ0  在数据库的使用过程中,有时需要改变它的表结构,包括改变字段名,甚至改变不同数据库字段间的关系。可以实现上述改变的命令是   alter,其基本语法如下:
)~$Eh)NE?7k0  alter table table_name alter_spec [, alter_spec ...]Linux宝库 b2K m8n*^X
  例:
[C!k'dR;Hq0   mysql> alter table dbname add column userid int(11) not null primary key auto_increment;Linux宝库f3@?-S{,|OG
  这样,就在表dbname中添加了一个字段userid,类型为int(11)。Linux宝库2WIVi_-n ?D$}2N(b;u
  9.修改表中数据Linux宝库h([^z"DXW Ac
  在使用数据库过程中,往往要修改其表中的数据,比如往表中添加新数据,删除表中原有数据,或对表中原有数据进行更改。它们的基本  语法如下:
1wd,lQk;`V0  数据添加:
)J!X#di}0   insert [into] table_name [(column(s))]
e9cdU0yI0   values (expression(s))
't1w2y` i aJ0  例:
~:w`k AvI#WTz0   mysql>insert into mydatabase values('php','mysql','asp','sqlserver','jsp','oracle');
'B4S.T0HQu010.表的数据更新Linux宝库 i[ ou0\B;wNP*I
  (1)一次修改一个字段,再次注意语法。文本需要加引号但数字不要。Linux宝库7s8}![o5c)U)fss
   mysql>update table01 set field03='new info' where field01=‘1’;
i e FZ.uuT!w'i l$J)_0
8Ec9W,{m:I m0   Query OK, 1 row affected (0.00 sec)Linux宝库 ? l Oh"Ux!x*d
  (2)一次改变多个字段,记住在每一个更新的字段间用逗号隔开。
KAmzA%LGA0   mysql>update table01 set field04=19991022, field05=062218 where field01=1;
q&A ntnH5]6kf6Ju B}0   Query OK, 1 row affected (0.00 sec)Linux宝库;cY-Z p:v|;r
  (3)一次更新多个数据Linux宝库k+Ol c#T+q3yE
   mysql>update table01 set field05=152901 where field04>19990101;
1sjcr4EJ0   Query OK, 3 rows affected (0.00 sec)Linux宝库GRd4} C GU
  11.删除数据
.v@#}$?"ggl0   mysql>delete from table01 where field01=3;
$p5On9[ d\m|r H0   Query OK, 1 row affected (0.00 sec)
} L8E6d7i#H/S0  12.导入数据库表
WZLv_CI#F*G;i0   (1)创建.sql文件
de/O)p1z9Us3D0   (2)先产生一个库如auction.c:mysql in>mysqladmin -u root -p creat auction,会提示输入密码,然后成功创建。Linux宝库V2K{B+G3[
   (3)导入auction.sql文件
d$r0|H(YtE0    c:mysql in>mysql -u root -p auction < auction.sql。
g0r S8t}Q6Gd0   通过以上操作,就可以创建了一个数据库auction以及其中的一个表auction。
9l"Ir3i3CJ(g0  13.mysql数据库的授权Linux宝库`hKE5XpuD.s
   mysql>grant select,insert,delete,create,drop
'C@x?(~gm2\5up1s0   on *.* (或test.*/user.*/..)
"~ ZPV5w\N9O OM0   to用户名@localhost
"MY:T`X#n"c}2|@0   identified by '密码';Linux宝库vx{@-f;R
  如:新建一个用户帐号以便可以访问数据库,需要进行如下操作:
YOR2K3z0   mysql> grant usageLinux宝库3d:BP{ pQUag/u
   -> ON test.*
QAtX}n0   -> TO testuser@localhost;
)aLI&q3Hh0   Query OK, 0 rows affected (0.15 sec)
Ukd;eK3[%a2E+sS0  此后就创建了一个新用户叫:testuser,这个用户只能从localhost连接到数据库并可以连接到test数据库。下一步,我们必须指定     testuser这个用户可以执行哪些操作:
2{~"CWB0   mysql> GRANT select, insert, delete,updateLinux宝库r3A.M5UTg]
   -> ON test.*Linux宝库'A M^"r*M6p-}
   -> TO testuser@localhost;Linux宝库#]K{S5x[8WQ R
   Query OK, 0 rows affected (0.00 sec)
;F*S xl-@0  此操作使testuser能够在每一个test数据库中的表执行SELECT,INSERT和DELETE以及UPDATE查询操作。现在我们结束操作并退出MySQL客户  程序:
c_+J.faM!S0   mysql> exit
Fx]m7W {;J0   ByeLinux宝库-R o^P0mz
  14.授权MySQL用户密码Linux宝库"R8x:Y R&U+O!U
  MySQL数据库的默认用户名为"root"(MS SQL Server的sa相似),密码默认为空。在DOS提示符(注意,不是mysql提示符)下输入Linux宝库XMFa%b)Hu
  c:mysql in>"mysqladmin -u root -p password newpasswordLinux宝库"UvV$m2wg
  回车后会提示你输入原来的密码,由于原来密码为空,直接回车,root用户的密码便改为"newpassword"了。Linux宝库G:W2zj d
为了找出包含正好5个字符的名字,使用“_”模式字符: //这个还是比较有意思的
PToI4qs"h0mysql> SELECT * FROM pet WHERE name LIKE "_____";Linux宝库#x:yO;s3N:X
12、备份和恢复Linux宝库D'^ bOd&n4qX'z D
备份数据库staffer
a&zj['O0\ Kc0c:mysqlbinmysqldump -uroot -proot staffer>e:staffer.sqlLinux宝库I:^(W`5dV
得到的staffer.sql是一个sql脚本,不包括建库的语句,所以你需要手工
p[ eB_e:k0创建数据库才可以导入Linux宝库@T n5FNY
恢复数据库staffer,需要创建一个空库stafferLinux宝库%`mI8`)g'mQ+y
c:mysqlbinmysql -uroot -proot stafferLinux宝库~#[.j5f5P/c0[
如果不希望后来手工创建staffer,可以
k:Q(w(w L+U/]T&tW0c:mysqlbinmysqldump -uroot -proot --databases staffer>e:staffer.sqlLinux宝库 x%y\m@] e
mysql -uroot -proot >e:staffer.sqlLinux宝库+?2V&o"d%f.x
但这样的话系统种就不能存在staffer库,且无法导入其他名字的数据库, 当然你可以手工修改staffer.sql文件Linux宝库*R0S:n%S;R @o+o6L
13、从文本向数据库导入数据Linux宝库0~.J8AOb1s!y
1)使用工具c:mysqlbinmysqlimport
hh9Z2u(dE^9lV0这个工具的作用是将文件导入到和去掉文件扩展名名字相同的表里,如
c`HX:k)`F0staffer.txt,staffer都是导入到staffer表中
+T2a9w7EjQ0常用选项及功能如下Linux宝库:?vW*V&r
-d or --delete 新数据导入数据表中之前删除数据数据表中的所有信息Linux宝库eu \!Rsj
-f or --force 不管是否遇到错误,mysqlimport将强制继续插入数据Linux宝库,yO)r;?r
-i or --ignore mysqlimport跳过或者忽略那些有相同唯一Linux宝库"C1y%y8om2S[c
关键字的行, 导入文件中的数据将被忽略。
V1wV-^+}~6OPi$c0-l or -lock-tables 数据被插入之前锁住表,这样就防止了,Linux宝库+b%A{xw)X8a
你在更新数据库时,用户的查询和更新受到影响。Linux宝库5dD*WLp
-r or -replace 这个选项与-i选项的作用相反;此选项将替代表中有相同唯一关键字的记录。
gW i mT1}qR|-`-~%I0--fields-enclosed- by= charLinux宝库.x0l1a%BTn@t F(?
指定文本文件中数据的记录时以什么括起的, 很多情况下 数据以双引号括起。 默认的情况下数据是没有被字符括起的。Linux宝库A!| \KhZ#q[
--fields-terminated- by=char
GI$Hgt y*E0指定各个数据的值之间的分隔符,在句号分隔的文件中, 分隔符是句号。您可以用此选项指定数据之间的分隔符。Linux宝库d6`)SP*zL
默认的分隔符是跳格符(Tab)
-F(H$s6\zlN n.w+w*j0--lines-terminated- by=str
:Z `R"o|g!K0此选项指定文本文件中行与行之间数据的分隔字符串或者字符。 默认的情况下mysqlimport以newline为行分隔符。
uZY]'@!{ \8Is0您可以选择用一个字符串来替代一个单个的字符:Linux宝库o-b K G5{ u0NK
一个新行或者一个回车。
3u&vrOIbG0mysqlimport命令常用的选项还有-v 显示版本(version),Linux宝库G&A X$c1M5yS8_,ay
-p 提示输入密码(password)等。Linux宝库`HaC*et8FE
这个工具有个问题,无法忽略某些列,这样对我们的数据导入有很大的麻烦,虽然可以手工设置这个字段,但会出现莫名其妙的结果,我们做一个简单的示例
t3|)\:j7[!]}aV0我们定义如下的depart_no.txt,保存在e盘,间隔为制表符tLinux宝库FB:s},dVN
10 10
i7T3^9@V011 11
ox m"\3WH012 24
cV,t8QnJt$A%P0执行如下命令Linux宝库0LA{] M qO
c:mysqlbinmysqlimport -uroot -proot staffer e:depart_pos.txt
d1d Azb0在这里没有使用列的包围符号,分割采用默认的t,因为采用别的符号会有问题,不知道是不是windows的原因
f%eE w}!G \'J NJ(v02)Load Data INFILE file_name into table_name(column1_name,column2_name)Linux宝库+smr(lyM H
这个命令在mysql>提示符下使用,优点是可以指定列导入,示例如下Linux宝库;f Pv7mY
c:mysqlbinmysql -uroot -proot stafferLinux宝库Z2^E@2D q-\%Z
mysql>load data infile "e:/depart_no.txt" into depart_no(department_id,position_id);Linux宝库 kG$f#cn{nY'M;TG!Zu

#\ `;bYZL*X0这两个工具在Windows下使用都有问题,不知道是Windows的原因还是中文的问题, 而且不指定的列它产生了空值,这显然不是我们想要的,所以谨慎使用这些工具
7w8{FksY#Y0Linux宝库z }:FO C:a.J7B*[ F2H
Linux宝库)xM7Dz0n _ ?IJ*g8v
上面的资料从网上收集起来的,对于mysql的管理比较详细了。

TAG: java mysql 数据库 databases

 

评分:0

我来说两句

显示全部

:loveliness: :handshake :victory: :funk: :time: :kiss: :call: :hug: :lol :'( :Q :L ;P :$ :P :o :@ :D :( :)

日历

« 2008-08-28  
     12
3456789
10111213141516
17181920212223
24252627282930
31      

数据统计

  • 访问量: 9272
  • 日志数: 14
  • 图片数: 5
  • 商品数: 6
  • 建立时间: 2006-09-21
  • 更新时间: 2007-11-02

RSS订阅

Open Toolbar