真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

JavaSpring動(dòng)態(tài)生成Mysql存儲(chǔ)過(guò)程的詳細(xì)解析

這篇文章主要講解了Java Spring動(dòng)態(tài)生成MySQL存儲(chǔ)過(guò)程的詳細(xì)解析,內(nèi)容清晰明了,對(duì)此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會(huì)有幫助。

網(wǎng)站的建設(shè)創(chuàng)新互聯(lián)建站專注網(wǎng)站定制,經(jīng)驗(yàn)豐富,不做模板,主營(yíng)網(wǎng)站定制開(kāi)發(fā).小程序定制開(kāi)發(fā),H5頁(yè)面制作!給你煥然一新的設(shè)計(jì)體驗(yàn)!已為建筑動(dòng)畫(huà)等企業(yè)提供專業(yè)服務(wù)。

一、 背景

由于公司業(yè)務(wù)需要?jiǎng)討B(tài)配置一些存儲(chǔ)過(guò)程來(lái)生成數(shù)據(jù),之前嘗試過(guò)使用jpa來(lái)完成,或多或少都存在一些問(wèn)題,最后使用了spring的Jdbctemplate。

二、 環(huán)境

1.此隨筆內(nèi)容基于spring boot項(xiàng)目

2.數(shù)據(jù)庫(kù)為mysql 5.7.9版本

3.jdk 版本為1.8

三、 說(shuō)明

說(shuō)明:為方便表示,下列存儲(chǔ)過(guò)程在代碼中的表示我稱之為接口配置

四、 內(nèi)容

1、定義接口和接口參數(shù)bean;

1)接口配置bean:

@Entity
@Table(name="qt_interface")
public class QtInterface {
 @Id
 private String id;
 private String name;
 private String content;
 private String info;
 private String status;
//此處省略get、set…
}

2)接口配置參數(shù)bean:

@Entity
@Table(name="qt_interface_parameter")
public class QtInterfaceParameter {
 @Id
 private String id;
 @Column(name="inter_id")
 private String interId;
 private String name; //參數(shù)名稱
 private String explain_info; //參數(shù)描述
 private String type;// 輸入輸出類型
 private String paraType; // 參數(shù)類型
 private Integer paraLen;
//此處省略get、set…
}

2、編寫(xiě)頁(yè)面輸入接口配置的信息;

1)Html部分代碼:

2)Js部分代碼太長(zhǎng),就只貼一個(gè)提交方法吧

function createProduce(inter_id) {
 var postData = {
    id: $("#inter_id").val(),
    item_id: $("#item_id").val(),
    name: $("#name").val(),
    content: $("#content").val(),
    explain_info: $("#explain_info").val(),
    jsonData: JSON.stringify(jsonData)// 參數(shù)明細(xì)信息,字段就是接口配置參數(shù)bean 中的字段信息
};
 
  $.ajax({
    url: Url + 'test/createPro',
    type: 'get', //GET
    async: false,  //或false,是否異步
    data: JSON.stringify(postData),
    timeout: 5000,  //超時(shí)時(shí)間
    dataType: 'json',  //返回的數(shù)據(jù)格式:    success:   function (result, textStatus, jqXHR) {
      if (result.result == "1") { // 編輯賦值
        layer.alert("創(chuàng)建成功", {icon: 0});
      } else {
        layer.alert("創(chuàng)建失敗,請(qǐng)檢查sql語(yǔ)句,注意結(jié)尾不能有分號(hào)!具體錯(cuò)誤信息:"+result.msg, {icon: 5});
      }
    },
    error: function (xhr, textStatus) {
      layer.alert(textStatus);
    }
  });
}

3、將數(shù)據(jù)上傳到后臺(tái)之后,后臺(tái)生成存儲(chǔ)過(guò)程。當(dāng)然一般情況下,我們還是先把數(shù)據(jù)接口和接口明細(xì)數(shù)據(jù)持久化保存,再來(lái)執(zhí)行創(chuàng)建操作,可以保證數(shù)據(jù)不會(huì)丟失。此處由于篇幅問(wèn)題,我就省略了中間這一步。

1)創(chuàng)建一個(gè)service 的接口:

public interface TestService {
    ResultInfo createPro(Map map);
}

2)然后創(chuàng)建接口的實(shí)現(xiàn)類:

