Mysql数据库相关

数据库

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语句:

 mysql> USE db1; mysql> SELECT COUNT(*) FROM mytable;   # selects from db1.mytable
 mysql> USE db2; mysql> SELECT COUNT(*) FROM mytable;   # selects from db2.mytable​

使用USE语句为一个特定的当前的数据库做标记,不会阻碍您访问其它数据库中的表。下面的例子可以从db1数据库访问作者表,并从db2数据库访问编辑表:


   mysql> USE db1;  
   mysql> SELECT author_name,editor_name FROM author,db2.editor       ->        WHERE author.editor_id = db2.editor.editor_id;

7.当前选择的数据库

 

数据表

  1. 创建数据表

命令: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. 删除数据表

  1. 查询表中数据

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使用,以查询更精确更复杂的数据。

  1. 表中插入数据

命令: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每次只能向表中插入一条记录。

  1. 删除表中数据

命令:delete from 表名 where 表达式

例如:删除表 MyClass中编号为1 的记录mysql> delete from MyClass where id=1;

  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子句用于给定一个限值,限制可以被更新的行的数目。

  1. 增加字段

命令: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;

  1. 修改表名

命令:rename table 原表名 to 新表名;

例如:在表MyClass名字更改为YouClass mysql> rename table MyClass to YouClass;

当你执行 RENAME 时,你不能有任何锁定的表或活动的事务。你同样也必须有对原初表的 ALTER 和 DROP 权限,以及对新表的 CREATE 和 INSERT 权限。

如果在多表更名中,MySQL 遭遇到任何错误,它将对所有被更名的表进行倒退更名,将每件事物退回到最初状态。

RENAME TABLE 在 MySQL 3.23.23 中被加入。

  1. 备份数据

命令在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. 实例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文件导入数据库中。

 
原文地址:https://www.cnblogs.com/carleunderwood/p/7149793.html