关于如何理解 not exists 的好比喻 not exists = not in;exists= in

本文探讨了SQL中EXISTS与IN、NOT EXISTS与NOT IN的区别及效率对比,并通过实例展示了如何利用EXISTS条件句避免在数据库表中插入重复记录。

简单的理解就是 not exists = not in;exists= in

 

但这只是简单的理解而已,其里面的执行机制和细微处还是有一定的差别!

 

以下是从网络上摘录下的文章:

 

SQL里的EXISTS与in、not exists与not in 效率比较和使用

在 MSSQL 中,插入(insert)一条记录很简单,但是一些特殊应用,在插入记录前,需要检查这条记录是否已经存在,只有当记录不存在时才执行插入操作,本文介绍的就是这个问题的解决方案。


问题: 我创建了一个表来存放客户信息,我知道可以用 insert 语句插入信息到表中,但是怎么样才能保证不会插入重复的记录呢?

答案: 可以通过使用 EXISTS 条件句防止插入重复记录。


示例一:插入多条记录

假设有一个主键为 client_id 的 clients 表,可以使用下面的语句:

Code:


INSERT INTO clients
(client_id, client_name, client_type)
SELECT supplier_id, supplier_name, 'advertising'
FROM suppliers
WHERE not exists (select * from clients
where clients.client_id = suppliers.supplier_id);

 

个人批注:not exists不存在,也就是说后面的括号中只要返回了数据那么这个条件就不存在了,可以理解为括号前的not

exists是一个左表达式 ,括号后的查询是一个右表达式,只有当右表达式返回的也是not exists(即后面的查询出来的结果是非空的)时,等式才成立。

转载于:https://www.cnblogs.com/cy163/archive/2008/10/17/1313325.html

对一个不懂计算机的本科生,用通俗易懂的话,讲述以下的python代码,要确保能讲懂,并解释清楚代码中每一行的内容和作用以及每一部分内容和作用,讲解整个代码的清晰思路(一定要用最通俗易懂的话将代码给一个什么都不懂的本科生讲清楚) import os import sys import logging import subprocess from paddleocr import PaddleOCR logging.basicConfig( level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s' ) logger = logging.getLogger(__name__) def fix_numpy(): try: import numpy as np from packaging import version if version.parse(np.__version__) >= version.parse("2.0.0"): logger.warning("检测到 NumPy 2.x,正在降级到 1.x...") subprocess.check_call( [sys.executable, "-m", "pip", "install", "numpy<2.0", "-q"] ) logger.warning("请重新运行脚本以应用新 NumPy!") sys.exit(1) except Exception as e: logger.error("检查/修复 NumPy 失败:%s", e) fix_numpy() def init_ocr(): logger.info("正在加载 PP-OCRv3/v5 手写模型...") try: ocr = PaddleOCR( lang='ch', device='cpu', use_textline_orientation=True ) return ocr except Exception as e: logger.error("OCR 初始化失败:%s", e) return None def rec_vertical(image_path: str, ocr): if not os.path.exists(image_path): logger.error("图片不存在:%s", image_path) return False results = ocr.predict(image_path) if not results: logger.warning("未识别到任何结果") return False page = results[0] texts = page.get('rec_texts', []) # 识别文字列表 scores = page.get('rec_scores', []) # 置信度列表 polys = page.get('rec_polys', []) # 四点坐标列表 if not texts: logger.warning("未识别到有效文字") return False boxes_txts = [] for txt, conf, box in zip(texts, scores, polys): if conf < 0.5: continue x = min(pt[0] for pt in box) boxes_txts.append((x, txt, conf)) boxes_txts.sort(reverse=True, key=lambda t: t[0]) logger.info("毛笔字识别结果(从右到左):") for idx, (_, txt, conf) in enumerate(boxes_txts, 1): print(f"{idx}. {txt} (置信度:{conf:.2f})") return True if __name__ == "__main__": img_path = "image.png" ocr = init_ocr() if not ocr: sys.exit(1) if rec_vertical(img_path, ocr): logger.info("识别完成!") else: logger.error("识别失败")
最新发布
08-30
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值