.Net程序增删改查

发布时间:2020-08-06 14:23:21 作者:sshpp
来源:网络 阅读:303

1、插入语句

INSERT 语句用来向表、分区或视图中添加行。可以向单个表或者多个表中添加数据行。单表插入将会向一个表中插入一行数据,这行数据可以显示地列出插入值也可以通过一个子查询来获取。多表插入将会向一个或多个表中插入行,并且会通过子查询获取值来计算所插入行的值。

1.1、INSERT

如果你要插入表中所定义的所有字段的值,那么字段的列表是可选的。但是如果你只想提供部分字段的值,则必须在字段的列表中指明所需的字段名。建议即便要插入所有字段的值,也明确给出字段列表。语法:

INSERT INTO target_table(column1, column2, ... column_n) VALUES(expression1, expression2, ... expression_n);

INSERT INTO target_table(column1, column2, ... column_n)SELECT expression1, expression2, ... expression_n FROM source_table [WHERE conditions];

示例:

-- 向 t_staff 表添加一条员工数据INSERT INTO demo.t_staff(staff_name, dept_code, gender, birthday, edu_bg, base_salary, post_salary, post_code)VALUES('李阳','010101',1,TO_DATE('1989-01-14','yyyy-mm-dd'),2,2500,8000,'P50');

1.2、INSERT ALL

语法:

INSERT [ALL/FIRST]  WHEN <expression> THEN INTO target_table1(column1, column2, column_n)  WHEN <expression> THEN INTO target_table2(column1, column2, column_n)  ELSE INTO target_table3(column1, column2, column_n)SELECT <column list> FROM source_table;

INSERT ALL
  INTO target_table1(column1, column2, column_n) VALUES(expr1, expr2, expr_n)
  INTO target_table2(column1, column2, column_n) VALUES(expr1, expr2, expr_n)
  INTO target_table3(column1, column2, column_n) VALUES(expr1, expr2, expr_n)
SELECT * FROM DUAL;

示例:

-- 向 t_field_enum 表中添加一条部门数据,同时向 t_staff 表添加一条员工数据INSERT ALL  INTO demo.t_field_enum(field_code, enum_code, enum_name, enum_level, enum_order)  VALUES('DEPT','010203','实施三部',3,3)  INTO demo.t_staff(staff_name, dept_code, gender, birthday, edu_bg, base_salary, post_salary, post_code)  VALUES('徐来','010202',1,TO_DATE('1991-04-01','yyyy-mm-dd'),1,2500,5200,'P50')SELECT * FROM DUAL;

同步插入:有时候我们需要把一张表中的数据分别插入到另外两张表中,如果不加事物仅写两条 INSERT 语句分别添加是有问题的,因为表中数据完全有可能在第一条语句执行之后第二条语句执行之前发生了变化。如要将 t_staff 表中月薪达到 8000 的 90 员工分别添加到 t_staff_high 和 t_staff_young 两个表中,示例:

INSERT ALL  INTO demo.t_staff_high(staff_id, staff_name, dept_code, gender)  INTO demo.t_staff_young(staff_id, staff_name, dept_code, gender)SELECT t.staff_id, t.staff_name, t.dept_code, t.gender FROM demo.t_staff tWHERE t.birthday>=TO_DATE('1990-01-01','yyyy-mm-dd') AND (t.base_salary+t.post_salary)>=8000;

有条件的插入:使用 INSERT ALL 语句还可以根据条件将数据插入到不同的表中。示例:

INSERT ALL  WHEN test_value<8 THEN INTO demo.t_staff_high(staff_id, staff_name, dept_code, gender)  WHEN test_value<7 THEN INTO demo.t_staff_low(staff_id, staff_name, dept_code, gender)  ELSE INTO demo.t_staff_copy(staff_id, staff_name, dept_code, gender)SELECT t.staff_id, t.staff_name, t.dept_code, t.gender FROM demo.t_staff t WHERE t.post_salary>=5000;

在上面的语句中,如果 test_value=6,岗位工资达到 5000 的员工会被插入到 t_staff_high 和 t_staff_low 两张表中;如果 test_value=7,岗位工资达到 5000 的员工会被插入到 t_staff_low 表中;如果 test_value=8,岗位工资达到 5000 的员工会被插入到 t_staff_copy 表中。

假如 test_value=6,也就是前两个条件都满足时,优先执行第一个插入,当第一个条件不满足时,再来判断是否要执行第二个条件的插入,这种情况只需把 ALL 换成 FIRST 即可实现。

