//定义 特性类:

public class MyAttribute : Attribute//自定义注解类判断是否是主键
{
public bool PrimaryKey = false;
public string Type = null;
}

//完成个实体类:

public class Student
{
private int _Id;
[My(PrimaryKey =true,Type ="自动增长")]
public int Id
{
get { return _Id; }
set { _Id = value; }
}
private string _name;
[My(PrimaryKey =false,Type ="名字")]
public string Name
{
get { return _name; }
set { _name = value; }
}
private int _Age;
[My(PrimaryKey = false, Type = "年龄")]
public int Age
{
get { return _Age; }
set { _Age = value; }
}
private string _Remark;
[My(PrimaryKey =false,Type ="优点")]
public string Remark
{
get { return _Remark; }
set { _Remark = value; }
}

public Student(int id,string name,int age,string remark)
{
this._Id = id;
this._name = name;
this._Age = age;
this._Remark = remark;
}

}

//--执行方法:

class Program
{
static void Main(string[] args)
{
Student stu = new Student(1, "张三", 21, "很多的");//实体类
// Insert(stu);//添加
// Update(stu);//修改
SInsert<Student>(stu);
Console.ReadKey();
}
public static void SInsert<T>(T obj) where T : class
{
string Filed = string.Empty;//字段值初始化
string Values = string.Empty;//属性值初始化

Type type = obj.GetType();
//获取类名
string TableName = type.Name;
//获取所有公有属性
PropertyInfo[] info = type.GetProperties();

foreach (PropertyInfo var in info)
{
//取得属性的特性标签,false表示不获取因为继承而得到的标签
object[] attr = var.GetCustomAttributes(false);
if (attr.Length > 0)
{
//从注解数组中取第一个注解(一个属性可以包含多个注解)
MyAttribute myattr = attr[0] as MyAttribute;
if (myattr.PrimaryKey == true)
{
continue;
}
}
Filed += var.Name + ",";
Values += "'" + var.GetValue(obj, null) + "',";
}
Filed = Filed.Substring(0, Filed.Length - 1);
Values = Values.Substring(0, Values.Length - 1);
string sql = "insert into {0}({1}) values({2})";
sql = string.Format(sql, TableName, Filed, Values);
Console.WriteLine(sql);
}
public static void Insert(object obj)
{
PropertyInfo[] moderarr = obj.GetType().GetProperties(BindingFlags.Public | BindingFlags.Instance);
string val = string.Empty;//预先定义返回值,全局变量为空
string filed = string.Empty;//预先定义属性值,全局变量为空
Type type = obj.GetType();
string className = type.Name;//根据 [Type] 属性完成对实体类对象的获取
foreach (PropertyInfo item in moderarr)
{
string PropertyValue = item.GetValue(obj, null).ToString();//预定义一个属性值接收所返回的属性值
Object[] attr = item.GetCustomAttributes(false);//返回自定义特性数组
if (attr.Length > 0)
{
MyAttribute myattr = attr[0] as MyAttribute;
if (myattr.PrimaryKey == true)//利用C#自定义特性 [MyAttrbute] 判断对象是否是主键
{
continue;
}
}
if (item.PropertyType.Name.StartsWith("Int32") || item.PropertyType.Name.StartsWith("Decimal"))//利用属性类型匹配对应元素信息
{
PropertyValue = item.GetValue(obj, null).ToString();//返回指定对象的属性值
val += PropertyValue + ",";
filed += item.Name + ",";
}
if (item.PropertyType.Name.StartsWith("String") || item.PropertyType.Name.StartsWith("Boolean") || item.PropertyType.Name.StartsWith("DateTime"))
{
PropertyValue = item.GetValue(obj, null).ToString();
val += "'" + PropertyValue + "',";
filed += item.Name + ",";
}
}
val = val.TrimEnd(',');//完成对返回值 Values( ? ) 的获取
filed = filed.TrimEnd(',');//完成对属性值insert 表名 ( ? ) 的获取
string sql = "insert into {0} ({1}) values({2})";
sql = string.Format(sql, className, filed, val);//具体的实现语句
Console.WriteLine(sql);
}

public static void Update(object obj)
{
PropertyInfo[] modelarr = obj.GetType().GetProperties(BindingFlags.Public | BindingFlags.Instance);
string val = string.Empty;
string val2 = string.Empty;
string PropertyName = string.Empty;
string PropertyValue = string.Empty;
Type type = obj.GetType();
string className = type.Name;//根据 [Type] 属性完成对实体类对象的获取
foreach (PropertyInfo item in modelarr)
{
PropertyValue = string.Empty;
PropertyName = item.Name;
if (PropertyName.ToLower().Contains("id"))
{
PropertyValue = item.GetValue(obj, null).ToString();
if (item.PropertyType.Name.StartsWith("Int32"))
{
val2 = PropertyName + " = " + PropertyValue;
}
else
{
val2 = PropertyName + " = '" + PropertyValue + "'";
}
continue;
}
if (item.PropertyType.Name.StartsWith("Int32") || item.PropertyType.Name.StartsWith("Decimal"))
{
PropertyValue = item.GetValue(obj, null).ToString();
val += PropertyName + " = " + PropertyValue + ",";
}
if (item.PropertyType.Name.StartsWith("String") || item.PropertyType.Name.StartsWith("Boolean") || item.PropertyType.Name.StartsWith("DateTime"))
{
PropertyValue = item.GetValue(obj, null).ToString();
val += PropertyName + " = '" + PropertyValue + "',";
}
}
val = val.TrimEnd(',');
string sql = "update {0} set {1} where {2}";
sql = string.Format(sql, className, val, val2);//具体的实现语句
Console.WriteLine(sql);

}

public static List<T> Drop<T>(string ProcName)where T :new()
{
//数据库连接字符串
List<T> list = new List<T>();
string strc = System.Configuration.ConfigurationManager.AppSettings["Conn"].ToString();
SqlConnection conn = new SqlConnection(strc);
if (conn.State!=ConnectionState.Open)
{
conn.Open();
}
SqlCommand cmd = new SqlCommand(ProcName, conn);
cmd.CommandType = CommandType.StoredProcedure;
SqlDataReader rearer = cmd.ExecuteReader(CommandBehavior.CloseConnection);
Type type = typeof(T);
T entity = new T();
while(rearer.Read())
{
foreach (var item in type.GetProperties())
{
item.SetValue(entity, rearer);
}
list.Add(entity);
}
return list;
}
}

