创建表

drop table student;
DROP table Course;
DROP table sc; CREATE TABLE student
(
sid integer PRIMARY KEY ASC autoincrement not null,--id 升序排序 主键不为空,当为主键时默认为不为空自动增长升序排序 我无聊实践了下,只填primary key创建表比当前这种全写的要快
sname nvarchar(32),--学生名
age integer,--年龄
sex nvarchar(8)--性别
);
create table “main”."Course"--课程表
(
cid integer Not null,--id 这个是公司一个开发写的,感觉很新奇,但是没啥卵用,同上primary key已经解决一切,这样只会让创建表时间延长
cname nvarchar(32),--课程名
   primary key ("cid" ASC)
);
create table sc --成绩表
(
scid integer PRIMARY KEY autoincrement,--id
sid integer,--学生表id
cid integer,--课程表id
core integer--成绩
); INSERT into student(sname,age,sex)
VALUES
('芳芳',21,'女'),
('婷婷',21,'女'),
('瑞宝',21,'女'),
('不知名',21,'女'); insert into Course(cname)
VALUES
('语文'),
('数学'); INSERT into sc(sid,cid,core)
VALUES
(1,1,80),
(1,2,50),
(2,1,99),
(2,2,99);

各种插入

INSERT into student(sid,sname,age,sex)
VALUES
(6,'错乱',21,'女')

各种查询

--查询自增id不连续的id
select sid from (select sid from student order by sid asc) s where not exists (select 1 from student where sid=s.sid-1);
--连接查询,芳芳的数学成绩
select s.sname,sc.core from student s LEFT JOIN sc ON s.sid = sc.sid left JOIN Course c on c.cid =sc.cid WHERE s.sname = '芳芳';
--模糊查询名字有婷的学生
select * from student WHERE sname like '%婷%';
--不用连接查询查询婷婷 的数学成绩
select s.sid,s.sname,scc.core from (SELECT sid,sname FROM student ) s,(SELECT sid,core,cid FROM sc) scc WHERE sname = '婷婷' AND scc.sid = s.sid AND scc.cid = 2 ;
--简便多表查询芳芳以外学生的语文成绩
select s.sname,c.cname,sc.core from student s,sc,Course c WHERE s.sname IS NOT '芳芳' and s.sid = sc.sid and sc.cid = c.cid and c.cname = '语文' GROUP BY sc.scid ;
--查询出数学比语文高的学生
SELECT s.sid,s.sname,sc1.core FROM (SELECT sid,core FROM sc WHERE cid = '' ) sc2,(SELECT sid,core FROM sc WHERE cid = '' ) sc1, (SELECT sid,sname FROM student ) s WHERE s.sid = sc1.sid and sc1.sid = sc2.sid AND sc1.core<sc2.core;
--查询成绩100的其他学生
select * FROM student WHERE sname NOT IN (SELECT sname FROM student s,sc WHERE s.sid = sc.sid AND sc.core = 100);
--查询成绩大于60的学生个数
select count(distinct(sname)) FROM student s,sc WHERE s.sid = sc.sid AND sc.core>60;
--查询平均值大于70的学生
select s.sname,avg(sc.core) from student s,sc WHERE s.sid = sc.sid GROUP BY sc.sid HAVING avg(sc.core)>70;

各种更新--待更新

--将mark更新到name
update test1 set name = (SELECT mark FROM test2 WHERE test2.id=test1.id) WHERE test1.id=(select DISTINCT id from test2 where test2.id=test1.id)

各种删除--待更新


无聊试验了一下

aaa1比aaa创建的要快,没想到重复操作不简洁还是有点时间消耗的,每种创建10个,aaa1快了0.0001秒。创建表对于速度还是不要求,但如果是公司大数据大量的插入更新将会很明显,有一个代码优化的意识很重要。

然后这个,第二种竟然比第一种还要快。。


--倒叙查询 id倒叙且只显示前十条
select * from sc order by id desc limit 0,10;

