- python pandas 读取数据库_Python+Pandas 获取数据库并加入DataFrame的实例
weixin_39955149
pythonpandas读取数据库
Python+Pandas获取数据库并加入DataFrame的实例实例如下所示:importpandasaspdimportsysimportimpimp.reload(sys)fromsqlalchemyimportcreate_engineimportcx_Oracledb=cx_Oracle.connect('userid','password','10.10.1.10:1521/dbins
- python导出结果_Python连接Oracle数据查询导出结果
weixin_39712821
python导出结果
python连接oracle,需用用到模块cx_oracle,可以直接pip安装,如网络不好,可下载离线后本地安装本人由于工作需要,期望便捷查询所得结果,且固定输出某个格式具体代码如下:#!coding:utf-8importcx_Oracleconn=cx_Oracle.connect('username/password@IP/连接名')cur=conn.cursor()cur.execute
- python把oracle的查询结果导出为insert语句
优游的鱼
oraclepython数据库开发语言
可以使用cx_Oracle库在Python中连接Oracle数据库并执行查询。然后,可以使用pandas库将查询结果读取为DataFrame,并使用to_sql()方法将其导出为insert语句。示例代码如下:importcx_Oracleimportpandasaspd#ConnecttoOracledatabaseconn=cx_Oracle.connect('username/passwor
- 记一次从mysql数据迁移到oralce (基于python和pandas)
qq_36532060
mysqloraclepandaspython
记一次从mysql数据迁移到oralce(基于python)前景提要具体实现创建数据库链接读取mysql数据写入orcale结语前景提要公司最近有个从mysql迁移数据到oracle的需求,于是进行了一下方案调研和分析,但作为一个之前从没接触过Oracle的人真的感到好难,但再难也难上,这篇文章主要是记录一下做这件事时遇到的坑以及分享一下最终的方案及代码。具体实现创建数据库链接其实我觉得这个算是最
- python实现从oracle数据库查询数据生成excel透视表发送outlook
niceme!
python
#-*-coding:utf-8-*-#http://pypi.cq.pegatroncorp.com/simple--trusted-hostpypi.cq.pegatroncorp.comimportchardetimportdatetimeimporttimeimportxlwtimportwin32com.clientaswin32fromwin32com.clientimportcons
- 使用Python导出Oracle数据库数据表目录
SeanData
Python数据分析pythonoracle数据目录导出
###Oracle数据库数据表目录导出###导入包importpandasaspdimportcx_Oracle###数据库信息username='xxx'password='yyy'ipaddr='100.28.60.132'port='1521'service_name='service_name'connect_string=ipaddr+":"+port+"/"+service_name#
- 非关系型数据库和关系型数据库的区别
纠结哥_Shrek
数据库nosql
非关系型数据库(NoSQL)和关系型数据库(SQL)的主要区别体现在以下几个方面:数据模型:关系型数据库(SQL):数据以表格形式存储,数据行和列组成,每个表都有固定的模式(Schema)。常见的关系型数据库有MySQL、PostgreSQL、Oracle等。非关系型数据库(NoSQL):数据没有固定的模式,存储方式更加灵活。可以是键值对、文档、列族、图等形式。常见的非关系型数据库有MongoDB
- Oracle 数据库基础入门(一):搭建数据管理基石
Aphelios380
Oracleoracle数据库linux编辑器
在当今数字化时代,数据库作为数据管理的核心工具,对于各类应用系统的开发至关重要。尤其是在Java全栈开发领域,掌握一款强大的数据库技术是必备技能。Oracle数据库以其卓越的性能、高度的可靠性和丰富的功能,在企业级应用中广泛使用。开辟新的篇章,让我们踏上Oracle数据库的学习之旅,聚焦于基础的建表、数据操作等关键知识,为后续深入学习和实际项目应用筑牢根基。一、DDL数据定义语言:构建数据库结构框
- Oracle 数据库基础入门(二):深入理解表的约束
Aphelios380
Oraclelinuxoraclesql
在Oracle数据库的学习进程中,表的约束是构建健壮、准确且高效数据库的关键要素。约束如同数据库的“规则守护者”,它通过对数据的限制,确保了数据的完整性和一致性,就如同交通规则保障道路上车辆行驶的有序性一样。对于Java全栈开发者而言,熟练掌握Oracle数据库的约束知识,无论是在数据库设计、开发还是后续的维护中,都具有举足轻重的意义。接下来,让我们一同深入探索Oracle数据库中表的约束世界。一
- Java 编程基础:开启编程世界的大门
安年CJ
JAVAjava开发语言算法
一、Java环境搭建在开始编写Java代码之前,我们需要先搭建Java开发环境。1.安装JDK(JavaDevelopmentKit)JDK是Java开发的核心工具包,它包含了编译Java源文件所需的编译器(javac)以及运行Java程序的虚拟机(JavaVirtualMachine,JVM)等工具。你可以从Oracle官方网站下载适合你操作系统的JDK版本。下载完成后,按照安装向导进行安装。安
- oracle查询DBname 和 hostname(instance)
cyong888
数据库oracledatabase
selecthost_namefromv$instance;selectnamefromv$database一个instance上有多个database。
- 【YashanDB 知识库】通过 dblink 查询 Oracle 数据时报 YAS-07301 异常
数据库运维
问题现象某客户在通过yasql查询Oracle数据时,报如下异常:SQL>select1fromdual@link_oracle;YAS-07301externalmoduletimeout,reason:yex_serverheatbeattimeout问题的风险及影响dblink功能无法正常使用问题影响的版本所有的YashanDB版本问题发生原因查看YashanDB的run.log,有如下异常
- 【YashanDB 知识库】如何排查 YMP 报错:”OCI 版本为空或 OCI 的架构和本地系统的架构不符“
数据库程序员
问题现象在迁移预检查的版本检查阶段报错:检查未通过OCI版本为空,报错的详细信息:OCI版本为空或OCI的架构与本地系统架构不符;如何排查1、查看yasdts日志,从日志报错信息得知libdrv_oracle.so少了依赖库libnsl.so.1tail-fyashan-migrate-platform/logs/dts_log/run.log2、检查是否将OCI客户端路径加入到环境变量LD_LI
- 基于oracle linux的 DBI/DBD 标准化安装文档
linux
一、安装DBIDBI(DatabaseInterface)是perl连接数据库的接口。其是perl连接数据库的最优方法,他支持包括Orcale,Sybase,mysql,db2等绝大多数的数据库,下面将简要介绍其安装方法。1.1解压tar-zxvfDBI-1.616_901.tar.gz1.2安装依赖yuminstallperl-ExtUtils-CBuilderperl-ExtUtils-Mak
- 2.1部署logstash:9600
AustinCien
ELFKelk运维
实验环境:关闭防火墙,完成java环境yum-yinstallwgetwgethttps://d6.injdk.cn/oraclejdk/8/jdk-8u341-linux-x64.rpmyumlocalinstalljdk-8u341-linux-x64.rpm-yjava-version1.安装logstashtarxflogstash-6.4.1.tar.gz-C/usr/localln-s
- 编译 Linux 4.15.11 内核并增加系统调用
Isolarae
编译Linux4.15.11内核并增加系统调用实验日期;2018年3月21日-2018年3月22日实验环境:主机:操作系统:MicrosoftWindows10.0.16299Build16299处理器:
[email protected]物理内存:8.00GB虚拟机软件:OracleVMVirtualBox5.2.6r120293虚拟机:操作系统:openSUSE201
- OCP 认证专家零基础小白
leegong23111
oracle数据库
对于零基础的学习者而言,OCP专家认证是完全可以攻克的目标,而且其价值不可估量。从学习的角度来看,它为你提供了一套系统且全面的数据库知识体系。Oracle数据库作为行业内的领军者,其技术的深度和广度足以让你深入了解数据库的原理、架构、设计、管理与优化等各个关键环节。学习过程虽然充满挑战,但就像攀爬一座高峰,每一步的艰辛都伴随着知识积累的喜悦,当你逐渐掌握这些核心技能时,你会发现自己已经拥有了进入I
- 搭建Java集成开发环境IntelliJIDEA
愿时光不负.
intellijideajava
阶段1:安装Java开发工具包(JDK)下载JDK:访问OracleJDK或者OpenJDK官方网站,下载适合你操作系统的JDK版本。通常建议下载LTS(长期支持)版本,如JDK11或JDK17。安装JDK:运行下载的安装包,并按照提示完成安装。记下安装路径,稍后需要在IntelliJIDEA中配置。配置环境变量(Windows用户):右键点击“此电脑”>“属性”>“高级系统设置”>“环境变量”。
- python 生成excel
scan724
#!/usr/bin/envpython#-*-coding:utf-8-*-importMySQLdbfromdatetimeimportdatetimeimportcx_Oracleimportosimportxlwtimportsysreload(sys)sys.setdefaultencoding('utf-8')os.environ['NLS_LANG']='SIMPLIFIEDCHIN
- Oracle 高可用性与数据保护
鱼弦
人工智能时代oracle数据库
Oracle高可用性与数据保护介绍Oracle提供了一系列高可用性和数据保护技术,以确保数据库系统在各种故障情况下继续运行,并保护数据免受损坏或丢失。这些技术包括集群与实时应用集群(RAC)、数据卫士(DataGuard)和闪回技术。集群与实时应用集群(RAC)基本概念RAC:RealApplicationClusters允许多个服务器同时访问一组Oracle数据库实例。通过这种方式,RAC提供了
- 的卢导表:批量导入Excel文件到MySQL数据库的自动化工具
如意机反光镜裸
数据库excelmysqlexcel自动化
的卢导表:批量导入Excel文件到MySQL数据库的自动化工具简介的卢导表是一个可以批量导入excel到mysql数据库的自动化工具。支持将xls/xlsx/xlsm/xlsb/csv/txt/xml格式的Excel文件导入到mysql/oracle/sqlserver/postgresql等多种原生及国产数据库。自动化是其最大的特点,因为它可以根据excel自动生成表信息与数据库建立联系,最终将
- oracle:SID匹配错误
iteye_11495
数据库java网络
报错:java.sql.SQLException:Listenerrefusedtheconnectionwiththefollowingerror:ORA-12505,TNS:listenerdoesnotcurrentlyknowofSIDgiveninconnectdescriptorTheConnectiondescriptorusedbytheclientwas:localhost:15
- 本地Oracle数据库复制数据到Apache Hive的Linux服务器集群的分步流程
weixin_30777913
数据库大数据hive
我们已经有安装ApacheHive的Linux服务器集群,它可以连接到一个OracleRDS数据库,需要在该Linux服务器上安装配置sqoop,然后将OracleRDS数据库中所有的表数据复制到Hive。为了将本地Oracle数据库中的所有表数据复制到ApacheHiveLinux服务器集群中,您可以遵循以下详细步骤:第一步:安装和配置Sqoop1.下载并安装Sqoop您可以从ApacheSqo
- GaussDB 数据库迁移方案设计与实践
如清风一般
gaussdb数据库
一、引言随着企业数字化转型加速,数据库迁移成为IT基础设施升级的关键环节。GaussDB(华为云分布式关系型数据库)凭借其高吞吐、强一致性、弹性扩展等特性,成为政企客户替换传统数据库(如MySQL、Oracle)或升级原有GaussDB集群的首选目标。本文从技术角度系统化阐述GaussDB迁移的典型场景、核心方案及优化策略。二、迁移场景分类与技术挑战同构迁移(GaussDB→GaussDB)典型需
- Oracle数据库分区自动删除
deadknight9
Oracle运维数据库
说明:该存储过程部署后,设置成定时任务,每天执行。每次执行删除partition_position='2'的分区,删除之后,partition_position='3'的分区会前移到partition_position为'2';CREATEORREPLACEPROCEDUREBILL_CENT_JILI.DAY_PARTITIONASv_p_namevarchar2(2000);v_p_numnu
- Oracle体系结构:数据泵初探
姜豆豆耶
#Oracle体系结构oracledba数据库
数据泵是基于服务器的工具,用于数据和元数据的高速移动。可以跨数据库版本(Oracle版本)进行数据的导入导出。所以也常被用来当作数据迁移的方案之一。它有expdp、impdp两种程序进行导出和导入,下文也会进行详细介绍;但文章标题毕竟只是数据泵初探,也不会详细到让人拍手叫好的程度哈哈。那么话不多说,❀周末时间宝贵❀,开始介绍,先看目录!目录expdp例子常用参数可用关键参数交互模式命令impdp例
- Oracle 数据泵迁移步骤规范
deadknight9
运维Oracleoracle数据库
1、调研模块1.1、确认迁移用户以全库迁移为标准,也可直接通过需求方获取需要迁移的用户1)确认数据库中所有用户及其创建时间altersessionsetnls_date_format='yyyy-mm-dd-hh24:mi:ss';selectusername,createdfromdba_usersorderby2;2)以系统用户创建时间为限确认需要的用户selectusername,creat
- 华纳云:数据库的内存分配策略对性能和稳定性的影响
数据库
数据库的内存分配策略对性能和稳定性至关重要。以下是针对不同数据库(如MySQL和Oracle)的内存分配建议和最佳实践:一、MySQL数据库内存分配建议InnoDB缓冲池(BufferPool)配置建议:innodb_buffer_pool_size是MySQL中最重要的内存配置参数,建议设置为系统物理内存的60%80%。iniinnodb_buffer_pool_size=70%示例:16GB内
- ERP系统之比较——SAP Oracle BAAN JDE SSA
又是两个大汉堡
ERP系统之比较——SAP、Oracle、BAAN、JDE、SSAERP/MRPII系统剖析SAPSAP公司简介R/2和R/3系统是德国SAP公司所提供的MRPII产品。R/2是用于集中式大型机环境的系统,R/3是用于分布式的客户机/服务器环境的系统。SAP是国际上著名的标准应用软件公司。SAP总部设在德国南部的沃尔道夫市,公司成立于1972年,1988年成为德国股票上市公司。到1995年底,SA
- MongoDB 和 PostgreSQL 性能比较
AI天才研究院
Python实战DeepSeekR1&大数据AI人工智能大模型Java实战大数据人工智能语言模型JavaPython架构设计
作者:禅与计算机程序设计艺术1.简介随着互联网应用的普及,数据量越来越大,处理数据的需求也越来越强烈。数据量的爆炸性增长促使各种数据库系统应运而生。目前,基于关系型数据库管理系统(RDBMS)的产品如Oracle、MySQL等已经成为最主要的选择,但在实际生产环境中,存在性能问题,如读写延迟过高、查询效率低下、索引失效等。另外,NoSQL数据库系统如MongoDB、Cassandra等发展得相对较
- 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独立出来,数据持