python: SQLAlchemy (ORM) Simple example using SQLite

  • 领域层(Domain):定义了 School 实体类和 SchoolRepository 抽象基类,明确了业务实体和数据访问的契约。
  • 基础设施层(Infrastructure):通过 SQLAlchemy 实现了 SchoolRepository 类,负责与 SQLite 数据库进行交互,包括增删改查操作。
  • 应用层(Application)SchoolService 类封装了业务逻辑,调用 SchoolRepository 接口的方法完成具体的业务操作。
  • 表现层(Presentation)
    • SchoolView 类负责创建和管理用户界面,包括搜索框、ttk.Treeview 表格、操作按钮和分页按钮。
    • SchoolController 类处理用户的操作请求,调用 SchoolService 完成相应的业务逻辑,并更新视图。

项目结构:

领域层(Domain):

# encoding: utf-8
# 版权所有 2025 ©涂聚文有限公司 ®
# 许可信息查看:言語成了邀功盡責的功臣,還需要行爲每日來值班嗎
# 描述:
# Author    : geovindu,Geovin Du 涂聚文.
# IDE       : PyCharm 2023.1 python 3.11
# OS        : windows 10
# database  : mysql 9.0 sql server 2019, poostgreSQL 17.0  oracle 21c Neo4j
# Datetime  : 2025/2/19 20:39
# User      : geovindu
# Product   : PyCharm
# Project   : pySQLiteDDDOrmDemo
# File      : domain/entities/school.py
# explain   : 学习class School:"""领域层(Domain)"""def __init__(self, school_id, school_name, school_tel_no):""":param school_id::param school_name::param school_tel_no:"""self.school_id = school_idself.school_name = school_nameself.school_tel_no = school_tel_no# encoding: utf-8
# 版权所有 2025 ©涂聚文有限公司 ®
# 许可信息查看:言語成了邀功盡責的功臣,還需要行爲每日來值班嗎
# 描述:
# Author    : geovindu,Geovin Du 涂聚文.
# IDE       : PyCharm 2023.1 python 3.11
# OS        : windows 10
# database  : mysql 9.0 sql server 2019, poostgreSQL 17.0  oracle 21c Neo4j
# Datetime  : 2025/2/19 20:40
# User      : geovindu
# Product   : PyCharm
# Project   : pySQLiteDDDOrmDemo
# File      : domain/repositories/schoolRepositories.py
# explain   : 学习
from abc import ABC, abstractmethod
from typing import List
from ..entities.school import Schoolclass SchoolRepository(ABC):"""领域层(Domain) 接口"""@abstractmethoddef add(self, school: School):""":param school::return:"""pass@abstractmethoddef update(self, school: School):""":param school::return:"""pass@abstractmethoddef delete(self, school_id: str):""":param school_id::return:"""pass@abstractmethoddef get_all(self, page: int, page_size: int, search_query: str = "") -> List[School]:""":param page::param page_size::param search_query::return:"""pass@abstractmethoddef get_total_count(self, search_query: str = "") -> int:""":param search_query::return:"""pass


基础设施层(Infrastructure):

