数据库
1. 连接Mysql
连接Mysql:格式: mysql -h主机地址 -u用户名 -p用户密码
键入命令mysql -u root -p,回车后提示你输密码
2. 退出Mysql
exit回车
3.显示数据库
命令:mysql> show databases;
4. 创建数据库
命令:create database <数据库名>
例:建立一个名为newdatabase的数据库 mysql> create database newdatabase;
5. 删除数据库
命令:drop database <数据库名>例如:删除名为newdatabase的数据库mysql> drop database newdatabase;
6.连接数据库
命令: use <数据库名>
例如:如果newdatabase数据库存在,尝试存取它: mysql> use newdatabase;屏幕提示:Database changed
use 语句可以通告MySQL把db_name数据库作为默认(当前)数据库使用,用于后续语句。该数据库保持为默认数据库,直到语段的结尾,或者直到发布一个不同的USE语句:
使用USE语句为一个特定的当前的数据库做标记,不会阻碍您访问其它数据库中的表。下面的例子可以从db1数据库访问作者表,并从db2数据库访问编辑表:
7.当前选择的数据库
数据表
-
创建数据表
命令:create table <表名> ( <字段名1> <类型1> [,..<字段名n> <类型n>]);
例如,建立一个名为MyClass的表,
mysql> create table MyClass(> id int(4) not null,> name char(20) not null,> sex int(4) not null default '0',> degree double(16,2));
-
删除数据表
-
查询表中数据
1)、查询所有行命令: select <字段1,字段2,...> from < 表名 > where < 表达式 >例如:查看表 MyClass 中所有数据 mysql> select * from MyClass;
2)、查询前几行数据例如:查看表 MyClass 中前2行数据mysql> select * from MyClass order by id limit 0,2;
select一般配合where使用,以查询更精确更复杂的数据。
-
表中插入数据
命令:insert into <表名> [( <字段名1>[,..<字段名n > ])] values ( 值1 )[, ( 值n )]
例如:往表 MyClass中插入二条记录, 这二条记录表示:编号为1的名为Tom的成绩为96.45, 编号为2 的名为Joan 的成绩为82.99, 编号为3 的名为Wang 的成绩为96.5。 mysql> insert into MyClass values(1,'Tom',96.45),(2,'Joan',82.99), (2,'Wang', 96.59);
注意:insert into每次只能向表中插入一条记录。
-
删除表中数据
命令:delete from 表名 where 表达式
例如:删除表 MyClass中编号为1 的记录mysql> delete from MyClass where id=1;
-
修改表中数据
语法:update 表名 set 字段=新值,… where 条件 mysql> update MyClass set name='Mary' where id=1;
例子1:单表的MySQL UPDATE语句: UPDATE LOW_PRIORITY tbl_name SET col_name1=expr1 , col_name2=expr2 ... ORDER BY ...
例子2:多表的UPDATE语句:UPDATE LOW_PRIORITY table_references SET col_name1=expr1 , col_name2=expr2 ...
UPDATE语法可以用新值更新原有表行中的各列。SET子句指示要修改哪些列和要给予哪些值。WHERE子句指定应更新哪些行。如果没有WHERE子句,则更新所有的行。如果指定了ORDER BY子句,则按照被指定的顺序对行进行更新。LIMIT子句用于给定一个限值,限制可以被更新的行的数目。
-
增加字段
命令:alter table 表名 add字段 类型 其他;例如:在表MyClass中添加了一个字段passtest,类型为int(4),默认值为0 mysql> alter table MyClass add passtest int(4) default '0'
加索引 mysql> alter table 表名 add index 索引名 (字段名1[,字段名2 …]);例子: mysql> alter table employee add index emp_name (name);
加主关键字的索引 mysql> alter table 表名 add primary key (字段名);例子: mysql> alter table employee add primary key(id);
加唯一限制条件的索引 mysql> alter table 表名 add unique 索引名 (字段名);例子: mysql> alter table employee add unique emp_name2(cardnumber);
删除某个索引 mysql> alter table 表名 drop index 索引名;例子: mysql>alter table employee drop index emp_name;
增加字段:mysql> ALTER TABLE table_name ADD field_name field_type;
修改原字段名称及类型:mysql> ALTER TABLE table_name CHANGE old_field_name new_field_name field_type;
删除字段:MySQL ALTER TABLE table_name DROP field_name;
-
修改表名
命令:rename table 原表名 to 新表名;
例如:在表MyClass名字更改为YouClass mysql> rename table MyClass to YouClass;
当你执行 RENAME 时,你不能有任何锁定的表或活动的事务。你同样也必须有对原初表的 ALTER 和 DROP 权限,以及对新表的 CREATE 和 INSERT 权限。
如果在多表更名中,MySQL 遭遇到任何错误,它将对所有被更名的表进行倒退更名,将每件事物退回到最初状态。
RENAME TABLE 在 MySQL 3.23.23 中被加入。
-
备份数据
命令在DOS的[url=file://mysqlin]mysqlin[/url]目录下执行
1.导出整个数据库导出文件默认是存在mysqlin目录下
mysqldump -u 用户名 -p 数据库名 > 导出的文件名mysqldump -u user_name -p123456 database_name > outfile_name.sql
2.导出一个表
mysqldump -u 用户名 -p 数据库名 表名> 导出的文件名mysqldump -u user_name -p database_name table_name > outfile_name.sql
3.导出一个数据库结构
mysqldump -u user_name -p -d –add-drop-table database_name > outfile_name.sql-d 没有数据 –add-drop-table 在每个create语句之前增加一个drop table
4.带语言参数导出
mysqldump -uroot -p –default-character-set=latin1 –set-charset=gbk –skip-opt database_name > outfile_name.sql
例如,将aaa库备份到文件back_aaa中: [root@test1 root]# cd /home/data/mysql [root@test1 mysql]# mysqldump -u root -p --opt aaa > back_aaa
-
实例1
drop database if exists school; //如果存在SCHOOL则删除create database school; //建立库SCHOOLuse school; //打开库SCHOOLcreate table teacher //建立表TEACHER( id int(3) auto_increment not null primary key, name char(10) not null, address varchar(50) default ‘深圳’, year date); //建表结束
//以下为插入字段
insert into teacher values(”,’allen’,'大连一中’,'1976-10-10′);insert into teacher values(”,’jack’,'大连二中’,'1975-12-23′);
如果你在mysql提示符键入上面的命令也可以,但不方便调试。1、你可以将以上命令原样写入一个文本文件中,假设为school.sql,然后复制到c:下,并在DOS状态进入目录[url=file://mysqlin]mysqlin[/url],然后键入以下命令:
mysql -uroot -p密码 < c:\school.sql
如果成功,空出一行无任何显示;如有错误,会有提示。(以上命令已经调试,你只要将//的注释去掉即可使用)。
2、或者进入命令行后使用 mysql> source c:school.sql; 也可以将school.sql文件导入数据库中。