druid 数据源,插入数据只能成功一条,第二次(第二条)没法插入成功
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了druid 数据源,插入数据只能成功一条,第二次(第二条)没法插入成功相关的知识,希望对你有一定的参考价值。
使用的是mybatis,spring和druid
mapper配置
<insert id="insert" parameterType="Dept">
INSERT INTO XT_DEPT(<include refid="columns"/>)
VALUES (#id,jdbcType=VARCHAR,#deptName,jdbcType=VARCHAR,#address,jdbcType=VARCHAR,
#leader,jdbcType=VARCHAR,#tel,jdbcType=VARCHAR,#distCode,jdbcType=VARCHAR,
#postCode,jdbcType=VARCHAR,#fax,jdbcType=VARCHAR,#pid,jdbcType=VARCHAR)
</insert>
测试代码
@Test
public void testServiceInsert()
for(int i = 1000; i < 10020;i++)
Dept d = new Dept();
d.setId(UUIDUtil.getID());
d.setDeptName("第"+i+"次数据");
d.setDistCode("360124");
d.setAddress("啊沙发撒旦法"+i);
d.setTel("010-2342234");
d.setFax("010-342342");
d.setPid(null);
d.setPostCode("330821");
d.setLeader("米子"+i);
int rs = service.insert(d);
System.out.println(rs);
第一条成功的
第二条时:java.sql.SQLException: 索引中丢失 IN 或 OUT 参数:: 10
org.springframework.jdbc.UncategorizedSQLException:
### Error updating database. Cause: java.sql.SQLException: 索引中丢失 IN 或 OUT 参数:: 10
### The error may involve com.hdsx.framework.author.mapper.orcl.DeptMapper.insert-Inline
### The error occurred while setting parameters
### SQL: INSERT INTO XT_DEPT( ID, DEPTNAME, ADDRESS, LEADER, TEL, DISTCODE, POSTCODE, FAX, PID ) VALUES (?,?,?, ?,?,?, ?,?,?)
### Cause: java.sql.SQLException: 索引中丢失 IN 或 OUT 参数:: 10
; uncategorized SQLException for SQL []; SQL state [null]; error code [17041]; 索引中丢失 IN 或 OUT 参数:: 10; nested exception is java.sql.SQLException: 索引中丢失 IN 或 OUT 参数:: 10
----------------------
Caused by: java.sql.SQLException: 索引中丢失 IN 或 OUT 参数:: 10
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:112)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:146)
at oracle.jdbc.driver.OraclePreparedStatement.processCompletedBindRow(OraclePreparedStatement.java:1742)
at oracle.jdbc.driver.OraclePreparedStatement.executeInternal(OraclePreparedStatement.java:3334)
at oracle.jdbc.driver.OraclePreparedStatement.execute(OraclePreparedStatement.java:3445)
at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:2931)
at com.alibaba.druid.filter.FilterEventAdapter.preparedStatement_execute(FilterEventAdapter.java:440)
at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:2929)
at com.alibaba.druid.proxy.jdbc.PreparedStatementProxyImpl.execute(PreparedStatementProxyImpl.java:118)
at com.alibaba.druid.pool.DruidPooledPreparedStatement.execute(DruidPooledPreparedStatement.java:493)
.......
第一条数据在数据库中看到了,可以肯定成功了
- (void)insertRowsAtIndexPaths:(NSArray *)indexPaths withRowAnimation:(UITableViewRowAnimation)animation;
indexPaths是一个数组,里面装的是NSIndexPath,就是指插入的位置,animation是BOOL值,是否要动画效果。追问
看不太懂,好像不是java是安卓代码吧。框架的数据源要使用druid,这个不能变的(bonecp的以前就可以使用了)。
参考技术A 你的问题解决了吗,我现在也遇到同样的问题!追问没有,没有再用这个数据源了 改用了别的框架
DBUtils+druid基本使用
DBUtils+druid
DBUtils + druid实现数据库增删查改
DBUtils + druid实现多行数据查询
//演示 apache - dbutils + druid 完成 返回的结果是多行记录(多个对象)List
public void testQueryMany() throws SQLException { // 返回结果是多行的情况
//1.得到连接(druid)
Connection connection=JDBCUtilsByDruid.getConnection();
//2.使用DBUtils类和接口,先引入DBUtils 相关的jar
//3.创建 QueryRunner
QueryRunner queryRunner = new QueryRunner();
String sql="select * from course where course_id>=?";
//4.就可以执行相关的方法,返回ArrayList结果集
//4.1、query 方法 就是执行sql语句,得到resultset ----封装到 -->ArrayList集合中
//4.2、返回集合
//4.3、connection:连接
//4.4、sql:执行的sql语句
//4.5、new BeanListHandler<>(student.class):在将resultset -->student对象-->封装到ArrayList中
// 底层使用反射机制,去获取student类的属性,然后进行封装
//4.6、1:就是给sql语句中问号赋值的,可以有多个值,因为他是可变的参数 Object...params
//4.7、底层得到的resultset,会在query关闭,也会关闭PreparedStatment
List<student> query =
queryRunner.query(connection,sql , new BeanListHandler<>(student.class), "c1");
System.out.println(query.size());
for (student studen:query){
System.out.println(studen);
}
//释放资源
JDBCUtilsByDruid.close(null,null,connection);
}
new BeanListHandler<>(student.class) 通过反射,去查找javaBean中有多少属性,从而在数据库中查找到对相应的数据存入到结果集(List)中
DBUtils + druid实现单行数据查询
//演示 apache - dbutils + druid 完成 返回的结果是单行记录(单个对象)
public void testQuerySingle() throws SQLException {
//1.得到 连接(druid)
Connection connection = JDBCUtilsByDruid.getConnection();
//2.使用 DBUtils 类和接口 ,先引入DBUtils 相关的jar
//3.创建QueryRunner
QueryRunner queryRunner=new QueryRunner();
//4.执行相关方法,返回单个对象
String sql="select * from course where course_id=?";
student c1 = queryRunner.query(connection, sql, new BeanHandler<>(student.class), "c1");
System.out.println(c1);
//释放资源
JDBCUtilsByDruid.close(null,null,connection);
}
new BeanHandler<>(student.class) 通过反射查询javaBean类中的属性
返回单行数据
DBUtils + druid实现单个数据查询
//演示 DBUtils + druid 完成查询结果是单行单列的--->返回的就是Object
@Test
public void testScalar() throws SQLException {
//1.得到连接
Connection connection= JDBCUtilsByDruid.getConnection();
//2.使用 DBUtils 类和接口
//3.创建QueryRunner
QueryRunner queryRunner=new QueryRunner();
//4.创建sql语句
String sql="select course_name from course where course_id=?";
Object c1 = queryRunner.query(connection, sql, new ScalarHandler(), "c1");
System.out.println(c1);
System.out.println();
//释放资源
JDBCUtilsByDruid.close(null,null,connection);
}
new ScalarHandler() 查询单个数据时用到的方法
返回一个Object类型的数据
DBUtils + druid实现数据库DML
//演示apache- dbutils +druid 完成DML(update , insert , delete)
@Test
public void testDML() throws SQLException {
//1.得到连接
Connection connection=JDBCUtilsByDruid.getConnection();
//2.使用DBUtils 类和接口,
//3.创建QueryRunner
QueryRunner queryRunner=new QueryRunner();
//4.这里组织sql 完成update ,insert ,delete
//修改数据库
// String sql="update course set course_name=? where course_id=?";
// int update = queryRunner.update(connection, sql,"杨过","c5");
//插入一条数据到数据库
// String sql2="insert into course value('c4','才春磊','2002')";
// int update2=queryRunner.update(connection, sql2);
//从数据库中删除一条数据
String sql3="delete from course where course_id=?";
int update3=queryRunner.update(connection,sql3,"c5");
System.out.println(update3>0?"执行成功":"没有影响到数据库");
//释放资源
JDBCUtilsByDruid.close(null,null,connection);
}
修改数据库中的一条数据
//修改数据库
String sql="update course set course_name=? where course_id=?";
int update = queryRunner.update(connection, sql,"杨过","c5");
插入一条数据到数据库
//插入一条数据到数据库
String sql2="insert into course value('c4','才春磊','2002')";
int update2=queryRunner.update(connection, sql2);
从数据库中删除一条数据
//从数据库中删除一条数据
String sql3="delete from course where course_id=?";
int update3=queryRunner.update(connection,sql3,"c5");
queryRunner.update方法返回的int类型是执行操作后数据库中受影响的行数
最后释放资源
JDBCUtilsByDruid.close(null,null,connection);
BasicDao实例
BasicDao.java
package com.hb.dao_.dao;
import com.hb.dao_.utils.JDBCUtilsByDruid;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.apache.commons.dbutils.handlers.ScalarHandler;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.List;
/*
*
* @Author ccl
* @Description //开发BasicDao,其他dao的父类
* @Date 11:44 2021/7/5
* @return
**/
public class BasicDao<T> { //泛型指定具体类型
private QueryRunner qr=new QueryRunner();
//开发通用的dml方法,针对任意的表
public int update(String sql ,Object... parameters){
//定义Connection
Connection connection=null;
try {
connection= JDBCUtilsByDruid.getConnection();
int update = qr.update(connection, sql, parameters);
return update;
} catch (SQLException e) {
throw new RuntimeException(e); //将编译异常 变为 运行异常,抛出
}finally {
JDBCUtilsByDruid.close(null,null,connection);
}
}
/*
*
* @Author ccl
* @Description sql sql语句可以有?
* clazz 传入一个类的Class对象,比如course.class
* parameters 传入?的具体的值,可以是多个
* @Date 11:54 2021/7/5
* @return
**/
//返回多个对象(即查询的结果是多行),针对任意表
public List<T> queryMulti(String sql, Class<T> clazz,Object... parameters){
Connection connection=null;
try {
connection=JDBCUtilsByDruid.getConnection();
return qr.query(connection,sql,new BeanListHandler<>(clazz),parameters);
} catch (SQLException e) {
throw new RuntimeException(e);
}finally {
JDBCUtilsByDruid.close(null,null,connection);
}
}
//查询单行结果的通用方法
public T querySingle(String sql ,Class<T> clazz,Object... parameters){
Connection connection=null;
try {
connection=JDBCUtilsByDruid.getConnection();
return qr.query(connection,sql,new BeanHandler<T>(clazz),parameters);
} catch (SQLException e) {
throw new RuntimeException(e);
}finally {
JDBCUtilsByDruid.close(null,null,connection);
}
}
//查询单行单列的方法,即返回单值的方法
public Object queryScalar(String sql, Object... parameters){
Connection connection=null;
try {
connection=JDBCUtilsByDruid.getConnection();
return qr.query(connection,sql,new ScalarHandler(),parameters);
} catch (SQLException e) {
throw new RuntimeException(e);
} finally {
JDBCUtilsByDruid.close(null,null,connection);
}
}
}
Goods.java
public class GoodsDao extends BasicDao<Goods>{
}
因为是继承了BasicDao,所以Goods类中有BasicDao中的所有方法
插入一条数据到数据库中
GoodsDao goodsDao=new GoodsDao();
int update = goodsDao.update("insert into Goods values(?,?,?)", 2, "vivo", 3000);
System.out.println(update>0?"插入成功":"没有对表发生改变");
修改数据库中的数据
GoodsDao goodsDao=new GoodsDao();
int apple = goodsDao.update("update Goods set goods_name=? where id=?", "苹果手机", 1);
System.out.println(apple>0?"修改成功":"没有对表发生改变");
删除数据库中的一条数据
GoodsDao goodsDao=new GoodsDao();
int update1 = goodsDao.update("delete from Goods where id=?", 1);
System.out.println(update1>0?"删除成功":"数据库没有发生改变");
查询多行数据
GoodsDao goodsDao=new GoodsDao();
List<Goods> goods = goodsDao.queryMulti("select*from Goods where id>=?", Goods.class, "1");
for (Goods g:goods){
System.out.println(g);
}
查询单行数据
GoodsDao goodsDao=new GoodsDao();
Goods goods = goodsDao.querySingle("select*from Goods where id=?", Goods.class, 1);
System.out.println(goods);
查询单行单列数据
GoodsDao goodsDao=new GoodsDao();
Object o = goodsDao.queryScalar("select goods_name from Goods where id=?", 4);
System.out.println(o);
以上是关于druid 数据源,插入数据只能成功一条,第二次(第二条)没法插入成功的主要内容,如果未能解决你的问题,请参考以下文章