• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

如何使用python update()方法?代码操作过程

python 搞java代码 3年前 (2022-05-21) 45次浏览 已收录 0个评论

想必大家都不陌生吧,是最常见的python方法使用了,因此,好多小伙伴对于这块的转化,也要很长时间的消化,然后今天小编给大家总结了update方法的全部内容,一起来看下吧~

一、业务场景:

1)主从两个表,主表Student,有字段id、name、sex,从表Boy,有字段id、name,主从表同一对象id相同

2)从表Boy的name属性被业务修改,定时批量处理主表,以维持主表name属性与从表一致

二、表结构

1、主表 Student

2、从表 Boy

三、建表SQL(DDL)

1、主表 Student

- DDL
CREATE TABLE student (
id NUMBER NOT NULL ,
name VARCHAR2(255 BYTE) NULL ,
sex VARCHAR2(255 BYTE) NULL
)
 ALTER TABLE student ADD CHECK (id IS NOT NULL);
 
-- DML
INSERT INTO student VALUES ('1', 'zhangsan', 'boy');
INSERT INTO student VALUES ('2', 'lisi', 'girl');
INSERT INTO student VALUES ('3', 'wangwu', 'boy');、
www#gaodaima.com来源gaodai.ma#com搞##代!^码@网搞代码

2、从表 Boy

-- DDL
CREATE TABLE boy (
id NUMBER NOT NULL ,
name VARCHAR2(255 BYTE) NULL
)
 
-- DML
INSERT INTO boy VALUES ('1', '张三');
INSERT INTO boy VALUES ('3', '王五');

四、DML

1、基本语法

-- DML
UPDATE student s SET s.name = '张三' WHERE id = 1;

2、变相

 -- DML,0.015s
UPDATE student s
SET s.name = (
 SELECT b.name FROM boy b WHERE s.id = b.id AND s.name != b.name
)
WHERE EXISTS (
 SELECT 1 FROM boy b WHERE s.id = b.id AND s.name != b.name
);

3、快速游标法

 -- DML,0.014s
BEGIN
 FOR cur IN (
 SELECT s.id sid, b.name bname
 FROM student s, boy b
 WHERE s.id = b.id AND s.name != b.name AND s.sex = 'boy'
 ) loop
 
 UPDATE student s SET s.name = cur.bname WHERE s.id = cur.sid;
 
 END loop ;
END ;

4、内联视图法(inline View)

-- DML,0.019s
UPDATE (
 SELECT
 s.name sname, b.name bname
 FROM
 student s, boy b
 WHERE
 s.id = b.id AND s.name != b.name
)
SET sname = bname;

以上也运用了Oracle批量处理内容哦,如需了解更多python实用知识,点击进入云海天Python教程网

来源:搞代码网:原文地址:https://www.gaodaima.com


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:如何使用python update()方法?代码操作过程
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址