SQL基础学习_03_数据更新
数据的插入
1. 基本INSERT语句
INSERT的基本语法为:
INSERT INTO <表名> (列1, 列2, 列3, …) VALUES (值1, 值2, 值3, …) ;
例如:INSERT INTO Shohin (shohin_mei,shohin_bunrui,hanbai_tanka,shiire_tanka,torokubi) VALUES ('pen','office',100,NULL,'2009-11-11');
如果插入的是所有列,则列名可以省略,如:
INSERT INTO Shohin VALUES (4,'pencil','office',200,NULL,'2009-11-11');
如果要插入NULL值,可以显示地插入NULL值,
如果某些字段设置了默认值(DEFAULT 约束),则在INSERT操作时,值可以显示填入DEFAULT以使用默认值,也可以直接忽略该字段,则会自动按默认值填写;
2. 从其他表中复制数据
使用
INSERT INTO <表1> (列1, 列2, 列3, …)
SELECT 列1, 列2, 列3, …
FROM <表2>
可以将表2中的所有记录按照列的对应关系复制到表1中 ;
可以在SELECT中使用聚合函数,并且可以使用GROUP BY对表格进行分组,如:
INSERT INTO ShohinBunrui (shohin_bunrui, sum_hanbai_tanka,sum_shiire_tanka)
SELECT shohin_bunrui, SUM(hanbai_tanka), SUM(shiire_tanka)
FROM Shohin
GROUP BY shohin_bunrui;
数据的删除
1. DELETE语句
使用DELETE语句可以指定删除表格中的某些记录:
DELETE FROM <表名>
WHERE <条件表达式>;
如果没有 WHERE子句,则会删除整个表的内容;
数据的更新
1. UPDATE语句
使用UPDATE语句可以对表中已有的数据进行更新:
UPDATE <表名>
SET <列1> = <表达式1>
<列2> = <表达式2>
(<列3>,<列4>,<列5>,…) = (<表达式3>,<表达式4>,<表达式5>,...)
WHERE <条件表达式>
如果没有WHERE子句,则会对所有的记录进行更新;
事务
1. 事务的定义和创建
事务是需要在同一个处理单元中执行的一系列更新处理的集合;
事务的语法为:
START TRANSACTION(MySQL) / BEGIN TRANSACTION(SQL Server, PostgreSQL)
DML1
DML2
DML3
…
COMMIT / ROLLBACK
2. 事务的特点和应用
事务具有原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability),通常被成为ACIO特性;
原子性:一个事务是一个原子操作,事务中的DML语句要么全部都执行,要么完全不执行;
一致性:在事务中如果有一条DML语句不能正常执行,则整个事务都不会被正常执行;
隔离性:不同事务之间互不干扰,在事务结束之前,事务中的一切修改对其他事务都不可见;
持久性:事务一旦结束,数据库系统会保证该时点的数据状态得以保存,即使由于系统故障导致数据丢失,数据库也一定能通过某种手段进行恢复(如产生日志等);
3. 事务的提交和取消
事务使用COMMIT/ROLLBACK来结束,
其中COMMIT表示提交该事务,事务中的内容会被原子执行;
ROLLBACK表示取消该事务,事务中的内容完全不会被执行,表中的数据恢复到事务之前的状态;
SQL基础学习_03_数据更新的更多相关文章
- Oracle SQL 基础学习
oracel sql 基础学习 CREATE TABLE USERINFO ( ID ,) PRIMARY KEY, USERNAME ), USERPWD ), EMAIL ), REDATE DA ...
- SQL 基础学习(2) Joining 和function , 作业没有做,需要看百宝箱。NOsql的概念
SQL 基础学习(2) Joining 可以同时关联(joining)多张表进行复杂的查询. 相比于用Rails捞出数据再用Ruby进行过滤组合,使用SQL更加高效,节能. 以下是 users has ...
- SQL 基础学习(1):下载DB Browser for SQLite. 下载graphviz(为了使用Rails ERD的前提)出现❌,已debug.
SQL is a standard language for storing, manipulating and retrieving data in databases. 关系型数据库:RDBMS( ...
- SQL基础学习_04_视图
视图 1. 视图的创建 视图就是保存好的SELECT语句,这些SELECT语句执行之后会产生新的表,所以在SQL中,视图和表是不做差别对待的,也就是SQL也可以对视图做一些操作: 由于 ...
- sql基础学习
学习参考网站:http://www.runoob.com/sql/sql-tutorial.html 一.SQL命令 1.SELECT 语句 用于从数据库中选取数据. select column_na ...
- SQL基础学习_05_函数、谓词、CASE表达式
函数 算术函数 1. 四则运算: +.-.*./ 2. ABS:求绝对值, ABS(数值) 3. MOD: 求余,MOD(被除数,除数) 4. ROUND:四舍五入,ROUND(对象数值,保留小数的 ...
- SQL基础学习_02_查询
SELECT语句 1. SELECT语句查询列(字段): SELECT <列名> FROM <表名>; 该语句使用了两个SQL子句,SELECT子句列举了 ...
- SQL基础学习_01_数据库和表
SQL语句及其种类 1. SQL语句分为三类: DDL(Data Definition Language): CREATE.DROP.ALTER; DML(Data Manipulat ...
- SQL基础学习篇--字符函数
字符函数可与SELECT,UPDATE,DELETE RIGHT()----从右侧开始选择 SELECT RIGHT(列,字符数量) FROM 表 LEFT()----从左侧开始选择 SUBSTR ...
随机推荐
- 使用pg_buffercache查看缓存区缓存
PG提供了一个扩展pg_buffercache来查看缓存区的内容. create database test; CREATE DATABASE create extension pg_bufferca ...
- Heritrix1.14.4在Eclipse的配置和使用
转载 1.首先在 Eclipse 中新建 Java 工程 ,工程名自取,以MyHeritrix为例.利用下载的源代码包根据以下步骤来配置这个工程. 2.导入类库 Heritrix 所用到的工具类库都在 ...
- Android 7.1 屏幕旋转流程分析
Android 7.1 屏幕旋转流程分析 一.概述 Android屏幕的旋转在framework主要涉及到三个类,结构如图 PhoneWindowManager:为屏幕的横竖屏转换的管理类. Wi ...
- PHP curl_setopt函数用法介绍
[导读] curl_setopt函数是php中一个重要的函数,它可以模仿用户的一些行为,如模仿用户登录,注册等等一些用户可操作的行为哦.bool curl_setopt (int ch, string ...
- 如何在你的blog中添加炫酷的飘雪动画效果
将下面的代码复制到你的设置栏下页眉html代码框中即可 <script> (function($){$.fn.snow=function(options){,maxSize:,newOn: ...
- [Sqoop]利用sqoop对mysql运行DML操作
业务背景 利用sqoop对mysql进行查询.加入.删除等操作. 业务实现 select操作: sqoop eval \ --connect jdbc:mysql://127.0.0.1:3306/m ...
- 【ASP.NET MVC】MVC概述
描述 本篇文章主要概述ASP.NET MVC,具体包括如下内容: 1.MVC模式概述 2.WebForm概述 3.WebForm与MVC区别 4.ASP.NET MVC发展历程 5.运用程序结构 6. ...
- 后台程序处理(二) python threading - queue 模块使用
由于协程没办法完成(一)中所说的任务模式 接下来就尝试一下使用线程和队列来实现一下这个功能 在实现之前,我们先明确一个问题--python的线程是伪并发的.同一时间只能有一个线程在运行.具体怎样的运作 ...
- Nginx各种配置
日志 日志中属性 $remote_addr,$http_x_forwarded_for 记录客户端IP地址 $remote_user 记录客户端用户名称 $request 记录请求的URL和HTTP协 ...
- 《分布式系统原理介绍》【PDF】下载
内容简介 分布式系统理论体系非常庞大,涉及知识面也非常广博,本文精心选择了部分在工程实践中应用广泛.简单有效的分布式理论.算法.协议加以介绍.全文分为两大部分,第一部分介绍了分布式系统的一些基本概念并 ...