zoukankan      html  css  js  c++  java
  • mysql常用命令小结

    以一个实际例子来说明mysql数据库的常用操作。学生选课系统,基本表包括student表、teacher表、course表,每门课程都有固定的老师;以及学生选课表,字段包括id(主键),学生id,课程id,以及分数score。如图所示:

    1、服务器的连接

    shell> mysql -h host -u user -p
    Enter password: ******
    host : 服务器运行的主机名
    user : mysql账号用户名

    2、数据库的创建和使用 

    create database course_choosing;
    alter database course_choosing character set utf8;
    use course_choosing;

    3、表相关操作

    create table student(id int NOT NULL primary key, name varchar(12), sex varchar(1), birth DATE);
    create table teacher(id int NOT NULL primary key, name varchar(12), birth date, university varchar(32));
    create table course(id varchar(3) NOT NULL primary key, name varchar(16) NOT NULL, address varchar(20), teacher_id int, UNIQUE (name));
    create table choose_course(id int NOT NULL primary key, student_id int, course_id varchar(3), score float(4,1));

    4、插入数据

    insert into table values();
    insert into student values(1001, '王小明', 'm', '1990-02-12'); 
    insert into student values(1002, '张晓丽', 'f', '1990-09-28'); 
    insert into student values(1003, '周婷', 'f', '1989-03-29'); 
    insert into student values(1004, '叶大勇', 'm', '1991-11-02'); 
    insert into student values(1005, '安卓', 'm', '1990-01-20'); 
    insert into teacher values(101, '祝大师', '1970-09-11', '北京大学');
    insert into teacher values(102, '李大卫', '1973-11-01', '北京大学');
    insert into teacher values(103, '乔明湘', '1980-02-11', ‘北京大学');
    insert into course values('003', '经济学', '梅园区东教学楼101室', 101);
    insert into course values('009', '建筑学', '桃园区东教学楼304室', 103);
    insert into course values('011', '金融学', '梅园区东教学楼103室', 101);
    insert into course values('022', '软件工程', '桃园区西教学楼203室', 102);
    insert into choose_course values(1, 1001, '003', 80.0);
    insert into choose_course values(2, 1001, '009', 59.5);
    insert into choose_course values(3, 1001, '011', 92.0);
    insert into choose_course values(4, 1002, '009', 89.0);
    insert into choose_course values(5, 1002, '022', 67.5);
    insert into choose_course values(6, 1003, '022', 80.0);
    insert into choose_course values(7, 1004, '003', 90.0);
    insert into choose_course values(8, 1005, '009', 80.0);
    insert into choose_course values(9, 1004, '011', 62.0);

    5、select语句

    #limit
    mysql> select * from student limit 3;
    --等价于select * from student limit 0,3;
    +------+-----------+------+------------+
    | id   | name      | sex  | birth      |
    +------+-----------+------+------------+
    | 1001 | 王小明    | m    | 1990-02-24 |
    | 1002 | 张晓丽    | f    | 1990-09-28 |
    | 1003 | 周婷      | f    | 1989-03-29 |
    +------+-----------+------+------------+
    
    #order by
    mysql> select * from choose_course order by score desc, id asc limit 6;
    --按分数由高到低排列,如果相同,则按id从小到大排序
    +----+------------+-----------+-------+
    | id | student_id | course_id | score |
    +----+------------+-----------+-------+
    |  3 |       1001 | 011       |  92.0 |
    |  7 |       1004 | 003       |  90.0 |
    |  4 |       1002 | 009       |  89.0 |
    |  1 |       1001 | 003       |  80.0 |
    |  6 |       1003 | 022       |  80.0 |
    |  8 |       1005 | 009       |  80.0 |
    +----+------------+-----------+-------+
    
    #in
    mysql> select * from student where id in(1001, 1004);
    --等价于select * from student where id=1001 or id=1004;
    +------+-----------+------+------------+
    | id   | name      | sex  | birth      |
    +------+-----------+------+------------+
    | 1001 | 王小明    | m    | 1990-02-24 |
    | 1004 | 叶大勇    | m    | 1991-11-02 |
    +------+-----------+------+------------+
    
    #between and
    mysql> select * from student where birth between '1990-01-01' and '1990-12-30';
    +------+-----------+------+------------+
    | id   | name      | sex  | birth      |
    +------+-----------+------+------------+
    | 1001 | 王小明    | m    | 1990-02-24 |
    | 1002 | 张晓丽    | f    | 1990-09-28 |
    | 1005 | 安卓      | m    | 1990-01-20 |
    +------+-----------+------+------------+
    
    #as
    mysql> select * from choose_course as cc where cc.score >= 90;
    --等价于select * from choose_course cc where cc.score >= 90;
    +----+------------+-----------+-------+
    | id | student_id | course_id | score |
    +----+------------+-----------+-------+
    |  3 |       1001 | 011       |  92.0 |
    |  7 |       1004 | 003       |  90.0 |
    +----+------------+-----------+-------+
    
    #join
    --JOIN: 如果表中有至少一个匹配,则返回行
    --LEFT JOIN: 即使右表中没有匹配,也从左表返回所有的行
    --RIGHT JOIN: 即使左表中没有匹配,也从右表返回所有的行
    mysql> select t1.*,t2.course_id,t2.score from student t1 join choose_course t2 on t2.score>80 and t1.id=t2.student_id; 
    +------+-----------+------+------------+-----------+-------+
    | id   | name      | sex  | birth      | course_id | score |
    +------+-----------+------+------------+-----------+-------+
    | 1001 | 王小明    | m    | 1990-02-24 | 011       |  92.0 |
    | 1002 | 张晓丽    | f    | 1990-09-28 | 009       |  89.0 |
    | 1004 | 叶大勇    | m    | 1991-11-02 | 003       |  90.0 |
    +------+-----------+------+------------+-----------+-------+
    
    mysql> select t1.*,t2.course_id,t2.score from student t1 left join choose_course t2 on t2.score>80 and t1.id=t2.student_id;
    +------+-----------+------+------------+-----------+-------+
    | id   | name      | sex  | birth      | course_id | score |
    +------+-----------+------+------------+-----------+-------+
    | 1001 | 王小明    | m    | 1990-02-24 | 011       |  92.0 |
    | 1002 | 张晓丽    | f    | 1990-09-28 | 009       |  89.0 |
    | 1003 | 周婷      | f    | 1989-03-29 | NULL      |  NULL |
    | 1004 | 叶大勇    | m    | 1991-11-02 | 003       |  90.0 |
    | 1005 | 安卓      | m    | 1990-01-20 | NULL      |  NULL |
    | 1006 | 陈路      | f    | 1989-01-23 | NULL      |  NULL |
    +------+-----------+------+------------+-----------+-------+
    
    #union (all)
    mysql> select name from student limit 2 union select name from teacher;
    +-----------+
    | name      |
    +-----------+
    | 王小明    |
    | 张晓丽    |
    | 祝大师    |
    | 李大卫    |
    | 乔明湘    |
    +-----------+

    #having
    --HAVING子句可以让我们筛选成组后的各组数据. 
    WHERE子句在聚合前先筛选记录.也就是说作用在GROUP BY 子句和HAVING子句前. 
    而HAVING子句在聚合后对组记录进行筛选。 
    举例:选出所有10个以上学生选择的课程id以及学生人数。
    mysql> select course_id, count(*) as c from choose_course group by course_id having c>10 order by c desc;

    6、其他常用操作

    安装mysql后给root账号设置密码
    mysqladmin -u root -p password
    新增用户并且设置权限
    GRANT ALL PRIVILEGES ON blog.* TO 'blog'@'%' IDENTIFIED BY 'blog';
    flush privileges; ##表相关 查看默认引擎 show engines; 或者 show variables
    like 'table_type'; 更改表名 alter table student rename to student_new; 查看表结构 desc student; 清空表数据 delete from student; 删除表 drop table student; 查看建表语句 show create table student; ##列相关 添加列 alter table student add column age int; 删除列 alter table student drop column age; 修改列名或属性 alter table student change username name varchar(12); 添加、删除主键/外健约束 alter table course add primary key(id); alter table course add foreign key(teacher_id) references teacher(id); alter table course drop foreign key teacher_id; 多列唯一索引 alter table course add unique index (address, teacher_id); 如果不存在则插入,如果存在则更新on duplicate key update insert into course(id, name, address, teacher_id) values('111', '王晓明', '123', 129) on duplicate key update name='张晓丽';
  • 相关阅读:
    servlet基础讲解
    tomcat web.xml配置
    JavaScript Cookies
    窗口的自适应处理
    让Eclipse和NetBeans共享同一个项目
    maven基础知识
    JS中令人发指的valueOf方法介绍
    在iOS开发中使用FMDB
    苹果开发者账号那些事儿(三)
    苹果开发者账号那些事儿(二)
  • 原文地址:https://www.cnblogs.com/everSeeker/p/4903342.html
Copyright © 2011-2022 走看看