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
                                            

 

posted @ 2012-10-19 11:40  邹晟  阅读(259)  评论(0编辑  收藏  举报