数据库第三天

//文章表

文章标题(title)、文章内容(content)、文章点击量(hits)、文章评论量(coms)

create table article(

aid int(11) not null auto_increment primary key,

title varchar(1000) not null,

content text not null,

hits int(11) not null,

coms int(11) not null

)engine=innodb charset=utf8;

//评论表

评论内容(com_content)、评论时间(com_time)

create table comment(

cid int(11) not null auto_increment primary key,

aid int(11) not null,//关联字段不能设为主键

com_content text not null,

com_time datetime null,

foreign key(aid) references article(aid)

)engine=innodb charset=utf8;

//学生表

DROP TABLE IF EXISTS `student`;

CREATE TABLE `student` (

`stid` int(11) NOT NULL AUTO_INCREMENT,

`name` varchar(1000) NOT NULL,

`age` tinyint(4) NOT NULL,

`sex` enum('男','女','其他') NOT NULL,

`tel` varchar(1000) NOT NULL,

`joinTime` date NOT NULL,

`local` varchar(255) DEFAULT NULL,

PRIMARY KEY (`stid`)

) ENGINE=InnoDB CHARSET=utf8;

//科目表

create table course(

coid int(11) not null auto_increment primary key,

co_name varchar(255) not null

);

//成绩表(哪个学生的哪科成绩)

//联合主键:两个字段联合起来唯一标识一条记录

//stid和coid联合起来作为一个主键

create table score(

stid int(11) not null,//关联学生表

coid int(11) not null,//关联科目表

score decimal(5,2) not null

);

alter table score add foreign key(stid) references student(stid);

alter table score add foreign key(coid) references course(coid);

学生ID  学生姓名  学生成绩

(1)左链接(left join):会读取左边表的全部数据,即使右表无对应数据

A left join B:A在左边作为主表,A表全部数据都会显示出来,而B表只会显示符合条件的数据,B表记录不足的地方会以Null补足

//left join:最常用

//select 字段名 from 表名1 left join 表名2 on 表1.关联字段=表2.关联字段;

select st.stid,st.name,sc.score from student st

left join score sc on st.stid=sc.stid;

//score作为主表

select st.stid,st.name,sc.score from score sc

left join student st on st.stid=sc.stid;

//学生ID  学生姓名  科目  学生成绩

select st.stid,st.name,co.co_name,sc.score from student st

left join score sc on st.stid = sc.stid

left join course co on sc.coid = co.coid;

图书ID  图书名  图书类型

select bk.id,bk.b_name,bt.type_name from books bk

left join book_type bt on bk.type_id = bt.type_id;

(3)查询小雪所有科目的成绩,要求显示结果为:学生ID 学生姓名 科目名称 科目成绩

select st.stid,st.name,co.co_name,sc.score from student st left join score sc on st.stid =sc.stid

left join course co on co.coid = sc.coid

where st.name='小雪';

右连接(right join):会读取右边表的全部数据,若左边表无对应的数据,会以Null来补足

A right join B:B表在右边,作为主表

//右连接:

//score在右边,作为主表

select st.stid,st.name,sc.score from student st

right join score sc on st.stid = sc.stid;

//子查询

//什么情况下使用

//(1)一般涉及到两张表及两张以上的表

//(2)通过一个已知表的条件去查找另一个表的数据(必须保证两张表有一个共同的字段)

//查询图书类型是'黑客'的所有的图书信息、

select type_id from book_type where type_name = '黑客';

select * from books where type_id=6;

select * from books where type_id = (select type_id from book_type where type_name = '黑客');

//查询小明的所有科目成绩

select stid from student where name = '小明';

select * from score where stid = (select stid from student where name = '小明');

//查询小雪的英语成绩

select stid from student where name = '小雪';

select coid from course where co_name = '英语';

select * from score where stid =(select stid from student where name = '小雪')  and coid = (select coid from course where co_name = '英语');

//查询语文成绩最高的学生信息

select coid from course where co_name = '语文';

select stid from score where coid =(select coid from course where co_name = '语文') order by score desc limit 0,1;

