当前位置:Gxlcms > 数据库问题 > Springboot接口简单实现生成MySQL插入语句

Springboot接口简单实现生成MySQL插入语句

时间:2021-07-01 10:21:17 帮助过:9人阅读

Springboot接口简单实现调用接口生成MySQL插入语句

 

 

 

    在实际测试中,有这样一个需求场景,比如:在性能压力测试中,可能需要我们事先插入数据库中一些相关联的数据。

    我们在实际测试中,遇到问题,需要事先在数据库中创建10000家门店,存在shop表中。关键字段(门店的编号6位数)。

    分析:两种具体实现方案。

            一、利用MySQL函数功能随机生成<SELECT FLOOR(+ RAND() * 1000000)>,最后编写insert语句。但是效率低下。

                二、使用springboot编写接口实现,并自动生成insert脚本保存本地。

 

    本次实现以springboot接口实现此次目的:

 

  •     开发环境

      • 开发工具IDEA

      • JDK 1.8      

  •    新建springboot项目

            1、新建project

            技术图片

技术图片

 

        

 

 

        2、填写springbootDemo

 

直到填写finish完成。

    ?    ?3、pom.xml文件配置

 

  1. <?xml version="1.0" encoding="UTF-8"?><br><project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"<br> xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><br> <modelVersion>4.0.0</modelVersion><br> <parent><br> <groupId>org.springframework.boot</groupId><br> <artifactId>spring-boot-starter-parent</artifactId><br> <version>2.1.1.RELEASE</version><br> <relativePath/> <!-- lookup parent from repository --><br> </parent><br> <groupId>com.springbootDemo</groupId><br> <artifactId>demo</artifactId><br> <version>0.0.1-SNAPSHOT</version><br> <name>demo</name><br> <description>Demo project for Spring Boot</description><br><br> <properties><br> <java.version>1.8</java.version><br> </properties><br><br> <dependencies><br> <dependency><br> <groupId>org.springframework.boot</groupId><br> <artifactId>spring-boot-starter-web</artifactId><br> </dependency><br><br> <dependency><br> <groupId>org.springframework.boot</groupId><br> <artifactId>spring-boot-starter-test</artifactId><br> <scope>test</scope><br> </dependency><br><br> <dependency><br> <groupId>org.projectlombok</groupId><br> <artifactId>lombok</artifactId><br> <version>1.16.14</version><br> </dependency><br><br> </dependencies><br><br> <build><br> <plugins><br> <plugin><br> <groupId>org.springframework.boot</groupId><br> <artifactId>spring-boot-maven-plugin</artifactId><br> </plugin><br> </plugins><br> </build><br><br></project>

?

        4、打开工程,看到main里面有默认启动类。

  1. @RestController<br>@SpringBootApplication<br>public class DemoApplication {<br> public static void main(String[] args) {<br> SpringApplication.run<br>(DemoApplication.class, args);<br> }<br><br>}
  •    编写接口实现类 

    1. * 分析:<br>* inpuid: uuid<br>* sotreId=commonCode 以8开头后面五位随机<br>* createDatetime:当前时间<br>* create_by: admin<br>* is_recharge_consumption:1<br>* updateDatetime:当前时间<br>* update_by:admin<br>* sync_date:null<br>* channel_key:123456<br>* chainName: XX<br>* state:0<br>* shopCode 以8开头后面五位随机
  1. @RequestMapping("/generateSql")<br> public static String insert(@RequestParam(required = false) int size) throws IOException {<br> // 开时时间<br> Long begin = new Date().getTime();<br> log.info("begin:{}",begin);<br> for (int i = 0; i <size ; i++) {<br> StringBuffer addSql = new StringBuffer();<br> SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");<br> addSql.append("INSERT INTO"<br> + " t_shop"<br> + "(`inputId`, `storeId`, `storeType`, `initialsName`, `storeName`, `ipAddress`, `portEP`, `ipAddressEP`, `fixedTelephone`, `mobile`, `contactPerson`, `email`, `address`, `registrationNo`, `createDatetime`, `create_by`, `is_recharge_consumption`, `updateDatetime`, `update_by`, `sync_date`, `channel_key`, `chainName`, `state`, `commonCode`, `areaCode`, `registNumberEP`, `softName`, `busiNature`, `brand`, `floor`, `usageArea`, `computerNum`, `profit_rate`)");<br><br> addSql.append("values" + "(");<br> addSql.append("‘"+UUID.randomUUID().toString().replace("-", "") + "‘,");<br> //生成commoncode storeid<br> String newStoreId;<br> double a = (Math.random()+1)*1000;<br> int sotreId = Integer.parseInt(String.valueOf(a).substring(0,4));<br> newStoreId = "‘8" + String.valueOf(sotreId) + "‘";<br> addSql.append(newStoreId + ",");<br>// String empty = "".join("‘", Collections.nCopies(12,"‘,"));<br> String empty = "‘‘,";<br> addSql.append(empty);<br> addSql.append(empty);<br> addSql.append(newStoreId + ",");<br> addSql.append(empty);<br> addSql.append(empty);<br> addSql.append(empty);<br> addSql.append(empty);<br> addSql.append(empty);<br> addSql.append(empty);<br> addSql.append(empty);<br> addSql.append(empty);<br> addSql.append(empty);<br> Date date = new Date();<br> SimpleDateFormat sdf1 = new <br> SimpleDateFormat("yyyy-MM-dd HH:mm:ss");<br> String createTime = sdf1.format(date);<br> addSql.append("‘"+createTime + "‘,");<br> addSql.append("‘admin‘,");<br> addSql.append("‘1‘,");<br> addSql.append("‘"+createTime + "‘,");<br> addSql.append("‘admin‘,");<br> addSql.append(NULL + ",");<br> addSql.append("‘123456‘,");<br> addSql.append("‘XX‘,");<br> addSql.append("‘0‘,");<br> addSql.append(newStoreId + ",");<br> addSql.append(empty);<br> addSql.append("‘201805093512‘,");<br> addSql.append(empty);<br> addSql.append(empty);<br> addSql.append(empty);<br> addSql.append(empty);<br> addSql.append(NULL + ",");<br> addSql.append(NULL + ",");<br> addSql.append(NULL);<br> addSql.append(");");<br> String path = "D:\\sqlYpay.txt";<br> BufferedWriter out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(path,true)));<br> out.write(addSql+"\r\n");<br> System.out.println(addSql);<br> out.close();<br><br> }<br>// System.out.println(addSql);<br> // 结束时间<br> Long end = new Date().getTime();<br> log.info("end:{}",end);<br> log.info("耗时:{}",end-begin);<br> // 耗时<br> System.out.println("cast : " + (end - begin) / 1000 + " s");<br> return "生成SQL执行语句成功,一共生成了:>>>>>>" + size;<br> }
  •    启动主程序,调用接口

    技术图片

     

    ?SQL语句生成执行成功,查看文件夹生成文件。执行即可。

 

Springboot接口简单实现生成MySQL插入语句

标签:简单   查看   sel   created   tor   函数   spring   als   脚本   

人气教程排行