# encoding: utf-8
# 版权所有 2025 涂聚文有限公司
# 许可信息查看:言語成了邀功盡責的功臣,還需要行爲每日來值班嗎
# 描述:
# Author    : geovindu,Geovin Du 涂聚文.
# IDE       : PyCharm 2023.1 python 3.11
# os        : windows 10
# database  : mysql 9.0 sql server 2019, poostgreSQL 17.0  Oracle 21c
# Datetime  : 2025/2/19 21:30
# User      : geovindu
# Product   : PyCharm
# Project   : pySQLiteDDDOrmDemo
# File      : school.py
# explain   : 学习from sqlalchemy import create_engine, Column, String
from sqlalchemy.orm import sessionmaker, declarative_base
from domain.entities.school import School
from ..database.sqlitehelper import SqliteHelperBase = declarative_base()class SchoolModel(Base):"""基础设施层(Infrastructure)"""__tablename__ = 'School'SchoolId = Column(String, primary_key=True)SchoolName = Column(String, nullable=False)SchoolTelNo = Column(String, nullable=False)# encoding: utf-8
# 版权所有 2025 ©涂聚文有限公司 ®
# 许可信息查看:言語成了邀功盡責的功臣,還需要行爲每日來值班嗎
# 描述:
# Author    : geovindu,Geovin Du 涂聚文.
# IDE       : PyCharm 2023.1 python 3.11
# OS        : windows 10
# database  : mysql 9.0 sql server 2019, poostgreSQL 17.0  oracle 21c Neo4j
# Datetime  : 2025/2/19 21:41
# User      : geovindu
# Product   : PyCharm
# Project   : pySQLiteDDDOrmDemo
# File      : school.py
# explain   : 学习from sqlalchemy import create_engine, Column, String
from sqlalchemy.orm import sessionmaker, declarative_base
from domain.entities.school import School
from ..database.sqlitehelper import SqliteHelper
from ..model.school import SchoolModelclass SchoolRepository:"""基础设施层(Infrastructure)"""def __init__(self):""""""self._session = SqliteHelper()  # Session()def add(self, school: School):""":param school::return:"""session = self._session.getSession()    #  Session()  #school_model = SchoolModel(SchoolId=school.school_id, SchoolName=school.school_name,SchoolTelNo=school.school_tel_no)session.add(school_model)session.commit()session.close()def update(self, school: School):""":param school::return:"""session =  self._session.getSession()    # Session() #school_model = session.query(SchoolModel).filter_by(SchoolId=school.school_id).first()if school_model:school_model.SchoolName = school.school_nameschool_model.SchoolTelNo = school.school_tel_nosession.commit()session.close()def delete(self, school_id: str):""":param school_id::return:"""session =  self._session.getSession()    # Session()  #school_model = session.query(SchoolModel).filter_by(SchoolId=school_id).first()if school_model:session.delete(school_model)session.commit()session.close()def get_all(self, page: int, page_size: int, search_query: str = ""):""":param page::param page_size::param search_query::return:"""session = self._session.getSession()  #  Session()  #query = session.query(SchoolModel)if search_query:query = query.filter((SchoolModel.SchoolId.contains(search_query)) |(SchoolModel.SchoolName.contains(search_query)) |(SchoolModel.SchoolTelNo.contains(search_query)))offset = (page - 1) * page_sizeschool_models = query.offset(offset).limit(page_size).all()session.close()return [School(school.SchoolId, school.SchoolName, school.SchoolTelNo) for school in school_models]def get_total_count(self, search_query: str = ""):""":param search_query::return:"""session = self._session.getSession()    # Session()  #query = session.query(SchoolModel)if search_query:query = query.filter((SchoolModel.SchoolId.contains(search_query)) |(SchoolModel.SchoolName.contains(search_query)) |(SchoolModel.SchoolTelNo.contains(search_query)))count = query.count()session.close()return count


应用层(Application):

# encoding: utf-8
# 版权所有 2025 ©涂聚文有限公司 ®
# 许可信息查看:言語成了邀功盡責的功臣,還需要行爲每日來值班嗎
# 描述:
# Author    : geovindu,Geovin Du 涂聚文.
# IDE       : PyCharm 2023.1 python 3.11
# OS        : windows 10
# database  : mysql 9.0 sql server 2019, poostgreSQL 17.0  oracle 21c Neo4j
# Datetime  : 2025/2/19 21:10
# User      : geovindu
# Product   : PyCharm
# Project   : pySQLiteDDDOrmDemo
# File      : application/services/schoolServices.py
# explain   : 学习from typing import List
from domain.entities.school import School
from domain.repositories.schoolRepositories import SchoolRepositoryclass SchoolService:"""应用层(Application)"""def __init__(self, repository: SchoolRepository):""":param repository:"""self.repository = repositorydef add_school(self, school: School):""":param school::return:"""self.repository.add(school)def update_school(self, school: School):""":param school::return:"""self.repository.update(school)def delete_school(self, school_id: str):""":param school_id::return:"""self.repository.delete(school_id)def get_schools(self, page: int, page_size: int, search_query: str = "") -> List[School]:""":param page::param page_size::param search_query::return:"""return self.repository.get_all(page, page_size, search_query)def get_total_count(self, search_query: str = "") -> int:""":param search_query::return:"""return self.repository.get_total_count(search_query)


表现层(Presentation):

