当前位置: 首页 > news >正文

discuz做网站赚钱经历网站做等级保护

discuz做网站赚钱经历,网站做等级保护,法语网站建站公司,做网站的是怎么赚钱的网罗开发 (小红书、快手、视频号同名) 大家好,我是 展菲,目前在上市企业从事人工智能项目研发管理工作,平时热衷于分享各种编程领域的软硬技能知识以及前沿技术,包括iOS、前端、Harmony OS、Java、Python等…

在这里插入图片描述
在这里插入图片描述

网罗开发 (小红书、快手、视频号同名)

  大家好,我是 展菲,目前在上市企业从事人工智能项目研发管理工作,平时热衷于分享各种编程领域的软硬技能知识以及前沿技术,包括iOS、前端、Harmony OS、Java、Python等方向。在移动端开发、鸿蒙开发、物联网、嵌入式、云原生、开源等领域有深厚造诣。

图书作者:《ESP32-C3 物联网工程开发实战》
图书作者:《SwiftUI 入门,进阶与实战》
超级个体:COC上海社区主理人
特约讲师:大学讲师,谷歌亚马逊分享嘉宾
科技博主:极星会首批签约作者

文章目录

    • 摘要
    • 描述
      • 问题背景
      • 输入输出示例
    • SQL 解法
    • Swift 题解代码
    • Swift 题解代码分析
      • SQL 查询逻辑
      • Swift 实现分析
    • 示例测试及结果
      • 测试 1
    • 时间复杂度
      • SQL 查询
    • 空间复杂度
    • 总结

摘要

在数据处理中,经常需要从关联表中筛选出符合条件的数据。本篇文章以“找出从未下订单的客户”为例,结合 SQL 查询和 Swift 编程,提供完整的解决方案。文章内容包括题解答案、代码分析、示例测试及结果展示,帮助开发者快速掌握此类问题的解决思路。

描述

问题背景

我们有两张表:

  1. Customers 表: 包含客户的 ID 和姓名。
  2. Orders 表: 包含订单的 ID 和关联的客户 ID。

任务是找出所有从未下过订单的客户,即那些在 Orders 表中没有任何记录的客户。

输入输出示例

输入:

Customers 表:

+----+-------+
| id | name  |
+----+-------+
| 1  | Joe   |
| 2  | Henry |
| 3  | Sam   |
| 4  | Max   |
+----+-------+

Orders 表:

+----+------------+
| id | customerId |
+----+------------+
| 1  | 3          |
| 2  | 1          |
+----+------------+

输出:

+-----------+
| Customers |
+-----------+
| Henry     |
| Max       |
+-----------+

解释: HenryMaxidOrders 表中不存在,因此他们是未下订单的客户。

SQL 解法

可以使用 LEFT JOINWHERE 条件来查找未下订单的客户。

SQL 查询如下:

SELECT C.name AS Customers
FROM Customers C
LEFT JOIN Orders O ON C.id = O.customerId
WHERE O.customerId IS NULL;

Swift 题解代码

以下是基于 Swift 的完整实现,使用 SQLite 数据库来存储和查询数据:

import SQLite3func findCustomersWithoutOrders(databasePath: String) -> [String] {var db: OpaquePointer?var stmt: OpaquePointer?var results: [String] = []// 打开数据库连接if sqlite3_open(databasePath, &db) == SQLITE_OK {let query = """SELECT C.name AS CustomersFROM Customers CLEFT JOIN Orders O ON C.id = O.customerIdWHERE O.customerId IS NULL;"""// 准备 SQL 查询if sqlite3_prepare_v2(db, query, -1, &stmt, nil) == SQLITE_OK {// 执行查询并获取结果while sqlite3_step(stmt) == SQLITE_ROW {if let cString = sqlite3_column_text(stmt, 0) {let customerName = String(cString: cString)results.append(customerName)}}} else {print("SQL Error: \(String(cString: sqlite3_errmsg(db)))")}// 清理资源sqlite3_finalize(stmt)}sqlite3_close(db)return results
}// 示例测试
let databasePath = "path_to_your_database.sqlite"
let customersWithoutOrders = findCustomersWithoutOrders(databasePath: databasePath)
print("Customers without orders: \(customersWithoutOrders)")

