如果是maven项目,在pom.xml里加入依赖。不是的话下载相应的jar包放到lib目录下。这里驱动包的版本要和你cassandra的大版本一致。我这里cassandra的版本是最新的3.9,驱动是3.0

 <dependency>
<groupId>com.datastax.cassandra</groupId>
<artifactId>cassandra-driver-core</artifactId>
<version>3.0.0</version>
</dependency>

新建一个类CassandraTest。

连接cassandra

 public Cluster cluster;

 public Session session;

 public void connect()
{
// addContactPoints:cassandra节点ip withPort:cassandra节点端口 默认9042
// withCredentials:cassandra用户名密码 如果cassandra.yaml里authenticator:AllowAllAuthenticator 可以不用配置
cluster = Cluster.builder().addContactPoints("192.168.3.89").withPort(9042)
.withCredentials("cassandra", "cassandra").build();
session = cluster.connect();
}

驱动里自带了cassandra连接池的配置,将上面的稍作修改

 public Cluster cluster;

 public Session session;

 public void connect()
{
PoolingOptions poolingOptions = new PoolingOptions();
// 每个连接的最大请求数 2.0的驱动好像没有这个方法
poolingOptions.setMaxRequestsPerConnection(HostDistance.LOCAL, 32);
// 表示和集群里的机器至少有2个连接 最多有4个连接
poolingOptions.setCoreConnectionsPerHost(HostDistance.LOCAL, 2).setMaxConnectionsPerHost(HostDistance.LOCAL, 4)
.setCoreConnectionsPerHost(HostDistance.REMOTE, 2).setMaxConnectionsPerHost(HostDistance.REMOTE, 4); // addContactPoints:cassandra节点ip withPort:cassandra节点端口 默认9042
// withCredentials:cassandra用户名密码 如果cassandra.yaml里authenticator:AllowAllAuthenticator 可以不用配置
cluster = Cluster.builder().addContactPoints("192.168.3.89").withPort(9042)
.withCredentials("cassandra", "cassandra").withPoolingOptions(poolingOptions).build();
// 建立连接
// session = cluster.connect("test");连接已存在的键空间
session = cluster.connect(); }

创建键空间和表(这2个最好在搭建cassandra的时候完成)

 /**
* 创建键空间
*/
public void createKeyspace()
{
// 单数据中心 复制策略 :1
String cql = "CREATE KEYSPACE if not exists mydb WITH replication = {'class': 'SimpleStrategy', 'replication_factor': '1'}";
session.execute(cql);
} /**
* 创建表
*/
public void createTable()
{
// a,b为复合主键 a:分区键,b:集群键
String cql = "CREATE TABLE if not exists mydb.test (a text,b int,c text,d int,PRIMARY KEY (a, b))";
session.execute(cql);
}

对test表的CURD操作

 /**
* 插入
*/
public void insert()
{
String cql = "INSERT INTO mydb.test (a , b , c , d ) VALUES ( 'a2',4,'c2',6);";
session.execute(cql);
} /**
* 修改
*/
public void update()
{
// a,b是复合主键 所以条件都要带上,少一个都会报错,而且update不能修改主键的值,这应该和cassandra的存储方式有关
String cql = "UPDATE mydb.test SET d = 1234 WHERE a='aa' and b=2;";
// 也可以这样 cassandra插入的数据如果主键已经存在,其实就是更新操作
String cql2 = "INSERT INTO mydb.test (a,b,d) VALUES ( 'aa',2,1234);";
// cql 和 cql2 的执行效果其实是一样的
session.execute(cql);
} /**
* 删除
*/
public void delete()
{
// 删除一条记录里的单个字段 只能删除非主键,且要带上主键条件
String cql = "DELETE d FROM mydb.test WHERE a='aa' AND b=2;";
// 删除一张表里的一条或多条记录 条件里必须带上分区键
String cql2 = "DELETE FROM mydb.test WHERE a='aa';";
session.execute(cql);
session.execute(cql2);
} /**
* 查询
*/
public void query()
{
String cql = "SELECT * FROM mydb.test;";
String cql2 = "SELECT a,b,c,d FROM mydb.test;"; ResultSet resultSet = session.execute(cql);
System.out.print("这里是字段名:");
for (Definition definition : resultSet.getColumnDefinitions())
{
System.out.print(definition.getName() + " ");
}
System.out.println();
System.out.println(String.format("%s\t%s\t%s\t%s\t\n%s", "a", "b", "c", "d",
"--------------------------------------------------------------------------"));
for (Row row : resultSet)
{
System.out.println(String.format("%s\t%d\t%s\t%d\t", row.getString("a"), row.getInt("b"),
row.getString("c"), row.getInt("d")));
}
}

