- @Cacheable 和 @CacheEvict 注解的详细使用说明及参数解析,结合 Spring Cache 的核心功能和实际开发场景
大手你不懂
JavaJava项目实战Redisspringjavaredis
一、@Cacheable注解详解1.核心作用@Cacheable用于标记方法的返回值需要被缓存。执行逻辑:方法调用前检查缓存:若缓存存在且有效,直接返回缓存值;否则执行方法并将结果存入缓存。2.关键参数参数名作用示例value/cacheNames必填,指定缓存名称(命名空间),可配置多个缓存。@Cacheable(value="users",key="#id")key指定缓存键(支持SpEL表达
- 深入学习 GORM:记录插入与数据检索
Code季风
GORM从入门到精通学习数据库golang后端
引言在使用GORM进行数据库操作时,掌握如何高效地插入记录和检索数据是非常重要的。本文将详细介绍通过Create方法插入记录、批量插入、以及各种数据检索方法,并结合实际示例进行讲解。一、通过Create方法插入记录GORM提供了简单易用的Create方法来插入单条记录。以下是一个基本示例:typeUserstruct{IDuintNamestring}varuser=User{Name:"jinz
- MongoDB 与关系型数据库的核心区别(面试向详解)
真IT布道者
数据库mongodb面试
一、数据模型差异1.1结构化vs半结构化关系型数据库:严格遵循二维表结构,需要预定义Schema(字段名、数据类型、约束等)CREATETABLEusers(idINTPRIMARYKEY,nameVARCHAR(50)NOTNULL,ageINTCHECK(age>0)MongoDB:采用BSON文档模型(类似JSON),支持动态Schema//同一个集合中可以存在不同结构的文档db.users
- 第 5 部分 - 关系与超链接 API
pythondjango
目前我们API中的关系是通过使用主键来表示的。在教程的这一部分中,我们将通过使用超链接来代替主键,从而提高API的内聚性和可发现性。为我们的API根创建一个端点现在我们已经有了"snippets"和"users"的端点,但我们没有一个单一的API入口点。为了创建一个入口点,我们将使用一个普通的基于函数的视图以及我们之前介绍的@api_view装饰器。在你的snippets/views.py中添加:
- AndroidStudio 中虚拟机连接宿主机(本机)服务
崎岖Qiu
服务器运维androidstudioandroid网络ip
如果后端服务在本电脑的localhost:8080的ip和端口上,那么直接将该url配置到安卓代码中,连上的是虚拟机的本地,而非宿主机,导致连接不上跑在本机上的服务解决方法打开cmd使用ipconfig查看本机的ip地址:C:\Users\lyh>ipconfigWindowsIP配置无线局域网适配器本地连接*1:媒体状态............:媒体已断开连接连接特定的DNS后缀.......:
- 【NodeJs】【npm】npm安装electron报错
果壳~
npmelectron前端
解决问题npm安装electron报错一般来说是镜像源的问题。electron的镜像源与一般的vue之类的镜像源地址不一样需要单独配置。npm读取的全局配置一般是在C:\Users\{用户}\.npmrc这个配置文件中。如果你找不到你的配置文件可以执行如下命令,#执行后会直接用txt打开你的配置文件进行修改保存即可npmconfigeditcache=D:\Develop\nodeJs\node_
- MySQL(105) 如何进行数据库分片?
辞暮尔尔-烟火年年
MySQL数据库mysql
数据库分片(Sharding)是一种将数据库表的数据分布到多个物理数据库实例上的技术,以提高数据库的性能和可扩展性。下面将详细介绍如何在Java中实现数据库分片,包括分片策略、分片管理和数据访问。1.环境准备假设我们使用SpringBoot和MySQL,并且需要分片的表是users表。2.分片策略常见的分片策略有哈希分片(HashSharding)、范围分片(RangeSharding)和列表分片
- django+drf 前后端分离总结(1)
a35155
pythondjangopython后端
django常见问题django设计模式django的内置组件认证组件auth模块models用户模型主要有下面几个字段:username、password、email、first_name、last_name一般我们继承AbstractUser去扩展#注意要在setting设置这个、重载系统的用户,让UserProfile生效AUTH_USER_MODEL='users.UserProfile'
- DTO、VO、POJO转换性能测试
ZuuuuYao
Java开发语言java
PO、DTO、VO、BO对象转换性能测试一、Java对象转换性能测试(一)测试对象mapstruct(二)测试对象modelmapper二测试代码(1)准备UserEntity(2)准备UserVO(3)编写mapstruct的映射器UserStructMapper(4)准备测试类(5)输出结果三、测试报告四、结论一、Java对象转换性能测试(一)测试对象mapstructMapstruct是一个
- Microsoft VBA Excel 操控 Access资料表和查询代码进行搬运操作
偷心伊普西隆
VBA学习和实践microsoftexcel前端
问题场景Run_NoSource_AddressSource_FileDestination_AddressDestination_FileCopy_IndicatorRun_Start_Time1C:\Users\EP\path\to\FileSSS-1.MDBC:\Users\EP\path\to\FileSSC-1.MDBY2C:\Users\EP\path\to\FileSSS-2.MDB
- VB.NET,C#字典对象来保存用户数据,支持大小写
专注VB编程开发20年
java开发语言
用这个保存的,登录时大小写不一样会不会无法识别根据你提供的SaveUsersToJson方法,我注意到你使用了JSON序列化来保存用户数据,但没有显式指定字典的比较器。这意味着在反序列化时,默认会使用区分大小写的比较器,导致大小写不同的用户名无法正确匹配。问题分析当你保存用户数据时:PrivateSubSaveUsersToJson(usersAsDictionary(OfString,UserI
- 《Python数据分析与挖掘实战》Chapter8中医证型关联规则挖掘笔记
茫茫大地真干净
机器学习Python数据挖掘
最近在学习《Python数据分析与挖掘实战》中的案例,写写自己的心得。代码分为两大部分:1.读取数据并进行聚类分析2.应用Apriori关联规则挖掘规律1.聚类部分函数分析:defprogrammer_1():datafile="C:/Users/longming/Desktop/chapter8/data/data.xls"processedfile="C:/Users/longming/Des
- RPC与HTTP API对比
漫谈网络
NetDevOps智联空间rpchttp网络协议
一、核心流程对比环节RPCHTTPAPI调用方式调用远程函数/方法(如userService.getUser(123))调用远程端点(如GET/users/123)参数传递通过序列化直接传递编程语言对象通过URL参数、Header或Body传递结构化数据网络传输通常基于TCP/UDP+二进制协议(如gRPC的HTTP/2)基于HTTP/HTTPS文本协议数据封装由框架自动处理序列化/反序列化需手动
- 实例化Bean对象的三种方式
越来越无动于衷
javasql开发语言
默认是无参数的构造方法(默认方式,基本上使用)静态工厂实例化特点:工厂方法属于静态方法,可直接通过类名调用,无需先创建工厂类的对象。优势:调用起来更为简便,性能方面也稍占优势。Spring配置:class属性指向静态工厂类,factory-method属性指向静态方法。示例代码:publicclassStaticFactory{publicstaticUserServicecreateUs(){r
- Python打卡训练营day31
weixin_70153780
Python打卡训练营python开发语言
规范的文件命名目标:将文件夹中的文件按规则重命名(如添加前缀、序号等)。#示例importos#定义文件夹路径folder_path=r'C:\Users\Name\Documents\Project\Files'#遍历文件夹中的文件forindex,filenameinenumerate(os.listdir(folder_path)):#拆分文件名和后缀file_ext=os.path.spl
- VSCode 拉取/推送github出现Git:[email protected]:Permission denied(publickey)解决方案
本地测过没问题啊
githubgitvscode
弹窗提示:原因:Github没有添加本地公钥(publickey),要将本地的公钥添加至github内,就可以拉取/推送了。解决方法:1、查看本地是否有SSH密钥:cd~/.ssh,找不到即没有。2、生成SSH密钥:ssh-keygen-trsa-C“youremail”3、进入本地/C:\Users\11937\.ssh文件夹下面将id_rsa.pub文件里面的内容拷贝出来4、将id_rsa.p
- 95.mysql5.7/MySQL8.0root密码忘记重置
戒掉贪嗔痴
数据库运维-MySQLmysql
1.mysql5.7密码重置方法mysql5.7--加参数vimy.cnf[mysqld]skip-grant-tables--重启systemctlrestartmysqld--修改密码USEmysql;FLUSHPRIVILEGES;UPDATEuserSETauthentication_string=PASSWORD('S3#1234')WHEREUser='root';EXIT;--注释v
- C语言大作业——学生信息管理系统
yeye_queenmoon
c语言开发语言
前言零基础小白第一次写项目,耗时两天,bug不断,浅浅记录一下项目介绍github依照作业要求分三层(1)Viewlayer(main.c):receiveuserinputs,displaydataandinteractwithusers.(2)Logiclayer(stu_service.c):processrelativebusinesslogics.(3)Dataaccesslayer(s
- AIGC-controlnet代码详细解读以及训练一个自己的controlnet
huggingface社区diffusers官方代码:stable_diffusion/controlnetcontrolnet.ipynb原始代码的解读可以看看这个博主的:万字长文解读StableDiffusion的核心插件—ControlNet小部分讲解引用controlnet代码讲解解读的是diffusersv0.16.0对应的controlnet代码里面也有对应的注释哈!controlne
- 解决github每次pull push输入密码问题
一只积极向上的小咸鱼
github
#解决gitpull/push每次都需要输入密码问题gitbash进入你的项目目录,输入:gitconfig--globalcredential.helperstore然后你会在你本地生成一个文本,上边记录你的账号和密码。配置项写入到"C:\Users\用户名\.gitconfig"文件中。然后你使用上述的命令配置好之后,再操作一次gitpull,然后它会提示你输入账号密码,这一次之后就不需要再次
- MySQL四大索引类型全解析:从原理到实战避坑指南
码里看花
mysql数据库
不扯官方文档的片汤话,直接带你手撕MySQL四大索引类型,通过真实场景案例+避坑指南,让你真正掌握索引的应用精髓!一、NORMAL索引:数据库优化的第一把利刃1.1本质揭秘NORMAL索引(默认B-Tree结构)是MySQL的默认索引类型,采用平衡树结构组织数据,适用于等值查询和范围查询。创建方式:--单列索引ALTERTABLEusersADDINDEXidx_email(email);--组合
- anaconda创建python3.7环境_anaconda使用以及创建python3.7+pytorch1.0虚拟环境以及Jupyter notebook初级使用...
weixin_39837124
查看所有已安装的软件包$condalist#packagesinenvironmentatS:\Users\jiangshan\Anaconda3:##NameVersionBuildChannel_ipyw_jlab_nb_ext_conf0.1.0py37_0defaultsalabaster0.7.12py37_0defaultsanaconda2018.12py37_0defaults..
- RuntimeError: Unsupported image type, must be 8bit gray or RGB image.
Roc-xb
Pythonpythoncv2opencv
(face)E:\code\运行代码>C:/Users/29847/Anaconda3/envs/face/python.exee:/code/运行代码/face.pyTraceback(mostrecentcalllast):File“e:\code\运行代码\face.py”,line76,insuccess=registrator.register_face(“Mark_Zuckerberg
- 链接拉起微信小程序
月深夜微凉
微信小程序小程序微信
前言:之前做过RN的app拉起小程序外链拉起app,需求变更,需要支持微信分享出去的链接拉起小程序,这里对微信分享做个补充准备工作:微信开放平台绑定小程序绑定时需要管理员账号app和小程序同一开发平台时,不用其他额外设置,如果不是同一平台,需要app绑定小程序获取access_token文档链接:https://developers.weixin.qq.com/miniprogram/dev/Op
- spring-webmvc @RequestBody 典型用法
张紫娃
注解springwindowsjava
典型用法接收JSON请求体并转换为Java对象@PostMapping("/users")publicStringcreateUser(@RequestBodyUseruser){return"Usercreated:"+user.getName();}//客户端请求示例(JSON):{"name":"Alice","email":"
[email protected]"}//Spring自动使用H
- 深入浅出ORM:对象关系映射的技术解析
weixin_47233946
编程数据库
##引言:从数据库操作痛点说起在传统软件开发中,程序员需要频繁编写SQL语句进行数据库操作:每次插入用户数据都要手写`INSERTINTOusers...`,查询订单需要构造`SELECT...JOIN...WHERE`的复杂语句。随着业务逻辑的复杂化,这些问题愈发突出:1.**SQL注入风险**:字符串拼接导致安全隐患2.**代码臃肿**:20%的业务代码被SQL语句占据3.**数据库切换成本*
- uniapp:微信小程序胶囊「复制链接」灰色处理
dingcho
前端小程序uni-app微信小程序
在原生开发的小程序中默认是支持复制的但是在uniapp开发的小程序中无法复制(体验版与开发版都可以进行复制,但发布后不可)解决方法:methods:{onShareAppMessage:function(){//returncustomsharedatawhenusershare.},}这样即可,复制链接就能使用了;如果无效可以尝试在小程序后台开启对应的功能【在测试和模拟器中除了首页能点,其它必须
- 使用Qt6写一段实现数据库为指定字段特定内容统计数量的代码
亭台六七座
Qt/C++成长之路数据库oraclejvm
以下是使用Qt6实现统计数据库中指定user和passMD5字段数量的代码示例:cpp复制下载#include#include#includeintcountUsers(constQString&dbPath,constQString&targetUser,constQString&targetPassMd5){intcount=-1;//初始化计数为-1表示出错//1.建立数据库连接QSqlDa
- 深度解析MySQL EXPLAIN:揭秘SQL执行计划的每个细节
缘来是黎
webank数据库sqljava
作为MySQL性能调优的核心工具,EXPLAIN命令能帮助我们理解SQL语句的执行计划。本文将全面解析EXPLAIN输出的每个字段及其可能的值,并通过实际场景说明如何利用这些信息优化查询性能。EXPLAIN基础语法EXPLAINSELECT*FROMusersWHEREid=1;--或更详细的格式EXPLAINFORMAT=JSONSELECT*FROMusersWHEREid=1;核心字段解析1
- MySQL分页原理与慢SQL优化实战
缘来是黎
webankmysqlsql数据库
分页查询的本质在Web应用中,分页是处理大量数据的常见需求。MySQL中的分页通常使用LIMIToffset,size语法实现,例如:SELECT*FROMusersORDERBYidLIMIT10000,20;这条语句看似简单,但隐藏着性能陷阱。让我们深入理解其工作原理。分页的底层执行机制当MySQL执行LIMIT10000,20时,它实际上需要:读取前10020条记录(10000+20)丢弃前
- PHP,安卓,UI,java,linux视频教程合集
cocos2d-x小菜
javaUIPHPandroidlinux
╔-----------------------------------╗┆
- 各表中的列名必须唯一。在表 'dbo.XXX' 中多次指定了列名 'XXX'。
bozch
.net.net mvc
在.net mvc5中,在执行某一操作的时候,出现了如下错误:
各表中的列名必须唯一。在表 'dbo.XXX' 中多次指定了列名 'XXX'。
经查询当前的操作与错误内容无关,经过对错误信息的排查发现,事故出现在数据库迁移上。
回想过去: 在迁移之前已经对数据库进行了添加字段操作,再次进行迁移插入XXX字段的时候,就会提示如上错误。
&
- Java 对象大小的计算
e200702084
java
Java对象的大小
如何计算一个对象的大小呢?
 
- Mybatis Spring
171815164
mybatis
ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml");
CustomerService userService = (CustomerService) ac.getBean("customerService");
Customer cust
- JVM 不稳定参数
g21121
jvm
-XX 参数被称为不稳定参数,之所以这么叫是因为此类参数的设置很容易引起JVM 性能上的差异,使JVM 存在极大的不稳定性。当然这是在非合理设置的前提下,如果此类参数设置合理讲大大提高JVM 的性能及稳定性。 可以说“不稳定参数”
- 用户自动登录网站
永夜-极光
用户
1.目标:实现用户登录后,再次登录就自动登录,无需用户名和密码
2.思路:将用户的信息保存为cookie
每次用户访问网站,通过filter拦截所有请求,在filter中读取所有的cookie,如果找到了保存登录信息的cookie,那么在cookie中读取登录信息,然后直接
- centos7 安装后失去win7的引导记录
程序员是怎么炼成的
操作系统
1.使用root身份(必须)打开 /boot/grub2/grub.cfg 2.找到 ### BEGIN /etc/grub.d/30_os-prober ### 在后面添加 menuentry "Windows 7 (loader) (on /dev/sda1)" { 
- Oracle 10g 官方中文安装帮助文档以及Oracle官方中文教程文档下载
aijuans
oracle
Oracle 10g 官方中文安装帮助文档下载:http://download.csdn.net/tag/Oracle%E4%B8%AD%E6%96%87API%EF%BC%8COracle%E4%B8%AD%E6%96%87%E6%96%87%E6%A1%A3%EF%BC%8Coracle%E5%AD%A6%E4%B9%A0%E6%96%87%E6%A1%A3 Oracle 10g 官方中文教程
- JavaEE开源快速开发平台G4Studio_V3.2发布了
無為子
AOPoraclemysqljavaeeG4Studio
我非常高兴地宣布,今天我们最新的JavaEE开源快速开发平台G4Studio_V3.2版本已经正式发布。大家可以通过如下地址下载。
访问G4Studio网站
http://www.g4it.org
G4Studio_V3.2版本变更日志
功能新增
(1).新增了系统右下角滑出提示窗口功能。
(2).新增了文件资源的Zip压缩和解压缩
- Oracle常用的单行函数应用技巧总结
百合不是茶
日期函数转换函数(核心)数字函数通用函数(核心)字符函数
单行函数; 字符函数,数字函数,日期函数,转换函数(核心),通用函数(核心)
一:字符函数:
.UPPER(字符串) 将字符串转为大写
.LOWER (字符串) 将字符串转为小写
.INITCAP(字符串) 将首字母大写
.LENGTH (字符串) 字符串的长度
.REPLACE(字符串,'A','_') 将字符串字符A转换成_
- Mockito异常测试实例
bijian1013
java单元测试mockito
Mockito异常测试实例:
package com.bijian.study;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
import org.junit.Assert;
import org.junit.Test;
import org.mockito.
- GA与量子恒道统计
Bill_chen
JavaScript浏览器百度Google防火墙
前一阵子,统计**网址时,Google Analytics(GA) 和量子恒道统计(也称量子统计),数据有较大的偏差,仔细找相关资料研究了下,总结如下:
为何GA和量子网站统计(量子统计前身为雅虎统计)结果不同?
首先:没有一种网站统计工具能保证百分之百的准确出现该问题可能有以下几个原因:(1)不同的统计分析系统的算法机制不同;(2)统计代码放置的位置和前后
- 【Linux命令三】Top命令
bit1129
linux命令
Linux的Top命令类似于Windows的任务管理器,可以查看当前系统的运行情况,包括CPU、内存的使用情况等。如下是一个Top命令的执行结果:
top - 21:22:04 up 1 day, 23:49, 1 user, load average: 1.10, 1.66, 1.99
Tasks: 202 total, 4 running, 198 sl
- spring四种依赖注入方式
白糖_
spring
平常的java开发中,程序员在某个类中需要依赖其它类的方法,则通常是new一个依赖类再调用类实例的方法,这种开发存在的问题是new的类实例不好统一管理,spring提出了依赖注入的思想,即依赖类不由程序员实例化,而是通过spring容器帮我们new指定实例并且将实例注入到需要该对象的类中。依赖注入的另一种说法是“控制反转”,通俗的理解是:平常我们new一个实例,这个实例的控制权是我
- angular.injector
boyitech
AngularJSAngularJS API
angular.injector
描述: 创建一个injector对象, 调用injector对象的方法可以获得angular的service, 或者用来做依赖注入. 使用方法: angular.injector(modules, [strictDi]) 参数详解: Param Type Details mod
- java-同步访问一个数组Integer[10],生产者不断地往数组放入整数1000,数组满时等待;消费者不断地将数组里面的数置零,数组空时等待
bylijinnan
Integer
public class PC {
/**
* 题目:生产者-消费者。
* 同步访问一个数组Integer[10],生产者不断地往数组放入整数1000,数组满时等待;消费者不断地将数组里面的数置零,数组空时等待。
*/
private static final Integer[] val=new Integer[10];
private static
- 使用Struts2.2.1配置
Chen.H
apachespringWebxmlstruts
Struts2.2.1 需要如下 jar包: commons-fileupload-1.2.1.jar commons-io-1.3.2.jar commons-logging-1.0.4.jar freemarker-2.3.16.jar javassist-3.7.ga.jar ognl-3.0.jar spring.jar
struts2-core-2.2.1.jar struts2-sp
- [职业与教育]青春之歌
comsci
教育
每个人都有自己的青春之歌............但是我要说的却不是青春...
大家如果在自己的职业生涯没有给自己以后创业留一点点机会,仅仅凭学历和人脉关系,是难以在竞争激烈的市场中生存下去的....
&nbs
- oracle连接(join)中使用using关键字
daizj
JOINoraclesqlusing
在oracle连接(join)中使用using关键字
34. View the Exhibit and examine the structure of the ORDERS and ORDER_ITEMS tables.
Evaluate the following SQL statement:
SELECT oi.order_id, product_id, order_date
FRO
- NIO示例
daysinsun
nio
NIO服务端代码:
public class NIOServer {
private Selector selector;
public void startServer(int port) throws IOException {
ServerSocketChannel serverChannel = ServerSocketChannel.open(
- C语言学习homework1
dcj3sjt126com
chomework
0、 课堂练习做完
1、使用sizeof计算出你所知道的所有的类型占用的空间。
int x;
sizeof(x);
sizeof(int);
# include <stdio.h>
int main(void)
{
int x1;
char x2;
double x3;
float x4;
printf(&quo
- select in order by , mysql排序
dcj3sjt126com
mysql
If i select like this:
SELECT id FROM users WHERE id IN(3,4,8,1);
This by default will select users in this order
1,3,4,8,
I would like to select them in the same order that i put IN() values so:
- 页面校验-新建项目
fanxiaolong
页面校验
$(document).ready(
function() {
var flag = true;
$('#changeform').submit(function() {
var projectScValNull = true;
var s ="";
var parent_id = $("#parent_id").v
- Ehcache(02)——ehcache.xml简介
234390216
ehcacheehcache.xml简介
ehcache.xml简介
ehcache.xml文件是用来定义Ehcache的配置信息的,更准确的来说它是定义CacheManager的配置信息的。根据之前我们在《Ehcache简介》一文中对CacheManager的介绍我们知道一切Ehcache的应用都是从CacheManager开始的。在不指定配置信
- junit 4.11中三个新功能
jackyrong
java
junit 4.11中两个新增的功能,首先是注解中可以参数化,比如
import static org.junit.Assert.assertEquals;
import java.util.Arrays;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runn
- 国外程序员爱用苹果Mac电脑的10大理由
php教程分享
windowsPHPunixMicrosoftperl
Mac 在国外很受欢迎,尤其是在 设计/web开发/IT 人员圈子里。普通用户喜欢 Mac 可以理解,毕竟 Mac 设计美观,简单好用,没有病毒。那么为什么专业人士也对 Mac 情有独钟呢?从个人使用经验来看我想有下面几个原因:
1、Mac OS X 是基于 Unix 的
这一点太重要了,尤其是对开发人员,至少对于我来说很重要,这意味着Unix 下一堆好用的工具都可以随手捡到。如果你是个 wi
- 位运算、异或的实际应用
wenjinglian
位运算
一. 位操作基础,用一张表描述位操作符的应用规则并详细解释。
二. 常用位操作小技巧,有判断奇偶、交换两数、变换符号、求绝对值。
三. 位操作与空间压缩,针对筛素数进行空间压缩。
&n
- weblogic部署项目出现的一些问题(持续补充中……)
Everyday都不同
weblogic部署失败
好吧,weblogic的问题确实……
问题一:
org.springframework.beans.factory.BeanDefinitionStoreException: Failed to read candidate component class: URL [zip:E:/weblogic/user_projects/domains/base_domain/serve
- tomcat7性能调优(01)
toknowme
tomcat7
Tomcat优化: 1、最大连接数最大线程等设置
<Connector port="8082" protocol="HTTP/1.1"
useBodyEncodingForURI="t
- PO VO DAO DTO BO TO概念与区别
xp9802
javaDAO设计模式bean领域模型
O/R Mapping 是 Object Relational Mapping(对象关系映射)的缩写。通俗点讲,就是将对象与关系数据库绑定,用对象来表示关系数据。在O/R Mapping的世界里,有两个基本的也是重要的东东需要了解,即VO,PO。
它们的关系应该是相互独立的,一个VO可以只是PO的部分,也可以是多个PO构成,同样也可以等同于一个PO(指的是他们的属性)。这样,PO独立出来,数据持