Project Icon

spring-data-couchbase

Spring框架扩展简化Couchbase数据访问

Spring Data Couchbase为Couchbase Server提供了基于Spring的编程模型。该项目支持POJO与Couchbase的交互,实现了repository风格的数据访问层,并集成了对象映射功能。它还支持N1QL查询、地理空间查询和JMX管理,为开发者提供了全面的Couchbase数据访问方案。

= Spring Data Couchbase image:https://jenkins.spring.io/buildStatus/icon?job=spring-data-couchbase%2Fmain&subject=Build[link=https://jenkins.spring.io/view/SpringData/job/spring-data-couchbase/] https://gitter.im/spring-projects/spring-data[image:https://badges.gitter.im/spring-projects/spring-data.svg[Gitter]] image:https://img.shields.io/badge/Revved%20up%20by-Develocity-06A0CE?logo=Gradle&labelColor=02303A["Revved up by Develocity", link="https://ge.spring.io/scans?search.rootProjectNames=Spring Data Couchbase"]

https://www.springsource.org/spring-data[Spring Data]项目的主要目标是让构建使用新的数据访问技术(如非关系型数据库、MapReduce框架和基于云的数据服务)的Spring应用程序变得更加容易。

Spring Data Couchbase项目旨在为Couchbase Server作为文档数据库和缓存提供一个熟悉且一致的基于Spring的编程模型,同时保留特定存储的特性和功能。Spring Data Couchbase的主要功能领域包括以POJO为中心的模型,用于与Couchbase Server Bucket交互,以及轻松编写repository风格的数据访问层。

集成测试需要一个Couchbase服务器,其中有一个名为"protected"的bucket,密码设置为"password"。如果服务器允许用户,还应设置一个用户名为"protected"、密码为"password"的用户。运行测试的推荐方式是安装Docker并使用server.properties中的容器。

该项目由Couchbase, Inc.领导和维护。

== 特性

  • 使用基于Java的@Configuration类或XML命名空间支持Couchbase驱动程序(Java SDK版本2.x)的Spring配置。
  • CouchbaseTemplate辅助类提高了执行常见Couchbase操作的生产力。包括文档和POJO之间的集成对象映射。
  • 将异常转换为Spring的可移植数据访问异常层次结构。
  • 功能丰富的对象映射,与Spring的转换服务集成。
  • 基于注解的映射元数据,但可扩展以支持其他元数据格式。
  • 自动实现Repository接口,包括支持自定义查找方法(由Couchbase的查询语言N1QL支持)和PagingAndSortingRepository
  • 对于Couchbase服务器版本<4.0,存储库仍可由Couchbase Views支持。
  • 支持地理空间和多维查询(由Couchbase空间视图支持)
  • JMX管理和监控
  • 可作为@Cacheable支持的后端,缓存任何需要高性能访问的对象(参见Couchbase GitHub中的兄弟Spring Cache项目,https://github.com/couchbaselabs/couchbase-spring-cache[couchbaselabs/couchbase-spring-cache])。

== 版本兼容性

Spring-Data CouchbaseCouchbase Java SDK 2.x一代的Spring Data连接器。

SDK和这个Spring Data社区项目都是主要版本变更,与各自的前一版本有很多不同。

值得注意的是,此版本兼容Couchbase Server 4.0,支持N1QL查询语言。

== 行为准则

本项目受https://github.com/spring-projects/.github/blob/e3cc2ff230d8f1dca06535aa6b5a4a23815861d4/CODE_OF_CONDUCT.md[Spring行为准则]管理。参与者应遵守此行为准则。请将不可接受的行为报告给spring-code-of-conduct@pivotal.io。

== 入门

这里是一个使用Spring Data Repositories的Java应用程序的快速示例:

[source,java]

public interface PersonRepository extends CrudRepository<Person, Long> {

List findByLastname(String lastname);

List findByFirstnameLike(String firstname); }

@Service public class MyService {

private final PersonRepository repository;

public MyService(PersonRepository repository) { this.repository = repository; }

public void doWork() {

repository.deleteAll();

Person person = new Person();
person.setFirstname("Couch");
person.setLastname("Base");
repository.save(person);

List<Person> lastNameResults = repository.findByLastname("Base");
List<Person> firstNameResults = repository.findByFirstnameLike("Cou*");

} }

@Configuration @EnableCouchbaseRepositories public class Config extends AbstractCouchbaseConfiguration {

@Override
protected List<String> getBootstrapHosts() {
	return Arrays.asList("host1", "host2");
}

@Override
protected String getBucketName() {
	return "default";
}

@Override
protected String getPassword() {
	return "";
}

}

=== Maven配置

添加Maven依赖:

[source,xml]

org.springframework.data spring-data-couchbase ${version} ----

如果你更喜欢即将发布的主要版本的最新快照,请使用我们的Maven快照仓库并声明适当的依赖版本。

[source,xml]

org.springframework.data spring-data-couchbase ${version}-SNAPSHOT spring-snapshot Spring Snapshot Repository https://repo.spring.io/snapshot ----

== 获取帮助

使用Spring Data遇到问题?我们很乐意帮忙!

== 报告问题

Spring Data使用GitHub作为问题跟踪系统来记录bug和功能请求。如果你想提出一个问题,请遵循以下建议:

== 从源代码构建

你不需要从源代码构建来使用Spring Data(二进制文件在https://repo.spring.io[repo.spring.io]中),但如果你想尝试最新和最棒的功能,可以使用https://github.com/takari/maven-wrapper[maven wrapper]轻松构建Spring Data。你还需要JDK 17或更高版本。

[source,bash]

$ ./mvnw clean install

如果你想使用常规的mvn命令构建,你需要https://maven.apache.org/run-maven/index.html[Maven v3.5.0或更高版本]。

如果你希望提交pull请求,另请参阅link:CONTRIBUTING.adoc[CONTRIBUTING.adoc],特别是在进行第一个非微小更改之前,请签署https://cla.pivotal.io/sign/spring[贡献者协议]。

=== 构建参考文档

构建文档也会构建项目,但不运行测试。

[source,bash]

$ ./mvnw clean install -Pantora

生成的文档可在target/antora/site/index.html中找到。

=== 构建并暂存参考文档以供审阅

[source,bash]

export MY_GIT_USER= mvn generate-resources docs=pwd/target/site/reference/html pushd /tmp mkdir $$ cd $$

参见 https://docs.github.com/en/pages/getting-started-with-github-pages/creating-a-github-pages-site

此示例使用名为"staged"的仓库

git clone git@github.com:${MY_GIT_USER}/staged.git -b gh-pages cd staged cp -R $docs/* . git add . git commit --message "stage for review" git push origin gh-pages popd

生成的文档可在target/site/reference/html/index.html中找到。

== 示例

== 许可证

Spring Data Couchbase是根据https://www.apache.org/licenses/LICENSE-2.0.html[Apache 2.0许可证]发布的开源软件。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号