DML和DQL   增删改查

SELECT * FROM grade

--新增 insert

-- 向年级表中新增3条数据
INSERT INTO grade(gradeID,gradeName) VALUES(4,'4年级');
INSERT INTO grade(gradeID,gradeName) VALUES(5,'5年级');
INSERT INTO grade(gradeID,gradeName) VALUES(6,'6年级');

-1.备份表:create table 新表(不存在) select * from 原表
-2.追加数据:
(一次性向表中走N条记录)
insert into 被追加数据的表名(列) select 列 from 原表

-- 删除 delect

DELETE FROM grade WHERE gradeID>3;
DELETE FROM grade WHERE gradeID=4 OR gradeID=5  OR gradeID=6;
DELETE FROM grade WHERE gradeID IN (4,5,6);

-- 同时插入多条数据  (oracle数据库不支持)
INSERT INTO grade(gradeID,gradeName) 
VALUES(4,'4年级'),(5,'5年级'),(6,'6年级');

--修改 update

-- 修改gradeID=1的年级名称为 one
UPDATE  grade SET gradeName='one'
WHERE gradeID=1

-- delete 删除表中所有的数据
DELETE FROM grade;

delete 和 truncate的区别
01.delete

begin  (开启事务)
select  * from  grade;(查询年级表中所有的数据) 
delete  from  grade; (删除年级表中所有的数据)
select  * from  grade;(查询年级表中所有的数据,没有数据) 
rollback;  (事务回滚)
select  * from  grade;(查询年级表中所有的数据,删除的数据恢复) 
commit (提交事务)

02.truncate

begin  (开启事务)
select  * from  grade;(查询年级表中所有的数据) 
truncate table  grade; (删除年级表中所有的数据)
select  * from  grade;(查询年级表中所有的数据,没有数据) 
rollback;  (事务回滚)
select  * from  grade;(查询年级表中所有的数据,没有数据) 
commit (提交事务)

区别:
  01.delete后面可以拼接where条件,删除指定的行!
     truncate只能删除表中所有的数据!不能有where!

02.delete可以回滚,数据库可以恢复!(记录日志)
     truncate 不能事务混滚,数据不可以恢复!(不记录日志)

03.truncate执行效率高! 
     delete执行效率低!

04.delete删除后自增列编号会接着上次最大值
     Truncate截断表:自增列编号从1开始

查询

将查询结果保存到 新表中!
 create table  newStudent
    (select stuName,address from  student)

view (视图) :不占物理空间!

使用 具体的列 代替 *

select  * from  student;

select  stuName,age ,address  from  student;

使用别名

SELECT gradeID AS 年级编号,gradeName  '年级 名称' FROM grade;

格式
01.  列名  AS  别名
02.  列名   别名
03.  如果别名中有特殊符号,必须把 别名用 单引号 引起来!

查询年级表中 id不等于1的数据   <>    !=
SELECT gradeID,gradeName 
FROM grade
WHERE gradeid <> 1

+  必须是相同的数据类型,能转换成2进制的数据!
如果有一个列是null  整体返回null!

我们通常使用 concat来做合并
SELECT  CONCAT(loginPwd,',',studentNAME) AS  合并列 FROM STUDENT

使用is null 的时候 要确保 查询的列 可以为空!

null:
  01.标识  空值
  02.不是0,也不是空串""
  03.只能出现在定义 允许为null的字段
  04.只能使用is  null 或者is not null 进行比较!

SELECT *  FROM student
WHERE loginPwd  IS NULL

-- 查询成绩表的总成绩
SELECT  SUM(studentResult)  FROM result;
-- 查询成绩的平均值
SELECT  AVG(studentResult)  FROM result;
-- 查询成绩的最高分
SELECT  MAX(studentResult)  FROM result;
-- 查询成绩的最低分
SELECT  MIN(studentResult)  FROM result;
-- 查询有成绩的总数
SELECT  COUNT(studentResult)  FROM result;

#修改表名
ALTER TABLE 旧表名RENAME [TO] 新表名;
#添加字段
ALTER TABLE 表名ADD 字段名数据类型[属性];
#修改字段
ALTER TABLE 表名CHANGE 原字段名新字段名数据类型[属性];
#删除字段
ALTER TABLE 表名DROP 字段名;

