- ubuntu FreeRadius服务器安装
flowHEHE
ubuntu系统安装ubuntu服务器
1、获取安装源(1)wgethttps://github.com/FreeRADIUS/freeradius-server/archive/v3.0.x.zip(2)unzipv3.0.x.zip(3)cdfreeradius-server-3.0.x/2、创建ubuntu相关依赖(1)sudoapt-getinstalldevscriptsquiltdebhelperfakerootequivs
- PostgreSQL 窗口函数学习指南
AI人H哥会Java
sql
PostgreSQL是一个功能强大的开源关系数据库管理系统,广泛应用于数据分析、Web应用和企业级解决方案中。窗口函数是PostgreSQL中的一项强大特性,允许用户在查询结果中进行复杂的计算和分析,而无需使用子查询或连接。本文将深入探讨PostgreSQL的窗口函数,包括其基本概念、语法、常见用法和实际示例,帮助读者掌握这一重要工具。1.窗口函数的基本概念窗口函数是一种特殊的函数,它在结果集的“
- GreatSQL通过伪装从库回放Binlog文件
数据库mysql
GreatSQL通过伪装从库回放Binlog文件一、适用场景说明1、主库误操作恢复利用Binlog在其他实例解析、回放,根据gtid只回放到指定位点。2、网络隔离环境同步备份恢复后可以拉去主库Binlog文件至新实例同步增量数据。3、备份恢复遇到Binlog文件过大处理恢复实例时有可能主库的Binlog超过限定大小,无法用mysqlbinlog工具恢复。以上只是列举部分场景,而且恢复的方式也并非一
- Sentinel
sevevty-seven
sentinellinux服务器
一、Sentinel的核心概念Sentinel的设计围绕“流量治理”展开,以下是其核心概念:资源(Resource):资源是Sentinel的核心概念,可以是代码中的任意一段逻辑(如方法调用、接口、SQL查询等),也可以是服务或URL。每个资源都有唯一的名称(resourceName),Sentinel通过资源名称对其进行监控和控制。用户需要通过SentinelAPI(如SphU.entry(re
- 人大金仓 vs MySQL 窗口函数:三大核心差异与实战对比
一、窗口函数的演进与挑战窗口函数(WindowFunctions)自MySQL8.0引入以来,已成为数据分析和业务报表开发的核心工具。然而,随着国产数据库如人大金仓(KingbaseES)对MySQL语法的兼容性增强,开发者在迁移或选型时面临一个关键问题:如何选择支持更强大窗口函数功能的数据库?本文将从语法设计、功能特性、性能表现三个维度,结合代码实战,深度剖析人大金仓与MySQL窗口函数的核心差
- Linux之Socket 编程 UDP
孞㐑¥
linuxudp经验分享笔记c++服务器网络协议
一、UDP网络编程1.1、V1版本-echoserver功能:简单的回显服务器和客户端代码注意:云服务器不允许直接bind公有IP,我们也不推荐编写服务器的时候,bind明确的IP,推荐直接写成INADDR_ANY。C++/*Addresstoacceptanyincomingmessages.*/#defineINADDR_ANY((in_addr_t)0x00000000)在网络编程中,当一个
- PHP语法基础篇(八):超全局变量
zorro_z
php手记实战php
超全局变量是在PHP4.1.0中引入的,并且是内置变量,可以在所有作用域中始终可用。PHP中的许多预定义变量都是"超全局的",这意味着它们在一个脚本的全部作用域中都可用。在函数或方法中无需执行global$variable;就可以访问它们。PHP超全局变量包括:$GLOBALS$_SERVER$_REQUEST$_POST$_GET$_FILES$_ENV$_COOKIE$_SESSION本篇文章
- Nginx轻松上手
oaa114龙仔
Nginxnginx运维服务器
Nginx轻松上手准备环境部署安装源码安装yum安装nginx配置文件简单使用虚拟主机与域名解析反向代理负载均衡动静分离nginx+keepalived高可用准备环境Linux操作系统IP地址功能Centos7192.168.1.20nginx_server+keepalivedCentos7192.168.1.21nginxbackup+keepalivedCentos7192.168.1.22
- Nginx负载均衡详解_nginx负载均衡配置详解
为了做好运维面试路上的助攻手,特整理了上百道【运维技术栈面试题集锦】,让你面试不慌心不跳,高薪offer怀里抱!这次整理的面试题,小到shell、MySQL,大到K8s等云原生技术栈,不仅适合运维新人入行面试需要,还适用于想提升进阶跳槽加薪的运维朋友。本份面试集锦涵盖了174道运维工程师面试题128道k8s面试题108道shell脚本面试题200道Linux面试题51道docker面试题35道Je
- 常用指令合集(DOS/Linux/git/Maven等)
文章目录常用指令收集vmware虚拟机联网设置ubuntu常见问题设置apt相关指令:gcc编译相关指令sqlite3VSCode快捷键:收索引擎技巧(google)Intelideashell--LinxvimgitDOS:mavendockerkubectl指令nginx配置redis-clientMySQLlinux下java进程排错MongoDBCentOSJDK安装配置UbuntuJDK
- Python, Rust 开发机关事业单位公文写作助手APP
#机关事业单位公文写作助手应用设计基于Python和Rust开发机关事业单位公文写作APP的方案如下:##系统架构设计```桌面端/Web应用(Tauri/Vue.js)|RESTAPI/WebSocket|Rust核心服务(Actix-web/Axum)←───PythonNLP服务(FastAPI)|公文要素提取/模板生成/智能校对PostgreSQL数据库|Redis缓存(模板缓存/会话管理
- Lock wait timeout exceeded; try restarting transaction mysql报错
Lockwaittimeoutexceeded;tryrestartingtransactionmysql报错问题描述:问题复现第一步:开启sql命令页面第二步:输入starttransaction;开启一个事务第三步:输入update语句不要提交第四步:书写测试类第五步:查看锁第五步:等待错误出现原因分析解决方案一、杀掉锁二、重启mysql三、设置锁定等待时间改大问题描述:提示:最近项目中频繁出
- 解决MySQL “Lock wait timeout exceeded; try restarting transaction“ 错误
一勺菠萝丶
#MySQLmysqlandroid数据库
在处理MySQL数据库时,我们偶尔会遇到一个棘手的错误消息:“Lockwaittimeoutexceeded;tryrestartingtransaction”。这通常表明我们的一个事务在尝试获取资源时被阻塞了太长时间。在并发环境中,多个事务同时竞争相同的资源可能会导致这种情况发生。锁等待超时问题的原因锁等待超时是因为另一个事务持有了需要的锁,并且没有在配置的超时期限内释放。这可能是因为该事务非常
- MySQL:Lock wait timeout exceeded; try restarting transaction
喝醉酒的小白
MySQLmysql数据库
目录错误类型及根因分析1.`Lockwaittimeoutexceeded;tryrestartingtransaction`2.`Gotanerrorwritingcommunicationpackets`核心解决思路针对锁等待超时:针对通信包错误:总结错误类型及根因分析1.Lockwaittimeoutexceeded;tryrestartingtransaction原因:事务等待行锁/表锁超
- OracleSync2MySQL 数据同步问题bad connection、创建表异常、数据映射异常
aspirant-complete
运维开发
1、mysql数据库连接badconnection、invalidconnection等异常检查数据库连接空闲时间MySQL服务器等待一个连接所允许的空闲时间。如果达到此时间,MySQL服务器将自动关闭该连接,除非该连接正在活动状态```sqlSHOWVARIABLESLIKE'wait_timeout';通过TCP/IP或Socket协议连接到MySQL服务器。连接器验证用户名、密码及权限,若失败则返回错误(如Accessdenied)
- 探秘阿里云Tablestore:大数据存储与查询的神器
云资源服务商
阿里云大数据云计算
一、引言在大数据时代,数据量呈爆炸式增长,数据类型也日益丰富多样,这对数据库技术提出了前所未有的挑战。传统的关系型数据库在应对海量数据存储、高并发读写以及复杂数据分析时,往往显得力不从心,难以满足企业日益增长的业务需求。为了解决这些问题,各种新型数据库技术应运而生,阿里云Tablestore便是其中的佼佼者。阿里云Tablestore是一款构建在阿里云飞天分布式系统之上的分布式NoSQL数据存储服
- MySQL 锁等待超时问题解析:Lock wait timeout exceeded;try restarting transaction
Java皇帝
mysqljavamysql数据库后端开发语言
目录一、问题背景二、问题原因三、解决方案1.重启事务2.优化事务管理3.调整锁等待超时设置4.分析并优化锁竞争5.查找并终止持有锁的操作6.优化SQL语句四、预防措施五、总结在使用MySQL数据库时,Lockwaittimeoutexceeded;tryrestartingtransaction这个错误是个让人头疼的问题,它不仅影响程序的执行效率,还可能导致系统性能下降甚至卡死。接下来,我将深入浅
- MySQL 报错Lock wait timeout exceeded; try restarting transaction
A486525173
mysql数据库
处理MySQL报错Lockwaittimeoutexceeded;tryrestartingtransaction1.使用SELECT*FROMinformation_schema.INNODB_TRX;定位未结束的事务,在查询出来的数据找到要删除的事务取出trx_mysql_thread_id的ID使用KILLtrx_mysql_thread_id结束事务
- MySQL数据库的优化技巧:数据合规
数据库管理艺术
数据库mysqlai
从性能到合规:MySQL数据库的双向优化实战指南关键词数据合规、MySQL优化、GDPR、数据脱敏、审计日志、访问控制、数据生命周期摘要在数据安全法规(如GDPR、《个人信息保护法》)日益严格的今天,企业数据库不仅要追求高性能,更需满足合规要求。本文将结合MySQL的实际场景,拆解"性能优化"与"数据合规"的协同路径,通过生活化比喻、代码示例和真实案例,帮助DBA、开发人员掌握从数据分类到脱敏、从
- 深入探索 MyBatis 框架:原理、实践与优化
终见曦月
javamaven
一、MyBatis框架概述在Java开发的世界里,MyBatis作为一款优秀的持久层框架,为我们与数据库的交互提供了极大的便利。它的核心价值在于简化了数据库操作,让我们能够更加专注于业务逻辑的实现。(一)什么是MyBatisMyBatis是一款支持自定义SQL、存储过程以及高级映射的持久层框架。它能够将Java对象与数据库记录进行映射转换,从而实现数据的持久化操作。简单来说,就是我们可以通过简单的
- jfinal结合easyui完成基本的增删改查操作
顽疲
jfinal学习jfinaljavaeasyuicrud
jfinal结合easyui完成增删改查操作创建jfinal项目,具体不多说,下面会放出源码。请结合jfinal官网创建一个jfinal项目,加深印象。什么是jfinal?JFinal是基于Java语言的极速web开发框架。重点在于easyui的分页下面贴出部分代码publicvoiduserList(){Stringsql="fromuserorderbyiddesc";Pagepaginate
- 【MCP】MCP鉴权: 使用Header认证保护SSE通信
EulerBlind
MCPLLM人工智能
引言服务器发送事件(Server-SentEvents,SSE)是一种基于HTTP的技术,允许服务器向客户端推送实时更新。与WebSocket不同,SSE是单向通信机制,非常适合于需要服务器实时推送数据但不需要客户端频繁发送消息的场景。在构建现代Web应用程序时,安全性至关重要。本文将探讨如何在SSE通信中实现基于Header的认证机制,确保只有经过授权的客户端才能接收服务器推送的实时数据。我们将
- Mybatis简介与原理详解
CodeGu
mybatisoracle数据库编程
Mybatis简介与原理详解MyBatis是一种Java持久化框架,它通过将SQL语句与Java代码进行映射,提供了一种简单、直观的方法来访问关系型数据库。本文将介绍MyBatis的原理和使用方法,并提供相应的源代码示例。一、MyBatis的原理数据库配置在使用MyBatis之前,需要进行数据库的配置。首先,我们需要在配置文件中定义数据库连接信息,包括数据库驱动、URL、用户名和密码。这些信息将被
- 部署项目后配置nginx 前端项目地址路径
weixin_54129994
server{listen端口;server_nameip地址;#charsetkoi8-r;#access_loglogs/host.access.logmain;location/{root/home/userManagement;//路径indexindex.htmlindex.htm;//文件try_files$uri$uri//index.html;expires7d;}location
- SQL函数和存储过程的区别
_深巷的猫
sql
本质上没区别。只是函数有如:只能返回一个变量的限制。而存储过程可以返回多个。而函数是可以嵌入在sql中使用的,可以在select中调用,而存储过程不行。执行的本质都一样。函数限制比较多,比如不能用临时表,只能用表变量.还有一些函数都不可用等等.而存储过程的限制相对就比较少1.一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强。2.对于存储过程来说可以返回参数,而函数只能返回值或
- 07 | 查询最近一笔有效订单
走过冬季
SQL面试真题详解大数据数据仓库数据分析面试sql
目录一、问题定义与业务场景二、数据准备与建表语句2.1建表语句2.2样例数据2.3期望结果三、问题分析四、SQL解决方案一、问题定义与业务场景目标:为每个用户查询最近一笔有效订单(非取消状态且最近完成)。核心需求:排除is_valid=0(取消状态)的订单返回每个用户最近一笔成功订单的详细信息无有效订单时返回NULL业务场景:电商订单追溯、风控系统交易校验、用户行为分析。二、数据准备与建表语句2.
- 设计模式 19 观察者模式
设计模式19创建型模式(5):工厂方法模式、抽象工厂模式、单例模式、建造者模式、原型模式结构型模式(7):适配器模式、桥接模式、组合模式、装饰者模式、外观模式、享元模式、代理模式行为型模式(11):责任链模式、命令模式、解释器模式、迭代器模式、中介者模式、备忘录模式、观察者模式、状态模式、策略模式、模板方法模式、访问者模式文章目录设计模式19观察者模式(ObserverPattern)1定义2结构
- C# Linq to SQL:数据库编程的解决方案
阿蒙Armon
C#工作中的应用数据库c#linq
C#LinqtoSQL:数据库编程的解决方案LINQtoSQL是.NET平台上最早的ORM(对象关系映射)框架之一,它允许开发者使用LINQ语法直接与关系型数据库进行交互,而无需编写复杂的SQL语句。本文将深入探讨LINQtoSQL的核心概念、工作原理、常见操作及最佳实践。一、什么是LINQtoSQLLINQtoSQL是Microsoft为.NETFramework开发的一种数据访问技术,它作为L
- 基础知识:mysql-connector-j依赖
mysql-connector-j是MySQL官方提供的Java数据库连接驱动(JDBCDriver),用于在Java应用程序中连接和操作MySQL数据库。它是MySQL8.0版本之后的标准驱动名称,替代了旧的mysql-connector-java。一、新旧版本对比驱动名称适用MySQL版本主要区别mysql-connector-java5.x及以下旧版驱动,已停止更新,最后版本为8.0.31(
- 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独立出来,数据持