DML:数据操作语言

1.插入insert into

单行插入:insert into 表名 (字段名, 字段名,。。。) values (值, 值, 。。。) 注:值列表要和字段列表相匹配。

     insert into 表名  values  (值, 。。。) 表示全字段都插入相应的值。

多行插入:insert into 表名 (字段列表) select 字段列表/* from 表名 where 条件

       insert into 表名 select 字段列表/* from 表名 where 条件

  注:主要应用与表之间数据的复制

2.修改update

  update 表名 set 字段名1=值1, 字段名2=值2... where 条件。

  如果不加where条件就是全表更新。

3.删除delete

全表删除:delete from 表名  效率较低(因为此方法再删除时机器会先建立日志,先复制储存一遍再进行删除)

     truncate table 表名 效率高(通常采用此方法进行全表的删除)

选择删除:delete from 表名 where 条件

DQL:数据查询语言

一.查询某个表中的某个字段:select 字段名/* from 表名 。 当是*号时表示查询所有字段

给表加别名: student t   。   给字段加别名: son as s

二.排序order by的用法:

1.order by 字段名1 asc/desc, 字段名2 asc/desc,...

先按照字段名1的升序/降续给表进行排列 然后 按照字段名2的升序/降续给表进行排列。 其中排在前面的字段名优先进行排列,排在后面的在前面的基础上在进行排列。

2. order by 字段序号 asc/desc, 字段序号 asc/desc,...

按照字段的序号进行排列,字段的序号就是表中每个字段从左到右依次排列的顺序,从1开始。字段序号对应相应的字段名。

3.

asc(升序)/desc(降续)

order by 默认是升序排列的,所以我们在进行排列时

如果要按升序进行排列,就不需要写asc。

如果要按降续进行排列,就   需要写desc。

4.order by 要放在where语句的后面

三.group up的用法

1.group up 字段列表

2.group by 字段列表 having 过滤条件

在一完整的语句中select后面仅可以跟要分组的字段和聚合函数

四.多表之间的关联查询

1.join on 负责关联两个表 (内连接)

用法:select * from 表名 join 表名 on 两表之间的连接关系

例:学生表与成绩表两表之中都有学号,那么我就可以把学号作为关联两表之间的等式关系。

  select * from student t join score e on t.sno=e.sno

当然我们也可以关联更多的表,只需要在后面继续添加join 表名 on 链接关系即可。注意我们要把主表放在from后面。

例:成绩表中有学生号(sno)和课程号(con),学生表中有学号,课程表中有课程号,那么我们可以把成绩表作为主表,利用主表中的学号与课程号与学生表和课程表进行关联。

  select * from score e join student t on e.sno=t.sno join couser r on e.con=r.con

内连接特点:表的数据和另外一个表没有可关联数据,那该数据就会被隐藏

2.左联接 left join on

用法:同内连接一样只是在join前面加了left。

特点:可以保证左边表的数据会全部显示

3.右连接 right join on

用法:同内连接一样只是在join前面加了right。

特点:可以保证右边表的数据会全部显示

4.全连接 full join on

用法:同内连接一样只是在join前面加了full

特点:这样就保证了左右两边的表中的全部数据都会显示

五.结果集合并 union

用法:用来合并两条查询语句。当我们要把连个毫无联系的查询结果或者两个表进行合并成一个表,但要去除重复数据时,我们就需要用 union 进行合并。

例:我要去学生表中的学号(sno)和教师表中的教工号(tno)

  select sno from student union select tno from teacher

当我不想去掉重复数据时,我只需要在union 后面加一个 all即可

例:select sno from student union all select tno from teacher

总结一下:

在我们使用DQL查询语句时,不仅要搞懂每种特定语句的使用方式,更要了解清楚查询时的逻辑关系,有时在查询一个很复杂的数据时,我们不妨转换一下几种方式。

例如:

1.子查询的嵌套思想。

2.把查询出来的结果当做条件中的数值或者数组

3.其实我们间接查出来数值,我们都可以把它看做是一个表,然后把它作为表与其他表进行关联等等。

4.条件where的使用方式是很重要的:

1.where都是附属在DQL,DML语句后面的

2.where 后使用比较运算符,逻辑运算符连接

DML以及DQL的使用方法的更多相关文章

  1. Mysql 数据库操作之DDL、DML、DQL语句操作

    Mysql 数据库操作之DDL.DML.DQL语句操作 设置数据库用户名密码 l  Show databases 查看数据库列表信息 l  查看数据库中的数据表信息 ,格式: use 数据库名: sh ...

  2. MySQL的sql语言分类DML、DQL、DDL、DCL、

    MySQL的sql语言分类DML.DQL.DDL.DCL. SQL语言一共分为4大类:数据定义语言DDL,数据操纵语言DML,数据查询语言DQL,数据控制语言DCL 1.数据定义语言DDL(Data ...

  3. MySQL的DML和DQL 增删改查

    DML和DQL   增删改查 SELECT * FROM grade --新增 insert -- 向年级表中新增3条数据INSERT INTO grade(gradeID,gradeName) VA ...

  4. SQL--SQL详解(DDL,DML,DQL,DCL)

    SQL--SQL详解(DDL,DML,DQL,DCL) 博客说明 文章所涉及的资料来自互联网整理和个人总结,意在于个人学习和经验汇总,如有什么地方侵权,请联系本人删除,谢谢! 什么是SQL? Stru ...

  5. sql 语言--- DML,DDL,DQL,DCL,TCL,CCL

    结构化查询语言(Structured Query Language)简称SQL                是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询.更新和管理 ...

  6. 使用Statement执行DML和DQL语句

    import com.loaderman.util.JdbcUtil; import java.sql.Connection; import java.sql.DriverManager; impor ...

  7. sql操作数据库(1)-->DDL、DML、DQL

    SQL 操作数据库 概念:结构化查询语言 Structured Quary Language 作用:  1.是一种数据库的查询的标准,对所有的数据库都支持  2.不同的数据库SQL语句可能有点不同 ( ...

  8. jdbc java数据库连接 3)Statement接口之执行DDL、DML、DQL

    |- Statement接口: 用于执行静态的sql语句 |- int executeUpdate(String sql)  : 执行静态的更新sql语句(DDL,DML) |- ResultSet ...

  9. DDL\DML\DCL\DQL

    [DML] DML = Data Manipulation Language,数据操纵语言,命令使用户能够查询数据库以及操作已有数据库中的数据的计算机语言.具体是指是UPDATE更新.INSERT插入 ...

随机推荐

  1. Visual Studio 2015和ASP.NET 5中可用的前端开发工具集

    最近微软发布了一本白皮书,谈到了一些可以和Visual Studio 2015和ASP.NET 5配合使用的JS/前端Web开发工具(比如:函数库.任务执行器.框架等). 由于现在前端开发的生态系统在 ...

  2. 0x和H都表示十六进制有什么区别吗?

    0x是16进制的前缀,H是16进制的后缀 都是表示十六进制数,意义上没有什么区别,完全相等.至于什么时候用0x,什么时候用H,这取决于你在什么环境下使用,如果在C/C++,必须用0x来表示. 在C语言 ...

  3. loj 1185(bfs)

    题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=26898 思路:我们可以给定有直接边相连的两点的距离为1,那么就是求 ...

  4. Java Web应用调优线程池

    最简单的单线程 我们先从基础开始.无论使用哪种应用服务器或者框架(如Tomcat.Jetty等),他们都有类似的基础实现.Web服务的基础是套接字(socket),套接字负责监听端口,等待TCP连接, ...

  5. DP VK Cup 2012 Qualification Round D. Palindrome pairs

    题目地址:http://blog.csdn.net/shiyuankongbu/article/details/10004443 /* 题意:在i前面找回文子串,在i后面找回文子串相互配对,问有几对 ...

  6. Partran,Nastran和ANSYS的区别

    Partran .Nastran是MSC公司的产品.Patran是前处理器,用于建模.划分网格.设定载荷和边界条件等等:Nastran只是MSC公司提供的求解器之一,主要用于结构分析和热分析,应用的是 ...

  7. 走楼梯[XDU1031]

    Problem 1031 - 走楼梯 Time Limit: 1000MS   Memory Limit: 65536KB   Difficulty: Total Submit: 724  Accep ...

  8. POJ 1548 (二分图+最小路径覆盖)

    题目链接:http://poj.org/problem?id=1548 题目大意:给出一张地图上的垃圾,以及一堆机器人.每个机器人可以从左->右,上->下.走完就废.问最少派出多少个机器人 ...

  9. 【COGS】714. USACO 1.3.2混合牛奶(贪心+水题)

    http://cojs.tk/cogs/problem/problem.php?pid=714 在hzwer的刷题记录上,默默地先跳过2题T_T...求凸包和期望的..T_T那是个啥..得好好学习 看 ...

  10. 李洪强-C语言2-字符串

      C语言字符串 一.字符串基础 注意:字符串一定以\0结尾. Printf(“yang\n”); 其中yang为字符串常量,“yang”=‘y’+‘a’+‘n’+‘g’+‘\0’.字符串由很多的字符 ...