您的位置:首页 > 数据库 > MySQL

mySQL命令

2013-06-06 10:07 197 查看
MYSQL命令:

1. 进入DBMS mysql -u用户名 -p密码

2. 进入他人的DBMS mysql -h地址 -u用户名 -p密码

3. 创建数据库create database 数据库名

4. 删除数据库 drop database 数据库名

5. 查看现有数据库 show databases

6. 查看数据库下面的表 show tables;

7. 切换数据库 use 数据库名

8. 查看数据库的状态 \s;

9. 退出 quit或\q;

10. 启动mysql服务 net start mysql ,停止net stop mysql;

11.char与varchar的区别:在数据库中char(11)和varchar(11)都可以代表字符串,

将xiaochun这个字符串存在char(11)中的效果是xiaochun___,

如果存在varchar(11)中的效果是xiaochun,

如果字符串的长度未达到char的指定长度,就会用空格填充

如果字符串的长度未达到varchar的指定长度,不会用空格填充

char字段读取速度会很快,varchar需要算出字段长度后再读出

建议,对于知道长度的字符串用char,比如性别

对于不知道长度的用varchar ,比如姓名

12. 表的创建语法:

create table 表名(

列名 数据类型 not null,

列名 数据类型,

.........

列名 数据类型

)

13.表中插入语句:

insert into 表名 values(1,'张三',18);//注意插入的数据和列要一一对应

14.查看表中所有的数据的语句

select 列名,列名..... from 表名; //查看指定表中所有数据

15.desc 表名, 查看表结构

16. create table b(

bid int auto_increment, --自动增长,定义自动增长的列必须定义为主键

bname varchar(10),

bcard varchar(18),

primary key(bid), --主键

unique(bcard)); --该列唯一值

17. create table c(

cid int auto_increment,

cname varchar(20),

bid int,

primary key(cid),

foreign key(bid) references b(bid)); --和上表建立了主外键关系,只有主键才能在

--另外一张表中做为外键

--所以我们看到当c表中插入了一个b表中不存在的bid时,就会报错,因为有了主外键关系就会

--检查数据的有效性

18. 删除一条记录

delete from 表名;--删除表中的所有记录

delete from 表名 where bid=3; --删除一条记录

要注意,如果该行记录在另外一张表中做了外键,就不能删除了,必须先删掉做外键的记录

19. 删除 drop database wlk;

drop database if exists wlk;

drop table wlk;

drop table if exists wlk;

20. 插入语句,一次多条

mysql> insert into s values('1005','单单','中空油','22'),('1006','国加','央企','

22');

21. mysql> update s set sd='中原油',sa='24' where sid='1005'

--修改表中的数据,可以一次改动多列,但一定要限定where条件,避免整张表被修改

22. mysql> select * from s where sa > 23; --带条件的查询,纯数字的字符串可以当成数字计算

--以时间为格式的字符串,可以当成时间计算

23. mysql> select * from s where sa in (23,24); --查找23,24年纪

mysql> select * from s where sa between 23 and 30; --查找大于等于23,小于等于30;

mysql> select * from s limit 0,3; --查找前三条

mysql> select * from s limit 3,6; --从第4条开始,查6条

24. mysql> select * from s order by sa asc; --查看s表,并以sa为升序排列, asc可省,因为默认值;

mysql> select * from s order by sa desc; --降序排列

mysql> select * from s where sa>23 order by sa desc;

25. 1001 考了几门

mysql> select count(*) from sc where sid='1001'; --count计算结果有多少行

1001 的最高分

mysql> select max(g) from sc where sid='1001'; --max取出结果中指定列的最高值

1001 的最低分

mysql> select min(g) from sc where sid='1001'; --min取出结果中的指定列的最低值

1001 的平均分

mysql> select avg(g) from sc where sid='1001'; --avg取出指定列的平均分

26. 取出所有考试人员的平均分

--在sql中使group by 列名,将同名列分在一起,分组的意思

27. mysql> select sid , avg(g) from sc group by sid; --在sc表中按sid分组,并求出每组的平均值

mysql> select sid , avg(g) from sc where g>70 group by sid; --在sc表中按sid分组,求出每组大于70分的成绩的平均值

mysql> select sid , avg(g) from sc group by sid having avg(g) > 85; 在sc表中按sid分组求出每组的平均值

--但是小于等于85的成绩不要显示了

mysql> select sid , avg(g) from sc where g>70 group by sid having avg(g) > 84 order by avg(g);

--首先将g<=70分的所有成绩不要,然后分组求出平均成绩,然后只显示平均分大于84的成绩

mysql> select sid , avg(g),max(g),min(g),count(cid) from sc where g>70 group by sid having avg(g) > 84;

28. mysql> select * from female where mid is not null; --null值的查询

29. 找出和女人有关系的男人的姓名

mysql> select f.fid ,f.fname ,(select mname from male m where m.mid=f.mid) '她男

人的名字' from female f; --注意内置的select语句,子查询,注意表和列的别名

30. 打印出课目名,考生名和其成绩使用SC表

mysql> select (select cn from c where c.cid=sc.cid) 'cn' , (select sn from s whe

re s.sid=sc.sid) 'sn',g from sc;

用连接查询来解决问题:

mysql> select s.sn,c.cn,g from sc inner join s on sc.sid = s.sid inner join c

-> on c.cid=sc.cid;

31. 列出和女人有关系的姓名,没有关系的女人不列出

内连接查询:根椐条件f.mid=m.mid把两张表合并在一起,如果不满足条件的将不会列出(即找不到相等的)

inner join .......on.....

mysql> select f.fid,f.fname,m.mname from female f inner join male m on

-> f.mid = m.mid;

外连接(左,右)查询:根椐条件f.mid=m.mid把两张表合并在一起,如果左边表有 没有满足条件的也列出来

32. 找出考了税收基础的人名和成绩

a.找到税收基础的编号 :mysql> select cid from c where cn='税收基础'; //cid=s001

b.拿着cid=s001去sc表中查询出哪些sid考了这门及成绩

c.合并解决问题

mysql> select cid,(select sn from s where s.sid=sc.sid) 'sn',g from sc where cid

=(select cid from c where cn='税收基础');

mysql> select cid,s.sn,g from sc inner join s on s.sid=sc.sid where cid=(select

cid from c where cn='税收基础');
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: