springboot 集成 cassandra3.11.10

1.pom:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-cassandra</artifactId>
</dependency>

2.yml:

spring:
  data:
    cassandra:
      keyspace-name: spacenametest
      #entity-base-packages:
      contact-points: 集群地址用逗号分隔
      port: 9042
      cluster-name: Test Cluster
      username: cass用户名
      password: cass密码
      consistency-level: ONE
      serial-consistency-level: ONE

3.CassandraConfig.java

package com.config;


import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.cassandra.config.AbstractCassandraConfiguration;
import org.springframework.data.cassandra.config.CqlSessionFactoryBean;

@Configuration
public class CassandraConfig extends AbstractCassandraConfiguration {

    //空间名称
    @Value("${spring.data.cassandra.keyspace-name}")
    private String keyspaceName;

    //节点IP(连接的集群节点IP)
    @Value("${spring.data.cassandra.contact-points}")
    private String contactPoints;

    @Value("${spring.data.cassandra.username}")
    private String username;

    @Value("${spring.data.cassandra.password}")
    private String password;

//    @Value("${spring.data.cassandra.session-name}")
//    private String sessionName;

    public String getKeyspaceName() {
        return keyspaceName;
    }

    public String getContactPoints() {
        return contactPoints;
    }

//    @Override
//    public String getSessionName() {
//        return sessionName;
//    }

//    @Override
//    public String getLocalDataCenter() {
//        return "datacenter1";
//    }

    @Override
    public CqlSessionFactoryBean cassandraSession() {
        CqlSessionFactoryBean cqlSessionFactoryBean = super.cassandraSession();
        cqlSessionFactoryBean.setPassword(password);
        cqlSessionFactoryBean.setUsername(username);
        return cqlSessionFactoryBean;
    }

}

4.表student列名的映射文件Student.java

package com.cas4.entity;

import lombok.Getter;
import lombok.Setter;
import org.springframework.data.cassandra.core.cql.PrimaryKeyType;
import org.springframework.data.cassandra.core.mapping.Column;
import org.springframework.data.cassandra.core.mapping.PrimaryKeyColumn;
import org.springframework.data.cassandra.core.mapping.Table;

@Setter
@Getter
@Table(value = "student")
public class Student {

//@PrimaryKeyColumn(value = "id", type = PrimaryKeyType.CLUSTERED)
    @PrimaryKeyColumn(value = "id", type = PrimaryKeyType.PARTITIONED)
    private int id;
    @Column("name")
    private String name;
    @Column("age")
    private int age;

}

4.service调用:

package com.cas4.service;

import com.cas4.entity.Student;
import org.springframework.data.cassandra.core.CassandraTemplate;
import org.springframework.stereotype.Service;

import javax.annotation.Resource;
import java.util.List;

@Service
public class ServiceImpl {

    @Resource
    private CassandraTemplate cassandraTemplate;

    //自定义sql语句
    public Student findByTenantIdAndSequenceId(String tenantId, String sequenceId) {
        String cql = String.format("select * from master_order where tenant_id = '%s' and sequence_id='%s'", tenantId, sequenceId);
        Student student = cassandraTemplate.selectOne(cql, Student.class);
        return student;
    }

    public void insert(Student masterOrderDO) {
        //插入
        cassandraTemplate.insert(masterOrderDO);
        //删除
//        cassandraTemplate.delete(masterOrderDO);
    }

    public void find(Student student) {
        //插入
        List<Student> list  = cassandraTemplate.select("select * from spacenametest.student where v='"+ student.getV()+"'", Student.class);
        System.out.println("总条数:"+list.size());
    }

}
 

5.cassandra进入建表命令:

bin]# ./cqlsh x.x.x.x 9042 -u cass用户名 -p cass密码

use spacenametest;

CREATE TABLE student(
  id int,
  name text,
  age int,
  PRIMARY KEY (id,name)  --多个主键
)

或者

CREATE TABLE student(
  id int PRIMARY KEY,  --一个主键
  name text,
  age int,
  PRIMARY KEY 
)
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Spring Boot中整合Cassandra可以通过以下几个步骤完成: 1. 添加Cassandra依赖:在`pom.xml`文件中添加Cassandra的驱动依赖,例如: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-cassandra</artifactId> </dependency> ``` 2. 配置Cassandra连接信息:在`application.properties`文件中配置Cassandra的连接信息,例如: ```properties spring.data.cassandra.contact-points=your-cassandra-host spring.data.cassandra.port=9042 spring.data.cassandra.keyspace-name=your-keyspace-name ``` 3. 创建实体类:创建与Cassandra表对应的实体类,使用`@Table`注解指定表名,使用`@PrimaryKey`注解指定主键,例如: ```java @Table("users") public class User { @PrimaryKey("id") private UUID id; @Column("name") private String name; // getters and setters } ``` 4. 创建Repository:创建一个继承自`CassandraRepository`的接口,用于定义对Cassandra表的操作,例如: ```java @Repository public interface UserRepository extends CassandraRepository<User, UUID> { List<User> findByName(String name); } ``` 5. 使用Repository:在需要访问Cassandra数据的地方使用自动注入的Repository进行操作,例如: ```java @Service public class UserService { @Autowired private UserRepository userRepository; public List<User> getUsersByName(String name) { return userRepository.findByName(name); } } ``` 这样就完成了Spring Boot与Cassandra的整合。你可以根据具体的业务需求,使用Repository提供的方法进行数据操作。如果需要更复杂的查询,可以使用Cassandra的查询语言CQL来编写自定义查询。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值