查询显示:

JAVA操作cassandra数据库的更多相关文章

  1. Java操作Sqlite数据库-jdbc连接

    Java操作Sqlite数据库步骤: 1. 导入Sqlite jdbc 本文使用sqlite-jdbc-3.7.2.jar,下载地址 http://pan.baidu.com/s/1kVHAGdD 2 ...

  2. Linux+Redis实战教程_day02_3、redis数据类型_4、String命令_5、hash命令_6、java操作redis数据库技术

    3. redis数据类型[重点] redis 使用的是键值对保存数据.(map) key:全部都是字符串 value:有五种数据类型 Key名:自定义,key名不要过长,否则影响使用效率 Key名不要 ...

  3. JAVA操作MongoDB数据库

    1. 首先,下载MongoDB对Java支持的驱动包 驱动包下载地址:https://github.com/mongodb/mongo-java-driver/downloads 2.Java操作Mo ...

  4. java操作MySQL数据库(插入、删除、修改、查询、获取所有行数)

    插播一段广告哈:我之前共享了两个自己写的小应用,见这篇博客百度地图开发的两个应用源码共享(Android版),没 想到有人找我来做毕设了,年前交付,时间不是很紧,大概了解了下就接下了,主要用到的就是和 ...

  5. Java 操作MySql数据库

    Java 项目开发中数据库操作是很重要的一个方面,对于初学者来说,MySql是比较容易熟悉的一种常见数据库,这篇文章记录了如何用Java来操作MySql数据库. 第一章 JDBC的概念 JDBC(Ja ...

  6. JAVA操作ORACLE数据库的存储过程

    一.任务提出 JAVA操作oracle11g存储过程实验需要完成以下几个实例: 1.调用没有返回参数的过程(插入记录.更新记录) 2.有返回参数的过程 3.返回列表的过程 4.返回带分页的列表的过程. ...

  7. Java操作Oracle数据库以及调用存储过程

    操作Oracle数据库 publicclass DBConnection {     //jdbc:oracle:thin:@localhost:1521:orcl     publicstaticf ...

  8. java操作mongoDB数据库的简单实例

    首先导入mongoDB的jar包 http://pan.baidu.com/s/1bnGMJRD //DataBase.java package com.mongodb.test; import ja ...

  9. Java 操作Oracle数据库

    import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import ...

随机推荐

  1. 用array_search 数组中查找是否存在这个 值

    #判读里面是否还有id=1的超级管理员 $key=array_search(1, $ids); #判读这个是否存在 if($key!==FALSE){ #如果存在就unset掉这个 unset($id ...

  2. android 在githup中的资源整理(转)

    1.Github开源Android组件资源整理(一) 个性化控件(View) 2.Github开源Android组件资源整理(二)ActionBar和Menu 3. Github开源Android组件 ...

  3. cocos2d-x AssetsManager libcurl使用心得

    libcurl使用心得 最新正在写cocosclient更新的逻辑.研究了一下cocos2d-x自带的Libcurl,下面是自己在使用过程中的心得和遇到的未解问题.希望大家一起讨论一下,欢迎大家指导. ...

  4. iOS界面-仿网易新闻左侧抽屉式交互 续(添加新闻内容页和评论页手势)

     本文转载至  http://blog.csdn.net/totogo2010/article/details/8637430       1.介绍 有的博友看了上篇博文iOS界面-仿网易新闻左侧抽屉 ...

  5. angularcli填坑系列(持续更新...)

    1.在xx.ts中引入css样式无效 @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls ...

  6. JDBC通用方法实现

    在一些测试项目中会用到纯粹的jdbc操作数据库,下面提供统一的方法实现. import java.sql.CallableStatement; import java.sql.Connection; ...

  7. eclipse显示adb is down错误,无法真机调试

    cmd进入adb目录下,运行adb kill-server 和 adb start-server还是不能正常调试时, 在360的网络连接列表中找到占用端口5037的adb.exe,全部关闭,重启ecl ...

  8. 剑指Offer:栈的压入、弹出序列【31】

    剑指Offer:栈的压入.弹出序列[31] 题目描述 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列1,2,3,4,5是某栈 ...

  9. Zookeeper四字命令

    ZooKeeper 支持某些特定的四字命令(The Four Letter Words)与其进行交互.它们大多是查询命令,用来获取 ZooKeeper 服务的当前状态及相关信息.用户在客户端可以通过 ...

  10. 统一ID服务

    代码已经修改 调用方式 为restful请求  或者 feign请求  请参考 wiki:   http://192.168.120.46:8090/display/peixun/akucun+Gui ...