zoukankan      html  css  js  c++  java
  • mysql 命令总结(持续补全)

    安装命令 --initialize-insecure
    bin目录下的mysqld
    E:wupeiqimysql-5.7.16-winx64mysql-5.7.16-winx64inmysqld --initialize-insecure # 命令参考


    show databases; # 查看库
    create database db1; # 创建文件夹
    use db1; # 进入db文件夹
    create user '用户名'@'192.168.1.%'indentfied by '密码'; # 创建用户
    grant select,insert,update on db1.t1 to 'alex'@'%'; # 给用户授权 db1.t1 是某个表
    create table t1(列,列) engine=innodb 原子性操作 default charset=utf8 设置默认编码为utf8;
    一般 primary key 都是识别id添加not null 非空属性。
    create table t1( id int not null auto_increment primary key ,student_id int , constraint foreign (sutdent_id) references student(sid) );
    enum ('内容','内容','content') # 荐举属性,使列只能填括号内的内容
    insert into t1(student_id) values() # 插入数据行
    desc t1; # 查看表的信息,
    show create table t1 G; # 查看创建信息,可看自增属性
    alter table t10 AUTO_INCREMENT=20; # 把自增数修改。 比如表里由自增到3,那只能修改3以后的数。
    unique uq_u1 (user_id) # 索引,加速查找唯一值,可以为空
    delimiter // # 修改终止符,修改后例如: select * from t1// 结束
    set global log_bin_trust_function_creators=1; # 创建函数时,出错输入这个。
    关于自增的设置
    基于会话级别:
    show session variables like 'auto_inc%'; 查看全局变量
    set session auto_increment_increment=2; 设置会话步长
    # set session auto_increment_offset=10;
    基于全局级别:
    show global variables like 'auto_inc%'; 查看全局变量
    set global auto_increment_increment=2; 设置会话步长
    # set global auto_increment_offset=10;




    一对一:
    create table department(id int auto_increment primary key , title char(20) not null , unique uq1_dep (title))engine=innodb default charset=utf8;
    create table userinfo(id int auto_increment primary key , username char(10) not null , usertype int ,constraint foreign key (usertype) references department(id),unique uq2 (username) )engine=innodb default charset=utf8;
    create table admin(id int auto_increment primary key , user_id int , passwrod char(16) not null , unique uq_u1 (user_id) ,constraint foreign key (user_id) references userinfo(id) )engine=innodb default charset=utf8;

    多对多:
    create table userinfo(id int auto_increment primary key , name char(64) not null, gender enum('男','女') )engine=innodb default charset=utf8;
    create table host_table(id int auto_increment primary key , hostname char(64) not null ) engine=innodb default charset=utf8;
    create table user_host_table(id int auto_increment primary key , user_id int not null,host_id int not null,constraint foreign key (user_id) references userinfo(id) , constraint foreign key (host_id) references host_table(id),unique uq1 (user_id,host_id) )engine=innodb default charset=utf8;



    insert into tb11(name,age) values('alex',12);

    insert into tb11(name,age) values('alex',12),('root',18);

    insert into tb12(name,age) select name,age from tb11;

    delete from tb12;
    delete from tb12 where id !=2
    delete from tb12 where id =2
    delete from tb12 where id > 2
    delete from tb12 where id >=2
    delete from tb12 where id >=2 or name='alex'
    truncate table t1;


    update tb12 set name='alex' where id>12 and name='xx'
    update tb12 set name='alex',age=19 where id>12 and name='xx'


    select * from tb12;

    select id,name from tb12;

    select id,name from tb12 where id > 10 or name ='xxx';

    select id,name as cname from tb12 where id > 10 or name ='xxx';

    select name,age,11 from tb12;

    a、条件
    select * from 表 where id > 1 and name != 'alex' and num = 12;

    select * from 表 where id between 5 and 16;

    select * from 表 where id in (11,22,33)
    select * from 表 where id not in (11,22,33)
    select * from 表 where id in (select nid from 表)

    b、通配符
    select * from 表 where name like 'ale%' - ale开头的所有(多个字符串)
    select * from 表 where name like 'ale_' - ale开头的所有(一个字符)

    c、限制
    select * from 表 limit 5; - 前5行
    select * from 表 limit 4,5; - 从第4行开始的5行
    select * from 表 limit 5 offset 4 - 从第4行开始的5行

    d、排序
    select * from 表 order by 列 asc - 根据 “列” 从小到大排列
    select * from 表 order by 列 desc - 根据 “列” 从大到小排列
    select * from 表 order by 列1 desc,列2 asc - 根据 “列1” 从大到小排列,如果相同则按列2从小到大排序

    e、分组
    select num from 表 group by num
    select num,nid from 表 group by num,nid
    select num,nid from 表 where nid > 10 group by num,nid order nid desc
    select num,nid,count(*),sum(score),max(score),min(score) from 表 group by num,nid

    如果对于聚合函数结果进行二次筛选时,必须用having
    select num from 表 group by num having max(id) > 10

    特别的:group by 必须在where之后,order by之前

    f、连表
    无对应关系则不显示
    select A.num, A.name, B.name
    from A,B
    Where A.nid = B.nid

    无对应关系则不显示
    select A.num, A.name, B.name
    from A inner join B
    on A.nid = B.nid

    A表所有显示,如果B中无对应关系,则值为null
    select A.num, A.name, B.name
    from A left join B
    on A.nid = B.nid

    B表所有显示,如果B中无对应关系,则值为null
    select A.num, A.name, B.name
    from A right join B
    on A.nid = B.nid

    f2、上下连表: union
    # 自动去重
    select id,name from tb1
    union
    select num,sname from tb2
    # 不去重
    select id,name from tb1
    union all
    select num,sname from tb2

    g、组合
    组合,自动处理重合
    select nickname
    from A
    union
    select name
    from B

    组合,不处理重合
    select nickname
    from A
    union all
    select name
    from B

    h、条件:判断显示
    select course_id,max(number)as 最高分,min(number) as 最低分 , case when min(number) <60 then 0 else min(number) end from score group by course_id;

    case when min(number) <60 then 0 else min(number) end
    i、三元运算
    if(isnull( 判断条件),0,1) # 成立则为0 不成立则1
    临时表:
    select cid,cname from (select cid,cname from course where number > 60 ) as B;


    计算命令:
    sum
    avg
    count


    表格查询操作:
    select * from t1 as s1 ,t1 as s2; # 生成 t1 乘 t1 的表格

    38、查询没学过“叶平”老师讲授的任一门课程的学生姓名;
    # 思路,直接not in 老师的课程的话,会导致数据错误,先选出学过,然后排除学过的学生
    select score.student_id,student.sname from score
    left join student on student.sid = score.student_id
    where score.student_id not in
    (select student_id from score where course_id in (select cid from course where teacher_id = (select tid from teacher where tname = '波多')) );

    21、查询各科成绩前三名的记录:(不考虑成绩并列情况)
    # 把course as s1 可以每次循环的时候s1.cid 再次在 表No.1 2 3 里面循环判断,达到自己需求的目的
    select
    s1.cid,
    (select number from score as s2 where s2.course_id = s1.cid group by s2.number order by s2.number desc limit 0,1) as No1,
    (select number from score as s2 where s2.course_id = s1.cid group by s2.number order by s2.number desc limit 1,1) as No2 ,
    (select number from score as s2 where s2.course_id = s1.cid group by s2.number order by s2.number desc limit 2,1) as No3
    from course as s1;

    视图:
    - 创建
    create view 视图名称 as SQL
    PS: 虚拟
    - 修改
    alter view 视图名称 as SQL
    - 删除
    drop view 视图名称;
  • 相关阅读:
    java 通过Iterator输出Map
    java SortedSet接口swap方法
    java vector
    java Iterator双向迭代输出
    java 序列化和反序列化多个对象
    培训
    每天晚上

    又想起了

  • 原文地址:https://www.cnblogs.com/222kd/p/10868287.html
Copyright © 2011-2022 走看看