1 一、连接数据库 2 格式:mysql -h主机地址 -u用户名 -p用户密码 3 1.1.连接到本机上的MYSQL。 4 首先打开DOS窗口,然后进入目录mysqlin,再键入命令mysql -u root -p,回车后提示你输密码. 5 注意用户名前可以有空格也可以没有空格,但是密码前必须没有空格,否则让你重新输入密码。 6 如果刚安装好MYSQL,超级用户root是没有密码的,故直接回车即可进入到MYSQL中了,MYSQL的提示符是: mysql> 7 8 1.2连接到远程主机上的MYSQL。 9 10 假设远程主机的IP为:110.110.110.110,用户名为root,密码为abcd123。则键入以下命令: 11 mysql -h110.110.110.110 -u root -p 123;(注:u与root之间可以不用加空格,其它也一样) 12 1.3退出MYSQL命令: exit (回车) 13 14 二、增加用户 15 格式:grant select on 数据库.* to 用户名@登录主机 identified by “密码” 16 2.1 增加一个用户test1密码为abc,让他可以在任何主机上登录,并对所有数据库有查询、插入、修改、删除的权限。 17 18 首先用root用户连入MYSQL,然后键入以下命令: 19 20 复制代码 代码如下: 21 grant select,insert,update,delete on *.* to [email=test1@”%]test1@”%[/email]” Identified by “abc”; 22 但增加的用户是十分危险的,你想如某个人知道test1的密码,那么他就可以在internet上的任何一台电脑上登录你的mysql数据库并对你的数据可以为所欲为了,解决办法见2.2。 23 2.2增加一个用户test2密码为abc,让他只可以在localhost上登录,并可以对数据库mydb进行查询、插入、修改、删除的操作(localhost指本地主机,即MYSQL数据库所在的那台主机),这样用户即使用知道test2的密码,他也无法从internet上直接访问数据库,只能通过MYSQL主机上的web页来访问。 24 25 复制代码 代码如下: 26 grant select,insert,update,delete on mydb.* to [email=test2@localhost]test2@localhost[/email] identified by “abc”; 27 28 如果你不想test2有密码,可以再打一个命令将密码消掉。 29 复制代码 代码如下: 30 grant select,insert,update,delete on mydb.* to [email=test2@localhost]test2@localhost[/email] identified by “” 31 三、操作数据库 32 33 3.1创建数据库 34 注意:创建数据库之前要先连接Mysql服务器 35 命令:create database <数据库名> 36 例1:建立一个名为xhkdb的数据库 37 38 39 复制代码 代码如下: 40 mysql> create database xhkdb; 41 例2:创建数据库并分配用户 42 ①CREATE DATABASE 数据库名; 43 ②GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP,ALTER ON 数据库名.* TO 用户名@localhost IDENTIFIED BY '密码'; 44 ③SET PASSWORD FOR '数据库名'@'localhost' = OLD_PASSWORD('密码'); 45 依次执行3个命令完成数据库创建。 46 注意:中文 “密码”和“数据库”是户自己需要设置的。 47 48 3.2显示数据库 49 命令:show databases (注意:最后有个s) 50 51 复制代码 代码如下: 52 mysql> show databases 53 54 3.3 删除数据库 55 命令:drop database <数据库名> 56 例如:删除名为 xhkdb的数据库 57 复制代码 代码如下: 58 mysql> drop database xhkdb; 59 例子1:删除一个已经确定存在的数据库 60 61 复制代码 代码如下: 62 mysql> drop database drop_database; 63 Query OK, 0 rows affected (0.00 sec) 64 例子2:删除一个不确定存在的数据库 65 66 ? 67 1 68 2 69 3 70 4 71 5 72 6 73 7 74 8 75 9 76 mysql> drop database drop_database; 77 ERROR 1008 (HY000): Can't drop database 'drop_database'; database doesn't exist 78 //发生错误,不能删除'drop_database'数据库,该数据库不存在。 79 mysql> drop database if exists drop_database; 80 Query OK, 0 rows affected, 1 warning (0.00 sec)//产生一个警告说明此数据库不存在 81 mysql> create database drop_database; 82 Query OK, 1 row affected (0.00 sec) 83 mysql> drop database if exists drop_database;//if exists 判断数据库是否存在,不存在也不产生错误 84 Query OK, 0 rows affected (0.00 sec) 85 3.4 连接数据库 86 命令: use <数据库名> 87 例如:如果xhkdb数据库存在,尝试存取它:mysql> use xhkdb; 88 屏幕提示:Database changed 89 use 语句可以通告MySQL把db_name数据库作为默认(当前)数据库使用,用于后续语句。该数据库保持为默认数据库,直到语段的结尾,或者直到发布一个不同的USE语句: 90 91 ? 92 1 93 2 94 3 95 4 96 mysql> USE db1; 97 mysql> SELECT COUNT(*) FROM mytable; # selects from db1.mytable 98 mysql> USE db2; 99 mysql> SELECT COUNT(*) FROM mytable; # selects from db2.mytable 100 使用USE语句为一个特定的当前的数据库做标记,不会阻碍您访问其它数据库中的表。下面的例子可以从db1数据库访问作者表,并从db2数据库访问编辑表: 101 102 ? 103 1 104 2 105 3 106 mysql> USE db1; 107 mysql> SELECT author_name,editor_name FROM author,db2.editor 108 -> WHERE author.editor_id = db2.editor.editor_id; 109 要退出数据库或连接其他数据库直接 user '其他数据库名称'就可以了。 110 111 3.5当前选择数据库 112 命令:mysql> select database(); 113 MySQL中SELECT命令类似于其他编程语言里的print或者write,你可以用它来显示一个字符串、数字、数学表达式的结果等等。如何使用MySQL中SELECT命令的特殊功能? 114 115 (1).显示MYSQL的版本 116 117 ? 118 1 119 2 120 3 121 4 122 5 123 6 124 7 125 mysql> select version(); 126 +-----------------------+ 127 | version() | 128 +-----------------------+ 129 | 6.0.4-alpha-community | 130 +-----------------------+ 131 1 row in set (0.02 sec) 132 (2). 显示当前时间 133 134 ? 135 1 136 2 137 3 138 4 139 5 140 6 141 7 142 mysql> select now(); 143 +---------------------+ 144 | now() | 145 +---------------------+ 146 | 2009-09-15 22:35:32 | 147 +---------------------+ 148 1 row in set (0.04 sec) 149 (3). 显示年月日 150 151 ? 152 1 153 2 154 3 155 4 156 5 157 6 158 7 159 8 160 9 161 10 162 11 163 12 164 13 165 14 166 15 167 16 168 17 169 18 170 19 171 20 172 21 173 22 174 23 175 SELECT DAYOFMONTH(CURRENT_DATE); 176 +--------------------------+ 177 | DAYOFMONTH(CURRENT_DATE) | 178 +--------------------------+ 179 | 15 | 180 +--------------------------+ 181 1 row in set (0.01 sec) 182 183 SELECT MONTH(CURRENT_DATE); 184 +---------------------+ 185 | MONTH(CURRENT_DATE) | 186 +---------------------+ 187 | 9 | 188 +---------------------+ 189 1 row in set (0.00 sec) 190 191 SELECT YEAR(CURRENT_DATE); 192 +--------------------+ 193 | YEAR(CURRENT_DATE) | 194 +--------------------+ 195 | 2009 | 196 +--------------------+ 197 1 row in set (0.00 sec) 198 (4).显示字符串 199 200 ? 201 1 202 2 203 3 204 4 205 5 206 6 207 7 208 mysql> SELECT "welecome to my blog!"; 209 +----------------------+ 210 | welecome to my blog! | 211 +----------------------+ 212 | welecome to my blog! | 213 +----------------------+ 214 1 row in set (0.00 sec) 215 (5).当计算器用 216 217 ? 218 1 219 2 220 3 221 4 222 5 223 6 224 7 225 select ((4 * 4) / 10 ) + 25; 226 +----------------------+ 227 | ((4 * 4) / 10 ) + 25 | 228 +----------------------+ 229 | 26.60 | 230 +----------------------+ 231 1 row in set (0.00 sec) 232 (6).串接字符串 233 234 ? 235 1 236 2 237 3 238 4 239 5 240 6 241 7 242 8 243 9 244 10 245 11 246 12 247 select CONCAT(f_name, " ", l_name) 248 AS Name 249 from employee_data 250 where title = 'Marketing Executive'; 251 +---------------+ 252 | Name | 253 +---------------+ 254 | Monica Sehgal | 255 | Hal Simlai | 256 | Joseph Irvine | 257 +---------------+ 258 3 rows in set (0.00 sec) 259 注意:这里用到CONCAT()函数,用来把字符串串接起来。另外,我们还用到以前学到的AS给结果列'CONCAT(f_name, " ", l_name)'起了个假名 260 261 四、对表的操作 262 4.1创建表 263 命令:create table <表名> ( <字段名1> <类型1> [,..<字段名n> <类型n>]); 264 例如,建立一个名为MyClass的表 265 266 ? 267 1 268 2 269 3 270 4 271 5 272 mysql> create table MyClass( 273 > id int(4) not null primary key auto_increment, 274 > name char(20) not null, 275 > sex int(4) not null default '0', 276 > degree double(16,2)); 277 4.2获取表结构 278 命令: desc 表名,或者show columns from 表名 279 280 ? 281 1 282 2 283 mysql> desc MyClass; 284 mysql> show columns from MyClass; 285 使用MySQL数据库desc 表名时,我们看到Key那一栏,可能会有4种值,即' ','PRI','UNI','MUL'。 286 (1).如果Key是空的, 那么该列值的可以重复, 表示该列没有索引, 或者是一个非唯一的复合索引的非前导列; 287 (2).如果Key是PRI, 那么该列是主键的组成部分; 288 (3).如果Key是UNI, 那么该列是一个唯一值索引的第一列(前导列),并别不能含有空值(NULL); 289 (4).如果Key是MUL, 那么该列的值可以重复, 该列是一个非唯一索引的前导列(第一列)或者是一个唯一性索引的组成部分但是可以含有空值NULL。 290 如果对于一个列的定义,同时满足上述4种情况的多种,比如一个列既是PRI,又是UNI,那么"desc 表名"的时候,显示的Key值按照优先级来显,PRI->UNI->MUL。那么此时,显示PRI。 291 一个唯一性索引列可以显示为PRI,并且该列不能含有空值,同时该表没有主键。 292 一个唯一性索引列可以显示为MUL, 如果多列构成了一个唯一性复合索引,因为虽然索引的多列组合是唯一的,比如ID+NAME是唯一的,但是没一个单独的列依然可以有重复的值,只要ID+NAME是唯一的即可。 293 294 4.3删除表 295 命令:drop table <表名> 296 例如:删除表名为 MyClass 的表 297 298 复制代码 代码如下: 299 mysql> drop table MyClass; 300 DROP TABLE用于取消一个或多个表。您必须有每个表的DROP权限。所有的表数据和表定义会被取消,所以使用本语句要小心! 301 注意:对于一个带分区的表,DROP TABLE会永久性地取消表定义,取消各分区,并取消储存在这些分区中的所有数据。DROP TABLE还会取消与被取消 302 303 的表有关联的分区定义(.par)文件。 304 对与不存在的表,使用IF EXISTS用于防止错误发生。当使用IF EXISTS时,对于每个不存在的表,会生成一个NOTE。 305 RESTRICT和CASCADE可以使分区更容易。目前,RESTRICT和CASCADE不起作用。 306 307 4.4向表插入数据 308 命令:insert into <表名> [( <字段名1>[,..<字段名n > ])] values ( 值1 )[, ( 值n )] 309 例如:往表 MyClass中插入二条记录, 这二条记录表示:编号为1的名为Tom的成绩为96.45, 编号为2 的名为Joan 的成绩为82.99, 编号为3 的名为 310 311 Wang 的成绩为96.5。 312 mysql> insert into MyClass values(1,'Tom',96.45),(2,'Joan',82.99), (2,'Wang', 96.59); 313 注意:insert into每次只能向表中插入一条记录。 314 315 4.5查询表 316 (1)、查询所有行 317 命令: select <字段1,字段2,...> from < 表名 > where < 表达式 > 318 例如:查看表 MyClass 中所有数据 319 mysql> select * from MyClass; 320 (2)、查询前几行数据 321 例如:查看表 MyClass 中前2行数据 322 mysql> select * from MyClass order by id limit 0,2; 323 select一般配合where使用,以查询更精确更复杂的数据。 324 325 4.6删除表 326 命令:delete from 表名 where 表达式 327 例如:删除表 MyClass中编号为1 的记录 328 mysql> delete from MyClass where id=1; 329 330 4.7修改表中的数据 331 语法:update 表名 set 字段=新值,… where 条件 332 mysql> update MyClass set name='Mary' where id=1; 333 334 例子1:单表的MySQL UPDATE语句: 335 336 复制代码 代码如下: 337 UPDATE [LOW_PRIORITY] [IGNORE] tbl_name SET col_name1=expr1 [, col_name2=expr2 ...] [WHERE where_definition] [ORDER BY ...] [LIMIT row_count] 338 339 例子2:多表的UPDATE语句: 340 复制代码 代码如下: 341 UPDATE [LOW_PRIORITY] [IGNORE] table_references SET col_name1=expr1 [, col_name2=expr2 ...] [WHERE where_definition] 342 343 UPDATE语法可以用新值更新原有表行中的各列。SET子句指示要修改哪些列和要给予哪些值。WHERE子句指定应更新哪些行。如果没有WHERE子句,则更新所有的行。如果指定了ORDER BY子句,则按照被指定的顺序对行进行更新。LIMIT子句用于给定一个限值,限制可以被更新的行的数目。 344 4.8增加表字段 345 命令:alter table 表名 add字段 类型 其他; 346 例如:在表MyClass中添加了一个字段passtest,类型为int(4),默认值为0 347 mysql> alter table MyClass add passtest int(4) default '0'[/code] 348 加索引:mysql> alter table 表名 add index 索引名 (字段名1[,字段名2 …]); 349 例子: mysql> alter table employee add index emp_name (name); 350 加主关键字的索引:mysql> alter table 表名 add primary key (字段名); 351 例子: mysql> alter table employee add primary key(id); 352 加唯一限制条件的索引:mysql> alter table 表名 add unique 索引名 (字段名); 353 例子: mysql> alter table employee add unique emp_name2(cardnumber); 354 删除某个索引:mysql> alter table 表名 drop index 索引名; 355 例子: mysql>alter table employee drop index emp_name; 356 增加字段:mysql> ALTER TABLE table_name ADD field_name field_type; 357 修改原字段名称及类型:mysql> ALTER TABLE table_name CHANGE old_field_name new_field_name field_type; 358 修改字段类型:mysql>ALTER TABLE table_name MODIFY colum_name field_type new_type 359 删除字段:MySQL ALTER TABLE table_name DROP field_name; 360 361 4.9修改表名 362 命令:rename table 原表名 to 新表名; 363 例如:在表MyClass名字更改为YouClass 364 365 复制代码 代码如下: 366 mysql> rename table MyClass to YouClass; 367 368 当你执行 RENAME 时,你不能有任何锁定的表或活动的事务。你同样也必须有对原初表的 ALTER 和 DROP 权限,以及对新表的 CREATE 和 INSERT 权限。 369 如果在多表更名中,MySQL 遭遇到任何错误,它将对所有被更名的表进行倒退更名,将每件事物退回到最初状态。 370 RENAME TABLE 在 MySQL 3.23.23 中被加入。 371 五、备份数据 372 373 命令在DOS的[url=file://\mysql\bin]\mysql\bin[/url]目录下执行 374 (1).导出整个数据库 375 导出文件默认是存在mysqlin目录下 376 mysqldump -u 用户名 -p 数据库名 > 导出的文件名 377 mysqldump -u user_name -p123456 database_name > outfile_name.sql 378 (2).导出一个表 379 mysqldump -u 用户名 -p 数据库名 表名> 导出的文件名 380 mysqldump -u user_name -p database_name table_name > outfile_name.sql 381 (3).导出一个数据库结构 382 mysqldump -u user_name -p -d –add-drop-table database_name > outfile_name.sql 383 -d 没有数据 –add-drop-table 在每个create语句之前增加一个drop table 384 (4).带语言参数导出 385 mysqldump -uroot -p –default-character-set=latin1 –set-charset=gbk –skip-opt database_name > outfile_name.sql 386 例如,将aaa库备份到文件back_aaa中: 387 388 复制代码 代码如下: 389 [root@test1 root]# cd /home/data/mysql 390 [root@test1 mysql]# mysqldump -u root -p --opt aaa > back_aaa