SQL数据库各种查询建表插入集合-待续持续更新的更多相关文章

  1. 50个SQL语句(MySQL版) 建表 插入数据

    本学期正在学习数据库,前段时间老师让我们做一下50个经典SQL语句,当时做的比较快,有一些也是百度的,自我感觉理解的不是很透彻. 所以从本篇随笔开始,我将进行50个经典SQL语句的复盘,加深理解. 答 ...

  2. JavaFX程序初次运行创建数据库并执行建表SQL

    在我的第一个JavaFX程序完成安装的时候才突然发现,不能要用这个软件还要手动执行Sql来建表吧? 于是我的想法是在Main程序中执行时检测数据库连接状况,如果没有检测到数据库或者连接异常,那么出现错 ...

  3. 从数据库中查询所有表及所有字段的SQL语句

    从数据库中查询所有表及所有字段的SQL语句 由于一个小项目的需要,近日完成一个从数据库中查询所有表及所有字段的方法,其实用两条SQL语句就可以完成. Sql Server版:列出当前DB中所有表:se ...

  4. mysql数据库(一):建表与新增数据

    一. 学习目标 理解什么是数据库,什么是表 怎样创建数据库和表(create) 怎样往表里插入数据(insert) 怎样修改表里的数据(update) 怎样删除数据库,表以及数据(delete) 二. ...

  5. PowerDesigner创建表 拷贝创建表语句 SQLSERVER创建数据库 使用查询 创建表 并且添加数据

    PowerDesigner创建表 : 1.双击打开PowerDesigner   2.双击打开Create model 3左键点击Model  types,再点击Physical    Data  m ...

  6. 0420-mysql命令(数据库操作层级,建表,对表的操作)

    注意事项: 符号必须为英文. 数据库操作层级: 建表大全: #新建表zuoye1:drop table if exists zuoye1;create table zuoye1(    id int ...

  7. 干货!IT小伙伴们实用的网站及工具大集合!持续更新!

    1.Git 还在担心自己辛辛苦苦写的代码被误删了吗?还在担心自己改错了代码不能挽回吗?还在苦恼于多人开发合作找不到一个好的工具吗?那么用Git就对 了,Git是一个开源的分布式版本控制系统,用以有效. ...

  8. PHP 日常开发过程中的bug集合(持续更新中。。。)

    PHP 日常开发过程中的bug集合(持续更新中...) 在日常php开发过程中,会遇到一些意想不到的bug,所以想着把这些bug记录下来,以免再犯! 1.字符串 '0.00'.'0.0'.'0'  是 ...

  9. SQL 查询建表SQL

    1.新建一个查询语句,按执行按钮 2.结果页面会显示一条sql语句,复制该语句即可建表 3.建表测试

随机推荐

  1. Fire Balls 04——砖塔的创建,动态上升以及旋转

    版权申明: 本文原创首发于以下网站: 博客园『优梦创客』的空间:https://www.cnblogs.com/raymondking123 优梦创客的官方博客:https://91make.top ...

  2. 使用wait/notify/notifyAll实现线程间通信的几点重要说明

    在Java中,可以通过配合调用Object对象的wait()方法和notify()方法或notifyAll()方法来实现线程间的通信.在线程中调用wait()方法,将阻塞等待其他线程的通知(其他线程调 ...

  3. CSAPP - Ch 1 - 计算机系统漫游

    目录 0 序言及摘要 1 信息就是位+上下文 2 程序被其他程序翻译成不同的格式 3 了解编译系统如何工作是大有益处的 0 序言及摘要 (1) 序言: CS:APP -- Computer Syste ...

  4. ubuntu安装elasticsearch及head插件

    1.安装elasticsearch,参考http://www.cnblogs.com/hanyinglong/p/5409003.html就可以了 简单描述下: mkdir -p /usr/local ...

  5. NLP(十一) 提取文本摘要

    gensim.summarization库的函数 gensim.summarization.summarize(text, ratio=0.2, word_count=None, split=Fals ...

  6. HDU 4719Oh My Holy FFF 线段树+DP

    /* ** 日期: 2013-9-12 ** 题目大意:有n个数,划分为多个部分,假设M份,每份不能多于L个.每个数有一个h[i], ** 每份最右边的那个数要大于前一份最右边的那个数.设每份最右边的 ...

  7. CodeForces 103D Time to Raid Cowavans 询问分块

    Time to Raid Cowavans 题意: 询问 下标满足 a + b * k 的和是多少. 题解: 将询问分块. 将b >= blo直接算出答案. 否则存下来. 存下来之后,对于每个b ...

  8. [NOI1995]石子合并 题解

    一道经典的dp题 在一个圆形操场的四周摆放N堆石子,现要将石子有次序地合并成一堆.规定每次只能选相邻的2堆合并成新的一堆,并将新的一堆的石子数,记为该次合并的得分. 试设计出1个算法,计算出将N堆石子 ...

  9. cesium页面小控件的隐藏

    cesium页面小控件的隐藏 1   创建一个Viewer var viewer = new Cesium.Viewer('cesiumContainer');//cesiumContainer为di ...

  10. js中的所有兼容问题总结

    js兼容问题总结 ​ 在学习js过程中很多人都遇到过兼容问题,这些兼容问题是因为各版本浏览器不同导致的,为了解决这些兼容问题,js给我们提供了解决这些兼容问题的方案,对此,我个人进行了汇集以及总结. ...