@Service
public class TestServiceImpl implements TestService {
 
/**
 * 創(chuàng)建存儲(chǔ)過(guò)程
 *
 * @param map 接口配置和接口參數(shù)信息
 * 參數(shù)詳解: type 輸入輸出參數(shù),取值為 in,out
 *       paraType 參數(shù)類型。取值為:1:int 2:double 3:varchar 4:datetime
 * @return
 */
@Override
@Transactional
public void createPro(Map map) {
  ResultInfo resultInfo = new ResultInfo();
  QtInterface qtInterface=new QtInterface();
  qtInterface =buildInterface(map, qtInterface);// 加載接口配置信息
  List paraList = new ArrayList();
  paraList = buildParam(map.get("jsonData"));// 加載接口配置信息
  StringBuffer bf = new StringBuffer(); // 建立生成過(guò)程的語(yǔ)句
  bf.append("create procedure \t");
  bf.append(qtInterface.getName());
  bf.append("\n");
  bf.append("(");
  String para_type = "";
  int i = 1;
  for (QtInterfaceParameter qt : paraList) {
    switch (qt.getParaType()) { // 參數(shù)類型
      case "1":
        para_type = "int";
        break;
      case "2":
        para_type = "double";
        break;
      case "3":
        para_type = "varchar(" + qt.getParaLen() + ")";
        break;
      case "4":
        para_type = "datetime";
        break;
      default:
        para_type = "varchar(255)";
        break;
    }
    if (i == paraList.size()) {
      bf.append("" + qt.getType() + " " + qt.getName() + " " + para_type + ") ");
    } else {
      bf.append("" + qt.getType() + " " + qt.getName() + " " + para_type + ", ");
    }
 
    i++;
  }
  bf.append(" COMMENT '"+ qtMonitorWarnInterface.getInfo() +"'\n"); // 添加描述信息
  bf.append("BEGIN\n");
  bf.append(qtInterface.getContent()); // 存儲(chǔ)過(guò)程內(nèi)容
  bf.append(";\nEND;");
  // 先執(zhí)行刪除操作
  jdbcTemplate.execute("drop procedure if exists " + qtInterface.getName() + " ;");
  jdbcTemplate.execute(bf.toString());
 
}
 
/**
 * 初始化接口配置信息
 *
 */
private QtInterface buildInterface(Map map, QtInterface qtInterface) {
  // 接口配置名稱
  if (map.get("name") != null && !"".equals(map.get("name "))) {
    qtInterface.setName((String) map.get("name "));
  }
  //此處省略其他項(xiàng),其他項(xiàng)的取值方法跟上面的一樣 …
  return qtInterface;
}
 
/**
 * 初始化接口配置參數(shù)明細(xì)
 *
 */
  private List buildParam(String postData) {
    List list = new ArrayList();
    if(postData!=null &&!"".equals(postData)){
      List> listParam = (List>) JsonMapper.fromJsonString(postData, ArrayList.class);
      for (Map map : listParam) {
        QtInterfaceParameter para = new QtInterfaceParameter();
        // 接口配置參數(shù)名稱
        if (map.get("name") != null && !"".equals(map.get("name "))) {
          para.setName((String) map.get("name "));
        }
        // 此處省略其他項(xiàng),其他項(xiàng)的取值方法跟上面的一樣 …
        list.add(para);
      }
    }
    return list;
  }

3) 添加控制器進(jìn)行調(diào)用:

@Controller
@RequestMapping(value = "/test")
public class TestController {
@Autowired
private TestService testService;
 
@RequestMapping(value = "/createPro", method = RequestMethod.GET)
public ResultInfo createPro(@RequestBody Map map
) {
  ResultInfo resultInfo = new ResultInfo();
  try {
    testService.createPro(Id);
  resultInfo.setResult(1);
    resultInfo.setMsg("創(chuàng)建過(guò)程成功");
 
  } catch (Exception e) {
    resultInfo.setResult(-1);
    resultInfo.setMsg(e.getMessage());
  }
  return resultInfo;
 }
}

4)最后動(dòng)態(tài)生成的SQL就是這個(gè)樣子:

CREATE PROCEDURE `testbase`.`test`(in a_user_id varchar(100))
  COMMENT '測(cè)試接口'
BEGIN
select * from userInfo where user_id=a_user_id;
END

看完上述內(nèi)容,是不是對(duì)Java Spring動(dòng)態(tài)生成Mysql存儲(chǔ)過(guò)程的詳細(xì)解析有進(jìn)一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


文章標(biāo)題:JavaSpring動(dòng)態(tài)生成Mysql存儲(chǔ)過(guò)程的詳細(xì)解析
轉(zhuǎn)載來(lái)于:http://weahome.cn/article/jpgdoj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部