2021-05-21 仓库温控系统(Winform) 07 动态生成sql语句CreateSql

//生成sql语句的通用类
public class CreateSql
{
   
        /// <summary>
        /// 生成Insert语句
        /// </summary>
        /// <typeparam name="T"></typeparam>
        /// <param name="t"></param>
        /// <param name="cols">要插入的必要列</param>
        /// <returns></returns>
        public static SqlModel GetInsertSqlAndParas<T>(T t, string cols, int isReturn)
        {
   
                Type type = typeof(T);
                PropertyInfo[] properties = PropertyHelper.GetTypeProperties<T>(cols);
                string priName = type.GetPrimary();//获取主键名   标识列(不需要显式插入)
                                                   //生成要插入的列 {1}  insert into table (Id,Name,Age....) values (@Id,@Name,@Age)
                string columns = string.Join(",", properties.Where(p => p.Name != priName).Select(p => $"[{p.GetColName()}]"));
                //生成插入的参数{2}
                string paraColumns = string.Join(",", properties.Where(p => p.Name != priName).Select(p => $"@{p.GetColName()}"));
                //参数数组的生成
                SqlParameter[] arrParas = CreateParameters<T>(properties, t);
                //sql语句
                string sql = $"INSERT INTO [{type.GetTName()}] ({columns}) VALUES ({paraColumns}) ";
                if (isReturn == 1)
                        sql += ";select @@identity";
                return new SqlModel
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值