# encoding: utf-8
# 版权所有 2025 ©涂聚文有限公司 ®
# 许可信息查看:言語成了邀功盡責的功臣,還需要行爲每日來值班嗎
# 描述:
# Author    : geovindu,Geovin Du 涂聚文.
# IDE       : PyCharm 2023.1 python 3.11
# OS        : windows 10
# database  : mysql 9.0 sql server 2019, poostgreSQL 17.0  oracle 21c Neo4j
# Datetime  : 2025/2/19 18:46
# User      : geovindu
# Product   : PyCharm
# Project   : pySQLiteDDDOrmDemo
# File      : presentation/views/schoolViews.py
# explain   : 学习import tkinter as tk
from tkinter import ttkclass SchoolView:"""表现层(Presentation) UI"""def __init__(self, root):self.root = rootself.root.title("School Management")# 搜索框self.search_frame = ttk.Frame(root)self.search_frame.pack(pady=10)self.search_entry = ttk.Entry(self.search_frame)self.search_entry.pack(side=tk.LEFT, padx=5)self.search_button = ttk.Button(self.search_frame, text="Search")self.search_button.pack(side=tk.LEFT)# Treeviewself.tree = ttk.Treeview(root, columns=('SchoolId', 'SchoolName', 'SchoolTelNo'), show='headings')self.tree.heading('SchoolId', text='School ID')self.tree.heading('SchoolName', text='School Name')self.tree.heading('SchoolTelNo', text='School Tel No')self.tree.pack(pady=10)# 操作按钮self.button_frame = ttk.Frame(root)self.button_frame.pack(pady=10)self.add_button = ttk.Button(self.button_frame, text="Add")self.add_button.pack(side=tk.LEFT, padx=5)self.edit_button = ttk.Button(self.button_frame, text="Edit")self.edit_button.pack(side=tk.LEFT, padx=5)self.delete_button = ttk.Button(self.button_frame, text="Delete")self.delete_button.pack(side=tk.LEFT, padx=5)# 分页按钮self.pagination_frame = ttk.Frame(root)self.pagination_frame.pack(pady=10)self.prev_button = ttk.Button(self.pagination_frame, text="Previous")self.prev_button.pack(side=tk.LEFT, padx=5)self.page_label = ttk.Label(self.pagination_frame, text="Page 1 of 1")self.page_label.pack(side=tk.LEFT, padx=5)self.next_button = ttk.Button(self.pagination_frame, text="Next")self.next_button.pack(side=tk.LEFT, padx=5)def clear_tree(self):for item in self.tree.get_children():self.tree.delete(item)def populate_tree(self, schools):for school in schools:self.tree.insert('', 'end', values=(school.school_id, school.school_name, school.school_tel_no))def update_page_label(self, current_page, total_pages):self.page_label.config(text=f"Page {current_page} of {total_pages}")def open_add_window(self, save_callback):top = tk.Toplevel(self.root)top.title("Add School")ttk.Label(top, text="School ID:").grid(row=0, column=0, padx=5, pady=5)id_entry = ttk.Entry(top)id_entry.grid(row=0, column=1, padx=5, pady=5)ttk.Label(top, text="School Name:").grid(row=1, column=0, padx=5, pady=5)name_entry = ttk.Entry(top)name_entry.grid(row=1, column=1, padx=5, pady=5)ttk.Label(top, text="School Tel No:").grid(row=2, column=0, padx=5, pady=5)tel_entry = ttk.Entry(top)tel_entry.grid(row=2, column=1, padx=5, pady=5)def save_school():school_id = id_entry.get()school_name = name_entry.get()school_tel_no = tel_entry.get()if school_id and school_name and school_tel_no:save_callback(school_id, school_name, school_tel_no)top.destroy()ttk.Button(top, text="Save", command=save_school).grid(row=3, column=0, columnspan=2, pady=10)def open_edit_window(self, school_id, school_name, school_tel_no, update_callback):top = tk.Toplevel(self.root)top.title("Edit School")ttk.Label(top, text="School ID:").grid(row=0, column=0, padx=5, pady=5)id_entry = ttk.Entry(top)id_entry.insert(0, school_id)id_entry.config(state='readonly')id_entry.grid(row=0, column=1, padx=5, pady=5)ttk.Label(top, text="School Name:").grid(row=1, column=0, padx=5, pady=5)name_entry = ttk.Entry(top)name_entry.insert(0, school_name)name_entry.grid(row=1, column=1, padx=5, pady=5)ttk.Label(top, text="School Tel No:").grid(row=2, column=0, padx=5, pady=5)tel_entry = ttk.Entry(top)tel_entry.insert(0, school_tel_no)tel_entry.grid(row=2, column=1, padx=5, pady=5)def update_school():new_school_name = name_entry.get()new_school_tel_no = tel_entry.get()if new_school_name and new_school_tel_no:update_callback(school_id, new_school_name, new_school_tel_no)top.destroy()ttk.Button(top, text="Update", command=update_school).grid(row=3, column=0, columnspan=2, pady=10)# encoding: utf-8
# 版权所有 2025 ©涂聚文有限公司 ®
# 许可信息查看:言語成了邀功盡責的功臣,還需要行爲每日來值班嗎
# 描述: controllers  views 可以分开
# Author    : geovindu,Geovin Du 涂聚文.
# IDE       : PyCharm 2023.1 python 3.11
# OS        : windows 10
# database  : mysql 9.0 sql server 2019, poostgreSQL 17.0  oracle 21c Neo4j
# Datetime  : 2025/2/19 21:48
# User      : geovindu
# Product   : PyCharm
# Project   : pySQLiteDDDOrmDemo
# File      : presentation/controllers/schoolControllers.py
# explain   : 学习import tkinter as tk
from application.services.schoolServices import SchoolService
from domain.entities.school import Schoolclass SchoolController:"""表现层(Presentation)"""def __init__(self, service: SchoolService, view):""":param service::param view:"""self.service = serviceself.view = viewself.current_page = 1self.page_size = 10self.search_query = ""self.total_pages = 1self.view.search_button.config(command=self.search)self.view.add_button.config(command=self.add)self.view.edit_button.config(command=self.edit)self.view.delete_button.config(command=self.delete)self.view.prev_button.config(command=self.prev_page)self.view.next_button.config(command=self.next_page)self.load_data()def load_data(self):""":return:"""schools = self.service.get_schools(self.current_page, self.page_size, self.search_query)total_count = self.service.get_total_count(self.search_query)self.total_pages = (total_count + self.page_size - 1) // self.page_sizeself.view.clear_tree()self.view.populate_tree(schools)self.view.update_page_label(self.current_page, self.total_pages)self.view.prev_button.config(state=tk.NORMAL if self.current_page > 1 else tk.DISABLED)self.view.next_button.config(state=tk.NORMAL if self.current_page < self.total_pages else tk.DISABLED)def search(self):""":return:"""self.search_query = self.view.search_entry.get()self.current_page = 1self.load_data()def add(self):""":return:"""def save_callback(school_id, school_name, school_tel_no):new_school = School(school_id, school_name, school_tel_no)self.service.add_school(new_school)self.load_data()self.view.open_add_window(save_callback)def edit(self):""":return:"""selected_item = self.view.tree.selection()if selected_item:values = self.view.tree.item(selected_item, 'values')school_id, school_name, school_tel_no = valuesdef update_callback(school_id, new_school_name, new_school_tel_no):updated_school = School(school_id, new_school_name, new_school_tel_no)self.service.update_school(updated_school)self.load_data()self.view.open_edit_window(school_id, school_name, school_tel_no, update_callback)def delete(self):""":return:"""selected_item = self.view.tree.selection()if selected_item:school_id = self.view.tree.item(selected_item, 'values')[0]self.service.delete_school(school_id)self.load_data()def prev_page(self):"""下一页:return:"""if self.current_page > 1:self.current_page -= 1self.load_data()def next_page(self):"""上一页:return:"""if self.current_page < self.total_pages:self.current_page += 1self.load_data()

