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