学习历程-------java+sql篇

1、写内部sql语句

=======调用接口=========

 @Autowired
    DataSource dataSource;

    private Db db;


----------------

if (db == null) {
            db = DbUtil.use(dataSource);
        }

String sql = "select count(*) from prj_new_energy where org_name=? and prj_category=?";

List<Entity> datalist = db.query(sql,"安徽分公司", industryName);

注:db.query后面的参数可以跟多个,看自己sql里面有多少'?',对应位置。具体可以看内部实现

2、sql语句的in后面如果放数组

===注意:因为数组是以'[  ]'开始和结束,而in是'(  )'开始和结束,所以直接使用会直接报错,这里需要转一下

//数组
List<String> list = new ArrayList<>();

list.add('1');
list.add('2');
list.add('3');

System.out.println(list.toString());  //输出:['1','2','3']
System.out.println(StringUtils.strip(list.toString(),"[]"));//输出:'1','2','3'


//然后就可以拼接sql语句了

String li = StringUtils.strip(list.toString(),"[]");

String sql = "select count(*) from user where and org_code in ("+li+")";

PS:in后面的参数需要‘ ’引号引住,不然会报错

3、获取连接数据库的所有表名及表的columns

-------引用dataSource-------
 @Autowired
 DataSource dataSource;



public void getTablesAndColumns(){
        List  tableList=MetaUtil.getTables(dataSource);//表list集合
        tableList.forEach(i->{
            String[] ss =MetaUtil.getColumnNames(dataSource,i.toString());//字段数组
            System.out.println(ss);
        });
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值