select * from student where stid = (select stid from score where coid =(select coid from course where co_name = '语文') order by score desc limit 0,1);

1、子查询

(1)查询小明的所有科目的成绩

(2)查询小明的数学成绩

(3)查询河北、山东这两地用户下的订单信息

select uid from users where address in ('河北','山东');

//limit in 不能一起使用

select * from orders where uid in(select uid from users where address in ('河北','山东'));

(4)查询近一个月内(2017-02-02~2017-03-02)订单金额最少的用户信 息

select uid from orders where orderTime between '2017-02-02' and '2017-03-02' order by money limit 0,1;

select * from users where uid = (select uid from orders where orderTime between '2017-02-02' and '2017-03-02' order by money limit 0,1);

//无限极分类(递归)表

理财

京东下金库

票据理财

基金理财

众筹

智能硬件

流行文化

公益

保险

车险

健康险

意外险

ID  name      pid(父级ID)

1  理财        0

2  众筹        0

3  保险        0

4  京东下金库  1

5  票据理财    1

6  基金理财    1

7  智能硬件    2

8  流行文化    2

9  车险        3

10  健康险      3

11  意外险      3

select * from 表 where pid=0;

select * from biao where pid = (select id from biao where name = '理财');

ID  name  pid

1  山东    0

2  济南    1

3  青岛    1

4  长清区  2

5  历下区  2

6  某某镇  4

//聚合函数,通常与group by一起使用

//常用于统计

//count();统计记录数

select count(*) from department;

select count(id) from books;

select count(id) as shuliang from books;

//max()求最大值,min()求最小值

select max(price) expensive from books;

select min(price) from books;

//sum() 求和

select sum(price) from books;

//avg() 求平均值

select avg(price) from books;

select avg(score) from score where stid = (select stid from student where name = '小明');

//字符串函数,会影响mysql执行效率

//截取字符串

substr(string,start,length)=substring(string,start,length)

string:要截取的字符串

start:从哪个位置开始截,从1开始

length:截取多少长度

select substr(b_name,1,2) from books;

//拼接字符串

//select concat(1,2,3);//结果123

//任意一个参数为Null,结果就为null

select concat(1,2,null);//结果null

select concat(b_name,price) from books;

//日期时间函数

select now();

select curdate();

select curtime();

select unix_timestamp();//默认返回当前时间戳

select unix_timestamp('2017-03-04');//将日期转换为时间戳

//返回某个日期是周几(1=星期天 2=星期1,...)

select dayofweek('2017-03-04');

//日期相加:date_add();或adddate();

select date_add('2017-03-03',interval 1 day);

select date_add(now(),interval 1 hour);

select date_add(now(),interval -1 month);

//日期相减:date_sub();或subdate();

select date_sub(now(),interval 1 minute);

//格式化日期:DATE_FORMAT(date,format);

http://www.cnblogs.com/zeroone/archive/2010/05/05/1727659.html

//分组查询:group by

//查询结果中有重复的数据,只取每组中的第一条记录

员工ID  员工姓名 部门名称

select st.id,st.name st_name,de.name de_name from staff st left join department de

on st.dep_id = de.id

group by de_name;

员工ID  员工姓名 部门名称 工资

//求每个小组的最高工资

select de.name de_name,max(st.salary) from staff st left join department de

on st.dep_id = de.id

group by de_name;

having:分组中的条件(在聚合之后对记录进行筛选)

//查询每小组平均年龄大于25岁的员工的平均工资

select de.name de_name,avg(st.age),avg(st.salary) from staff st left join department de

on st.dep_id = de.id

group by de_name

having avg(st.age) > 25;

//查询每一类的图书的平均价格,并且筛选出平均价格大于50的记录

select avg(bk.price),bt.type_name from books bk left join book_type bt on bk.type_id=bt.type_id

group by bt.type_name

having avg(bk.price) > 50;

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,233评论 6 495
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,357评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,831评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,313评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,417评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,470评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,482评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,265评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,708评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,997评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,176评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,503评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,150评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,391评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,034评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,063评论 2 352

推荐阅读更多精彩内容