MySQL的DML和DQL 增删改查的更多相关文章

  1. MySQL数据库之表的增删改查

    目录 MySQL数据库之表的增删改查 1 引言 2 创建表 3 删除表 4 修改表 5 查看表 6 复制表 MySQL数据库之表的增删改查 1 引言 1.MySQL数据库中,数据库database就是 ...

  2. MYSQL - database 以及 table 的增删改查

    MYSQL - database 以及 table 的增删改查 MySQL的相关概念介绍 MySQL 为关系型数据库(Relational Database Management System), 这 ...

  3. 使用JDBC分别利用Statement和PreparedStatement来对MySQL数据库进行简单的增删改查以及SQL注入的原理

    一.MySQL数据库的下载及安装 https://www.mysql.com/ 点击DOWNLOADS,拉到页面底部,找到MySQL Community(GPL)Downloads,点击 选择下图中的 ...

  4. MySQL 之基础操作及增删改查等

    一:MySQL基础操作 使用方法: 方式一: 通过图型界面工具,如 Navicat,DBeaver等 方式二: 通过在命令行敲命令来操作 SQL ( Structure query language ...

  5. MYSQL的常用命令和增删改查语句和数据类型

    连接命令:<a href="http://lib.csdn.net/base/mysql" class='replace_word' title="MySQL知识库 ...

  6. MYSQL的常用命令和增删改查语句和数据类型【转】

    连接命令:<a href="http://lib.csdn.net/base/mysql" class='replace_word' title="MySQL知识库 ...

  7. nodejs+express+mysql实现restful风格的增删改查示例

    首先,放上项目github地址:https://github.com/codethereforam/express-mysql-demo 一.前言 之前学的java,一直用的ssm框架写后台.前段时间 ...

  8. node+mysql,实现基本的增删改查,附带跟踪记录和运行时间记录

    Node + mysql 实现基础的增删改查,以及性能测试. 网上有很多这样的例子,我也是找来学习的. 感觉node对mysql的操作非常简单,也很实用,比如自带防止sql注入的功能,一开始还担心注入 ...

  9. Mysql数据库和表的增删改查以及数据备份&恢复

    数据库 查看所有数据库 show databases; 使用数据库 use 数据库名; 查看当前使用的数据库 select database(); 创建数据库 create database 数据库名 ...

随机推荐

  1. Extract local angle of attack on wind turbine blades

    Extract local angle of attack on wind turbine blades Table of Contents 1. Extract local angle of att ...

  2. linux下的进程

    一.进程的基础: 1.程序:程序是一些保存在磁盘上的指令的有序集合: 2.进程:进程是程序的一次执行过程: 3.进程与程序的关系:①.程序是静态的,进程是动态的:  ②.一个程序可以对应多个进程:   ...

  3. shell输出颜色、printf输出颜色

    1.echo开启彩色输出: -e 开启echo中的转义: \e或者\033来输出Esc颜色: 恢复默认颜色为:\e[0m; 命令格式: echo -e "\e[字背景颜色:文字颜色m字符串\ ...

  4. MySQL导入-导出数据库-mac版

    MySQL导入-导出数据库-mac版 导出数据库-表结构,和数据 mysqldump -u 账号 -p 数据库名 表 > 文件名.sql 例如:mysqldump -u root -p test ...

  5. MongoDB增加用户、删除用户、修改用户读写权限及只读权限(注:转载于http://www.2cto.com/database/201203/125025.html)

    MongoDB  增加用户 删除用户  修改用户  读写权限 只读权限,   MongoDB用户权限分配的操作是针对某个库来说的.--这句话很重要.   1. 进入ljc 数据库:       use ...

  6. scrapy——中间件UserAgent代理

    pip install fake-useragent 使用说明:from fake_useragent import UserAgent# 实例化一个UserAgent对象ua = UserAgent ...

  7. [K/3Cloud]在插件中根据条件取消表单打开过程

    新建一个类,继承自动态表单抽象插件类AbstractBillPlugIn,重写PreOpenForm. /// <summary> /// 销售订单 单据维护界面插件 /// </s ...

  8. Mysql修改自增主键的起始值及查询自增主键的下一个值

    MySQL [xxx_mall]> alter table shop_base_info  AUTO_INCREMENT=11000;Query OK, 0 rows affected (0.0 ...

  9. BZOJ(3) 1051: [HAOI2006]受欢迎的牛

    1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 7365  Solved: 3937[Submit][Sta ...

  10. MyBatis与Spring MVC结合时,使用DAO注入出现:Invocation of init method failed; nested exception is java.lang.IllegalArgumentException: Property 'sqlSessionFactory' or 'sqlSessionTemplate' are required

    错误源自使用了这个例子:http://www.yihaomen.com/article/java/336.htm,如果运行时会出现如下错误: Invocation of init method fai ...