2、删除语句

2.1、DELETE

DELETE 语句用来从表中移除数据行。该语句的语法结构由 3 部分组成:DELETE、FROM 和 WHERE。DELETE 关键字是单独列出的,没有其它选项与 DELETE 关键字相结合(hint除外)。FROM 子句用来指定要从那个表中删除数据行。WHERE 子句提供筛选条件有助于确定那些行是要删除的。语法:

DELETE FROM target_table [WHERE conditions];

示例:

-- 把 t_staff_high 表中名字叫“韩三”的职员删除DELETE FROM demo.t_staff_high t WHERE t.staff_name='韩三';

2.2、TRUNCATE

TRUNCATE 语句是用来清空表中数据的。从表面上看它的效果与不带 WHERE 条件的 DELETE 语句效果是一样的。它有 4 个特点,分别是:

如要把 t_staff_high 表中所有数据全部删除,示例:

TRUNCATE TABLE t_staff_high;

3、更新语句

3.1、UPDATE

UPDATE 语句的作用是改变表中原有行的字段值。这个语句的语法由3部分组成:UPDATE、SET 和 WHERE。UPDATE 子句用来指定要更新的表,SET 子句用来指明那些字段要被改变以及改变后的值,WHERE 子句用来指定要更新的行。语法:

UPDATE target_tableSET column1 = expression1,
    column2 = expression2,
    ...
    column_n = expression_n
[WHERE conditions];

示例:

-- 给所有女性职工的工资加 100UPDATE demo.t_staff t SET t.post_salary=t.post_salary+100 WHERE t.gender=0;

从语法的角度来说,UPDATE 语句完全可以不带条件,但实际需求中基本上都有条件。我曾维护过某医院的 EMR 系统,有一天医生反馈说,他们科室所有患者的年龄显示都一样,我仔细检查之后发现是因为修改患者信息的 SQL 语句没有 WHERE 条件。后来我问一个老员工相关代码怎么会那么烂,他说当初这块功能是让一帮还没毕业的研究生做的,可能他们不太懂 SQL 语句。我只想说,这种低级错误即便是专科实习生也不应该犯,因为会犯这种错误至少能说明3个问题,首先这人根本没搞明白需求或业务逻辑太差,需求是要改某一个患者的信息;其次 SQL 基础也很差;再次他可能太过自信或不负责任,发布后的代码中还有这么严重的 Bug 说明他自己没有认真测试过。当然了,那个公司也没有测试人员,不过这是另一个层面的问题了。

3.2、带子查询的 UPDATE

UPDATE 语句内部可以包含子查询,常见的有两种情况,一种是仅 WHERE 子句中带有查询,这种情况和带子查询的 SELECT 语句类似,可参考下文;另一种是 SET 子句中带有查询,本节主要介绍这种情况。语法:

UPDATE target_tableSET column1 = (SELECT expression1               FROM source_table               WHERE conditions)
[WHERE conditions];

尽管这个语法看起来很简单,但初次接触 Oracle 的开发人员极易写错,本人在工作中发现不少工龄超过 5 年的开发人员依然会用错这个语法(没写最后那个可选的 WHERE 条件,结果导致表中不符合查询条件的数据全都被改成了 NULL),当我口头指出这个问题的时候他们往往还不以为然,直到我把测试结果亮出来他们才恍然大悟。

我分析之所以会这样主要有两方面原因,一方面很多人会习惯性的认为,查询语句的 WHERE 条件里已经和要更新的目标表关联过了,那更新的时候自然就会只更新 WHERE 条件限定的这部分数据呀!其实这只是一厢情愿的想法,因为他们忽略了这个查询其实是个行间查询。另一方面,实际开发中必须用这个语法的情况很少,而低频应用开发中偶尔用一次,即便有问题只要当时没发现,被坑的也是下一个人(我就是那个被坑了 N 多次的人)。所以会有很多工作多年的开发人员依然不太理解这个语法。

假如发现 t_staff_salary 表中研发一部的员工固定工资计算错了,需要重新计算一下,示例:

UPDATE demo.t_staff_salary t1 
SET t1.fixed_salary=(SELECT t2.base_salary+t2.post_salary 
                     FROM demo.t_staff t2 
                     WHERE t2.staff_id=t1.staff_id AND t2.dept_code='010101')WHERE t1.dept_code='010101';

如果把上述语句中最后一个 WHERE 条件去掉,再次执行就会把除研发一部以外的其它部门员工固定工资都改成 NULL。

