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)

.......
第一条数据在数据库中看到了,可以肯定成功了

UITableView 有一个方法,叫做
- (void)insertRowsAtIndexPaths:(NSArray *)indexPaths withRowAnimation:(UITableViewRowAnimation)animation;

indexPaths是一个数组,里面装的是NSIndexPath,就是指插入的位置,animation是BOOL值,是否要动画效果。追问

看不太懂,好像不是java是安卓代码吧。框架的数据源要使用druid,这个不能变的(bonecp的以前就可以使用了)。

参考技术A 你的问题解决了吗,我现在也遇到同样的问题!追问

没有,没有再用这个数据源了 改用了别的框架

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 数据源,插入数据只能成功一条,第二次(第二条)没法插入成功的主要内容,如果未能解决你的问题,请参考以下文章

DBUtils+druid基本使用

php 注册表单 为啥在显示注册成功后却在数据库里找不到呢 给20分!!

数据库中只能插入一条数据

Spring Boot实战之MyBatis、Druid

scrum 第二次冲刺

第二次冲刺