Swift 题解代码分析

SQL 查询逻辑

  1. LEFT JOIN 操作:

    • Customers 表和 Orders 表通过 idcustomerId 进行左连接。
    • 对每个客户,若没有匹配的订单记录,则 O.customerIdNULL
  2. WHERE 条件:

    • 筛选出 O.customerId IS NULL 的记录,即未下订单的客户。
  3. 结果返回:

    • 只返回符合条件客户的姓名。

Swift 实现分析

  1. 数据库连接:

    • 使用 sqlite3_open 连接 SQLite 数据库。
  2. 查询执行:

    • 使用 sqlite3_prepare_v2 准备 SQL 查询。
    • 遍历结果集,将每个未下订单客户的姓名添加到数组中。
  3. 结果输出:

    • 返回未下订单客户的姓名数组。

示例测试及结果

测试 1

数据库内容:
Customers 表:

+----+-------+
| id | name  |
+----+-------+
| 1  | Joe   |
| 2  | Henry |
| 3  | Sam   |
| 4  | Max   |
+----+-------+

Orders 表:

+----+------------+
| id | customerId |
+----+------------+
| 1  | 3          |
| 2  | 1          |
+----+------------+

运行代码:

let customersWithoutOrders = findCustomersWithoutOrders(databasePath: databasePath)
print("Customers without orders: \(customersWithoutOrders)")

输出结果:

Customers without orders: ["Henry", "Max"]

时间复杂度

SQL 查询

  1. 连接操作:
    • 时间复杂度为 (O(n \cdot m)),其中 (n) 是 Customers 表的记录数,(m) 是 Orders 表的记录数。
  2. 过滤条件:
    • 遍历每个记录的复杂度为 (O(n))。

总时间复杂度: (O(n \cdot m))。

空间复杂度

  1. 查询结果存储:
    • 空间复杂度为 (O(k)),其中 (k) 是未下订单客户的数量。

总空间复杂度: (O(k))。

总结

通过 SQL 和 Swift 的结合,我们成功实现了查询未下订单客户的功能。本文提供了完整的代码、详细的分析和测试结果,适合开发者学习和借鉴。此方法具有通用性,可扩展到其他类似的关联查询需求。在实践中,可以通过索引优化 Orders 表的连接键 customerId 提高查询性能。

http://www.yayakq.cn/news/12698/

相关文章:

  • 备案网站有哪些网店营销策划方案ppt
  • 国外的设计网站app吗百度广告点击软件
  • 长沙高校网站制作公司网站开发项目管理文档模板
  • 关键词网站建设公司做展柜在哪些网站找客户
  • 网站关键词 提醒做网站还挣钱吗
  • 社区微网站建设方案ppt模板下载重庆网站网络推广
  • 做网站备案地点自己怎做网站后台
  • 厦门成交型网站建设公司火车票网站建设多少钱
  • 忂州网站建设软件开发工作稳定吗
  • 永久免费做网站wordpress评论后不显示
  • 建设企业查询网站wordpress添加百度统计
  • php主机网站谁有手机网站啊介绍一下
  • dw做网站怎么连接gif图片高端酒店网站模板免费下载
  • 如何做别人的网站网页文件模板下载
  • 终身免费网站建设应用商店软件
  • 江苏省和城乡建设门户网站专门做童装的网站
  • 贵州省城乡和住房建设厅官方网站微信网站建设信息
  • 郑州商务网站建设自适应网站可以做伪静态页面吗
  • 包头市建设厅官方网站wordpress 自己创建主题
  • 如何管理网站页面设计小米手机官方网站
  • 网站姐姐做床戏网站网站建设工作有底薪吗
  • 资源收费网站怎么做网站建设发文章几点发比较合适
  • 教育局网站建设方案网站空间商盗取数据
  • 自己建设一个平台网站多少钱国外展柜网站
  • 做网站怎么防止被黑wordpress add_options_page
  • cad如何做图纸模板下载网站福州网站设计哪家比较好
  • 广安网站制作设计网站路径改版如何做301重定向
  • 在龙港网站哪里做搜索关键词排名提升
  • 网站后台文件名网站运营与建设作业
  • 专业的河南网站建设东营建设局网站