调用:

# encoding: utf-8
# 版权所有 2025 涂聚文有限公司
# 许可信息查看:言語成了邀功盡責的功臣,還需要行爲每日來值班嗎
# 描述:  Object-Relational Mapping (ORM)
# Author    : geovindu,Geovin Du 涂聚文.
# IDE       : PyCharm 2023.1 python 3.11
# os        : windows 10
# database  : mysql 9.0 sql server 2019, poostgreSQL 17.0  Oracle 21c
# Datetime  : 2025/2/19 21:02
# User      : geovindu
# Product   : PyCharm
# Project   : pySQLiteDDDOrmDemo
# File      : main.py
# explain   : 学习
import tkinter as tkfrom Infrastructure.repository.school import SchoolRepository
from application.services.schoolServices import SchoolService
from presentation.views.schoolViews import SchoolView
from presentation.controllers.schoolControllers import SchoolControllerif __name__ == '__main__':""""""root = tk.Tk()repository = SchoolRepository()service = SchoolService(repository)view = SchoolView(root)controller = SchoolController(service, view)root.iconbitmap("favicon.ico")root.mainloop()print('PyCharm,geovindu,Geovin Du,塗聚文,涂聚文')

输出:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/20599.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MySQL数据库入门到大蛇尚硅谷宋红康老师笔记 高级篇 part 1

