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);
});
}