SQL 参数动态绑定 模板不定长参数展开

#参数占位绑定
std::string strInsert = "insert into track_history_table values(?,?,?,?,?,?)";
std::string strSql = ParamBind::BindParams(strInsert , v1,v2,v3,v4,v5,v6)
#pragma once
#ifndef __C_PARAM_BIND_H__
#define __C_PARAM_BIND_H__
#include <iostream>
#include <string>
using namespace std;
namespace ParamBind
{
    //************************************
// Method:    ReplaceSlot 绑定字符串参数到sql中
// FullName:  CMySql::ReplaceSlot
// Access:    public
// Returns:   :type
// Qualifier:
// Parameter: std::string & strStateMent
// Parameter: T t
//************************************
    template <typename T>
    typename std::enable_if<std::is_same<char*, T>::value || std::is_same<const char*, T>::value>::type
        ReplaceSlot(std::string& strStateMent, T t)
    {
        int nPos = strStateMent.find_first_of('?');
        strStateMent.replace(nPos, 1, "'" + std::string(t) + "'");
    }

    //************************************
    // Method:    ReplaceSlot 绑定数值参数到sql中
    // FullName:  CMySql::ReplaceSlot
    // Access:    public
    // Returns:   :type
    // Qualifier:
    // Parameter: std::string & strStateMent
    // Parameter: T t
    //************************************
    template <typename T>
    typename  std::enable_if<std::is_integral<T>::value>::type ReplaceSlot(std::string& strStateMent, T t)
    {
        int nPos = strStateMent.find_first_of('?');
        std::string strValue = std::to_string(t);
        strStateMent.replace(nPos, 1, strValue);
    }

    //************************************
    // Method:    BindParams 参数递归展开终止
    // FullName:  CMySql::BindParams
    // Access:    public
    // Returns:   int
    // Qualifier:
    // Parameter: std::string & strStateMent
    //************************************
    inline int BindParams(std::string& strStateMent)
    {
        return 0;
    }

    //************************************
    // Method:    BindParams  递归展开不定长参数,同时进行值绑定
    // FullName:  CMySql::BindParams
    // Access:    public
    // Returns:   int
    // Qualifier:
    // Parameter: std::string & strStateMent
    // Parameter: T & & first
    // Parameter: Args & & ... args
    //************************************
    template <typename T, typename... Args>
    inline std::string BindParams(std::string& strStateMent, T&&  first, Args&&... args)
    {
        //参数展开时替换占位符
        ReplaceSlot(strStateMent, first);
        BindParams(strStateMent, std::forward<Args>(args)...);
        std::string res = strStateMent;
        return res;
    }
}
#endif

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值