第01章_Linux下MySQL的安装与使用 首先在vmware中下载centos7&#xff0c;实际上8更好一点&#xff0c;不过centos已经是时代的眼泪了&#xff0c;我之前已经教过了&#xff0c;不过是忘了&#xff0c;所以重新说一遍&#xff0c;看文档即可 2.开机前修改mac地址 &#xff0…

谈谈 ES 6.8 到 7.10 的功能变迁(1)- 性能优化篇

前言 ES 7.10 可能是现在比较常见的 ES 版本。但是对于一些相迭代比较慢的早期业务系统来说&#xff0c;ES 6.8 是一个名副其实的“钉子户”。 借着工作内升级调研的任务东风&#xff0c;我整理从 ES 6.8 到 ES 7.10 ELastic 重点列出的新增功能和优化内容。将分为 6 个篇幅给…

Vue前端开发-Vant组件之Button组件

Vant 有丰富的UI组件&#xff0c;而基础组件是全部组件的核心&#xff0c;基础组件中将常用的元素做了二次的开发&#xff0c;封装成Vant格式组件&#xff0c;如按钮、图片和布局等&#xff0c;这些封装后的Vant组件&#xff0c;提供了更多面向实际应用的属性和事件&#xff0c…

《机器学习数学基础》补充资料:求解线性方程组的克拉默法则

《机器学习数学基础》中并没有将解线性方程组作为重点&#xff0c;只是在第2章2.4.2节做了比较完整的概述。这是因为&#xff0c;如果用程序求解线性方程组&#xff0c;相对于高等数学教材中强调的手工求解&#xff0c;要简单得多了。 本文是关于线性方程组的拓展&#xff0c;供…

力扣 买卖股票的最佳时机

贪心算法典型例题。 题目 做过股票交易的都知道&#xff0c;想获取最大利润&#xff0c;就得从最低点买入&#xff0c;最高点卖出。这题刚好可以用暴力&#xff0c;一个数组中找到最大的数跟最小的数&#xff0c;然后注意一下最小的数在最大的数前面即可。从一个数组中选两个数…

idea无法联网,离线安装插件

插件地址&#xff1a;https://plugins.jetbrains.com/ JetBrains Marketplace 如果无法进入&#xff0c;可以试试 配置hosts 3.163.125.103 plugins.jetbrains.com ip 变了&#xff0c;可以查询个最新的&#xff1a; https://tool.chinaz.com/speedtest/plugins.jetbrai…

【Spring详解一】Spring整体架构和环境搭建

一、Spring整体架构和环境搭建 1.1 Spring的整体架构 Spring框架是一个分层架构&#xff0c;包含一系列功能要素&#xff0c;被分为大约20个模块 Spring核心容器&#xff1a;包含Core、Bean、Context、Expression Language模块 Core &#xff1a;其他组件的基本核心&#xff…

Spring Boot 定时任务:轻松实现任务自动化

在现代应用开发中&#xff0c;定时任务是一个常见的需求。比如&#xff0c;我们可能需要定时清理过期数据、定时发送邮件通知等。 操作流程 开启定时任务注解 在启动类添加注解EnableScheduling 设置时间&#xff08;固定时间间隔&#xff09; 使用 Scheduled 注解创建定时…

DeepSeek R1生成图片总结2(虽然本身是不能直接生成图片,但是可以想办法利用别的工具一起实现)

DeepSeek官网 目前阶段&#xff0c;DeepSeek R1是不能直接生成图片的&#xff0c;但可以通过优化文本后转换为SVG或HTML代码&#xff0c;再保存为图片。另外&#xff0c;Janus-Pro是DeepSeek的多模态模型&#xff0c;支持文生图&#xff0c;但需要本地部署或者使用第三方工具。…