3.3、一次更新多个字段的 UPDATE

一次更新多个字段,这个说法看上去没有什么稀奇之处,最普通的 UPDATE 语句的 SET 子句后面本身就可以写多个字段。如果特殊点,其中一个字段的值来自另一张表的某个字段呢?上一节已经说过,写个子查询就能搞定。但如果再特殊一点,其中两个甚至多个字段来自另一张甚至多张表呢?语法:

UPDATE target_table  SET(column1,column2,column3...) = (  SELECT expression1,expression2,expression3...    FROM source_table    WHERE conditions)
[WHERE conditions];

举个例子,假如公司人员异动和调薪后,员工表 t_staff 中的数据已经更新,但 t_staff_salary 表中的部门和工资字段尚未同步更新,示例:

UPDATE demo.t_staff_salary t1 SET(t1.dept_code,t1.fixed_salary)=(  SELECT t2.dept_code,t2.base_salary+t2.post_salary FROM demo.t_staff t2 WHERE t1.staff_id=t2.staff_id
);

当然,有些朋友可能会想到下面这种更新方式,我在不知道上述语法时也经常用下面这种方式,示例:

TRUNCATE TABLE demo.t_staff_salary;INSERT INTO demo.t_staff_salary(staff_id,staff_name,dept_code,fixed_salary) 
SELECT t.staff_id,t.staff_name,t.dept_code,t.base_salary+t.post_salary FROM demo.t_staff t;

这种方式一般也是行的,但毕竟要更新整张表,某些时候表中部分字段里的数据其实是不能删的,那就不能用这种方式了。

4、查询语句

SELECT 语句用来从一个或多个表中或者其它数据库对象中提取数据。要想写出符合语法规则的高效 SQL 语句,需要理解 SQL 语句是如何执行的。一个查询语句在逻辑上的处理方式可能会与实际物理处理过程大相径庭。Oracle 基于查询成本的优化器(cost-based optimizer,CBO)用来产生实际的执行计划。

4.1、SELECT

语法:

SELECT expressions FROM target_table [WHERE conditions];

示例一:

-- 查询所有 90 后女员工的姓名SELECT t.staff_name FROM demo.t_staff t WHERE t.gender=0 AND t.birthday>=TO_DATE('1990-01-01','yyyy-mm-dd');

示例二:

-- 查询所有 90 后女员工的姓名和部门SELECT t1.staff_name,t2.enum_name dept_nameFROM demo.t_staff t1LEFT JOIN demo.t_field_enum t2 ON t1.dept_code=t2.enum_code AND t2.field_code='DEPT'WHERE t1.gender=0 AND t1.birthday>=TO_DATE('1990-01-01','yyyy-mm-dd');

4.2、带子查询的 SELECT

WHERE 子句带子查询:如要查询开发部所有员工的姓名和生日。示例:

SELECT t1.staff_name,t1.birthdayFROM demo.t_staff t1WHERE t1.dept_code IN(SELECT t3.enum_code FROM demo.t_field_enum t3 WHERE t3.parent_enum_id=2);

FROM 子句带子查询:如要查询所有部门的岗位工资之和。示例:

SELECT DISTINCT t2.enum_name dept_name,t3.total_post_salaryFROM demo.t_staff t1LEFT JOIN demo.t_field_enum t2 ON t1.dept_code=t2.enum_code AND t2.field_code='DEPT'LEFT JOIN(SELECT s1.dept_code,SUM(s1.post_salary) total_post_salary          FROM demo.t_staff s1 GROUP BY s1.dept_code) t3 ON t1.dept_code=t3.dept_code;

SELECT 子句带子查询:如要查询所有部门的人数。示例:

SELECT DISTINCT t2.enum_name dept_name,(SELECT COUNT(1) FROM demo.t_staff s1 
                                        WHERE s1.dept_code=t1.dept_code) total_staffFROM demo.t_staff t1LEFT JOIN demo.t_field_enum t2 ON t1.dept_code=t2.enum_code AND t2.field_code='DEPT';

4.3、查询语句的各子句详解

查询语句完整语法:

SELECT DISTINCT <select list>FROM <left source object> <join type> JOIN <right source object> ON <on predicates>WHERE <where predicates>GROUP BY <group by list>HAVING <having predicates>ORDER BY <order by list>;


推荐阅读:
  1. .net程序防止反编译
  2. .net 程序加密方法

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

net ne

上一篇:ArrayBlockingQueue 1.8 源码浅析

下一篇:python中函数定义可以接受参数吗

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》