____利用C#特性Attribute完成对sql语句的拼接的更多相关文章

  1. 【转】Hibernate利用@DynamicInsert和@DynamicUpdate生成动态SQL语句

    原文链接:http://www.cnblogs.com/quanyongan/p/3152290.html 最近在使用Hibernate4中,发现两个很有奥秘的注解 @DynamicInsert 和  ...

  2. Hibernate利用@DynamicInsert和@DynamicUpdate生成动态SQL语句

    最近在使用Hibernate4中,发现两个很有奥秘的注解 @DynamicInsert 和 @DynamicUpdate 如果是在配置文件的话那就是dynamic -insert 和 dynamic- ...

  3. 理想中的SQL语句条件拼接方式 (二)

    问题以及想要的效果,不重复叙述,如果需要的请先看 理想中的SQL语句条件拼接方式 . 效果 现在有2个类映射数据库的2张表,结构如下: public class User { public int U ...

  4. [转帖]关于Java中SQL语句的拼接规则

    关于Java中SQL语句的拼接规则 自学demo 的时候遇到的问题 结果应该是 '"+e.getName()+"' 注意 一共有三组标点符号 (除去 方法函数后面的括号) 实现目标 ...

  5. .net core 利用日志查看ef生成的SQL语句

    EF Core 没有直接提供像 EF6 那样方便的在日志中记录最终生成的 SQL 的功能,可以通过官方提供的日志记录(Microsoft.Extensions.Logging)实现. 一. 使用 Mi ...

  6. 利用excel办公软件快速拼凑sql语句

    日常工作中经常会收到excel整理好的部门或者人员等数据信息并需要批量更新或者插入到数据库中,常用的办法有导入.脚本拼凑执行等,今天我介绍直接使用excel快速拼凑sql语句的方法 1.update批 ...

  7. 理想中的SQL语句条件拼接方式

    背景 Orm用过一些,但处理增删改上面做的都不错.但是查询上跟我想要的效果总是差了一点.我想要的效果则是这样,基于某种命名规则进行传参,后台解析器知道命名规则即可知道它要查询什么样的数据. 谈谈我之前 ...

  8. Java数据库学习之SQL语句动态拼接

    public class UserDaoImpl implements UserDao { @Override public List<User> getUserByPage(PageIn ...

  9. 关于Java中SQL语句的拼接规则

    实现目标语句是这个注意,这里的java变量是idd int idd; String sql = "SELECT id, piUrl FROM picinfos WHERE id BETWEE ...

随机推荐

  1. 服务器windows2008系统登录报错:由于远程桌面服务当前正忙,因此无法完成您尝试的任务。请在...

    1.问题描述:windows server 2008服务器通过远程桌面登录时很慢,登录不进去,把远程桌面关掉后,再用远程桌面登录时,出现下图提示. 把服务器接上显示器键盘鼠标后,卡在系统登录的欢迎界面 ...

  2. CSU1333最短路问题SPFA

    fastvj.rainng.com/contest/236779#problem/I Description: n个点m条路每条路 l,r,t:表示这条路开l秒,关r秒,通过要t秒,问你车辆从s到t最 ...

  3. LeetCode刷题:第一题 两数之和

    从今天开始刷LeetCode 第一题:两数之和 题目描述: 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. 你可以假设每种 ...

  4. FFmpeg 学习(一):FFmpeg 简介

    一.FFmpeg 介绍 FFmpeg是一套可以用来记录.转换数字音频.视频,并能将其转化为流的开源计算机程序.采用LGPL或GPL许可证.它提供了录制.转换以及流化音视频的完整解决方案.它包含了非常先 ...

  5. LeetCode题解33.Search in Rotated Sorted Array

    33. Search in Rotated Sorted Array Suppose an array sorted in ascending order is rotated at some piv ...

  6. 使用git clone命令克隆github项目到本地时出错,提示没有权限的解决方法

    最近使用 git clone 命令在Github上克隆自己项目到本地时出错:提示没有权限,确认仓库是否存在,如下图红色框所示 问题:用过 git 的小伙伴都知道克隆项目的命令是—— git clone ...

  7. ubuntu默认的Python版本号修改

    ubuntu默认的Python是2.7版本的,键入Python3 就可以使用Python3.X版本.下面修改默认的Python版本, 1.删除/usr/bin 下的Python链接 sudo rm / ...

  8. Scala - 快速学习06 - 面向对象

    1- 类 1.1- 简介:类.方法及对象 类是用来创建对象的蓝图. Scala文件中包含的多个类之间,都是彼此可见的,不需要声明为public. 创建对象 定义好类以后,就可以使用new关键字来创建对 ...

  9. Python - 安装并配置Anaconda环境

    1- 简介 官网:https://www.anaconda.com/ Anaconda是一个用于科学计算的Python发行版,适用于数据分析的Python工具,也可以用在大数据和人工智能领域. 支持 ...

  10. spring boot -thymeleaf-异常处理

    异常流程 :controller-ControllerAdvice-异常解析器-默认的error页面 1.错误页面error.html: 程序出现异常会自动跳到error.html里,视频效果,该页面 ...