燧光 XimmerseMR SDK接入Unity

官网SDK文档连接&#xff1a; RhinoX Unity XR SDK 一&#xff1a;下载SDK 下载链接&#xff1a;RhinoX Unity XR SDK 二&#xff1a;打开Unity项目&#xff0c;添加Package 1、先添加XR Core Utilties包和XR Interaction Toolkit包 2、导 2、再导入下载好的燧光SDK 三&…

vue学习笔记

结合目录&#xff0c;点击阅读 文章目录 案例1&#xff1a;第一行vue代码App.vue引入Person.vue案例&#xff1a;改变变量的值案例&#xff1a;改变对象属性值案例&#xff1a;toRefs进行解包案例&#xff1a;给名字首字母大写案例&#xff1a;监视变量值的变化案例&#xff1…

初学PADS使用技巧笔记(也许会继续更新)

操作意图&#xff1a;网上找某个芯片封装又不想自己画&#xff0c;再加上没经验&#xff0c;怎么办&#xff1f; 就以AC-DC芯片PN8036为例&#xff0c;打开嘉立创的的DFM&#xff0c;打开立创商城&#xff0c;输入PN8036&#xff0c;点击数据手册&#xff0c;然后点击直接打开…

解锁机器学习核心算法 | 随机森林算法:机器学习的超强武器

一、引言 在机器学习的广阔领域中&#xff0c;算法的选择犹如为一场冒险挑选趁手的武器&#xff0c;至关重要。面对海量的数据和复杂的任务&#xff0c;合适的算法能够化繁为简&#xff0c;精准地挖掘出数据背后隐藏的模式与价值。机器学习领域有十大核心算法&#xff0c;而随…

LeetCode每日精进:225.用队列实现栈

题目链接&#xff1a;225.用队列实现栈 题目描述&#xff1a; 请你仅使用两个队列实现一个后入先出&#xff08;LIFO&#xff09;的栈&#xff0c;并支持普通栈的全部四种操作&#xff08;push、top、pop 和 empty&#xff09;。 实现 MyStack 类&#xff1a; void push(int x…

二.数据治理流程架构

1、数据治理流程架构核心思想&#xff1a; 该图描绘了一个以数据标准规范体系为核心&#xff0c;大数据生命周期管理为主线&#xff0c;数据资源中心为依托&#xff0c;并辅以数据质量管理和大数据安全与隐私管理的数据治理流程架构。它旨在通过规范化的流程和技术手段&#x…

java_使用Spring Cloud Gateway + nacos实现跨域访问

Spring Cloud Gateway简介 Spring cloud gateway是spring官方基于Spring 5.0、Spring Boot2.0和Project Reactor等技术开发的网关&#xff0c;Spring Cloud Gateway旨在为微服务架构提供简单、有效和统一的API路由管理方式&#xff0c;Spring Cloud Gateway作为Spring Cloud生…

Linux中安装open-webui报sqlite版本低的解决办法

almalinux中安装好open-webui&#xff0c;启动服务时报如下错&#xff1a; RuntimeError: [91mYour system has an unsupported version of sqlite3. Chroma requires sqlite3 > 3.35.0.[0m [94mPlease visit https://docs.trychr…

基于SpringBoot+Vue的老年人体检管理系统的设计与实现(源码+SQL脚本+LW+部署讲解等)

专注于大学生项目实战开发,讲解,毕业答疑辅导&#xff0c;欢迎高校老师/同行前辈交流合作✌。 技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;…

【AI视频】Runway注册、基本设置、主界面详解

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: AI视频 | Runway 文章目录 &#x1f4af;前言&#x1f4af;Runway的正确启动方式推荐使用Google Chrome打开Chrome翻译 &#x1f4af;Runway的注册&#x1f4af;My Account&#xff08;我的账户&#xff09;General&a…

大数据的特点

高速、多样性、大量、低价值密度 大数据的应用场景 视频推荐&#xff0c;电商推荐&#xff0c;零售&#xff0c;金融 发展脉络 1.单机时代 2.大数据时代-分布式处理 Hadoop的优势 高可靠性、高拓展性、高效性、 高容错性