____利用C#特性Attribute完成对sql语句的拼接
//定义 特性类:
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语句的拼接的更多相关文章
- 【转】Hibernate利用@DynamicInsert和@DynamicUpdate生成动态SQL语句
原文链接:http://www.cnblogs.com/quanyongan/p/3152290.html 最近在使用Hibernate4中,发现两个很有奥秘的注解 @DynamicInsert 和 ...
- Hibernate利用@DynamicInsert和@DynamicUpdate生成动态SQL语句
最近在使用Hibernate4中,发现两个很有奥秘的注解 @DynamicInsert 和 @DynamicUpdate 如果是在配置文件的话那就是dynamic -insert 和 dynamic- ...
- 理想中的SQL语句条件拼接方式 (二)
问题以及想要的效果,不重复叙述,如果需要的请先看 理想中的SQL语句条件拼接方式 . 效果 现在有2个类映射数据库的2张表,结构如下: public class User { public int U ...
- [转帖]关于Java中SQL语句的拼接规则
关于Java中SQL语句的拼接规则 自学demo 的时候遇到的问题 结果应该是 '"+e.getName()+"' 注意 一共有三组标点符号 (除去 方法函数后面的括号) 实现目标 ...
- .net core 利用日志查看ef生成的SQL语句
EF Core 没有直接提供像 EF6 那样方便的在日志中记录最终生成的 SQL 的功能,可以通过官方提供的日志记录(Microsoft.Extensions.Logging)实现. 一. 使用 Mi ...
- 利用excel办公软件快速拼凑sql语句
日常工作中经常会收到excel整理好的部门或者人员等数据信息并需要批量更新或者插入到数据库中,常用的办法有导入.脚本拼凑执行等,今天我介绍直接使用excel快速拼凑sql语句的方法 1.update批 ...
- 理想中的SQL语句条件拼接方式
背景 Orm用过一些,但处理增删改上面做的都不错.但是查询上跟我想要的效果总是差了一点.我想要的效果则是这样,基于某种命名规则进行传参,后台解析器知道命名规则即可知道它要查询什么样的数据. 谈谈我之前 ...
- Java数据库学习之SQL语句动态拼接
public class UserDaoImpl implements UserDao { @Override public List<User> getUserByPage(PageIn ...
- 关于Java中SQL语句的拼接规则
实现目标语句是这个注意,这里的java变量是idd int idd; String sql = "SELECT id, piUrl FROM picinfos WHERE id BETWEE ...
随机推荐
- lambada
一.动态创建 ParameterExpression parameter = Expression.Parameter(typeof(User), "u"); //创建委托 Mem ...
- Linux的50个基本命令
1.ls -a 列出当前目录下的所有文件,包括以.头的隐含文件(如-/.bashrc) ls –l 列出当前目录下文件的详细信息 2. pwd 查看当前所在目录的绝对路经 3. cd 目录之间的移动 ...
- 在ASP.NET MVC里对Web Page网页进行权限控制
我们在ASP.NET MVC开发时,有时候还是得设计ASP.NET的Web Page网页(.aspx和.aspx.cs),来实现一些ASP.NET MVC无法实现的功能,如此篇<Visual S ...
- 两种经典电商CSS布局
圣杯布局和双飞翼布局! 两种布局功能相同,都是为了实现两端宽度固定,中间宽度自适应的三栏布局 圣杯布局: 三个区域都处于左浮动状态,并使main的宽度成父容器的100% 为两侧侧边栏添加负margin ...
- python模块的导入的两种方式区别详解
Python 有两种导入模块的方法.两种都有用,你应该知道什么时候使用哪一种方法.一种方法,import module,另一种是from module import,下面是 from module i ...
- Java面试题总结(附答案)
1.什么是B/S架构?C/S架构? B/S(Browser/Server),浏览器/服务器程序: C/S(Client/Server),客户端/服务端,桌面应用程序. 2.网络协议有哪些? HTTP: ...
- Android加密解析
编码.数字摘要.加密.解密 UrlEncoder /Urldecoder String str = "http://www.baidu.com?serach = 哈哈"; Stri ...
- 移动端适配方案-rem(基础篇)
常见移动web适配方案一般有3种方法,如下图: ①:定高,宽度百分比(一般用来做一些适配性不高的页面,比如主要以一些文字和图片为主的网页或移动端的头部和底部) ②:flex (更多的用于复杂页面的布局 ...
- 项目笔记:2018年4月(SpringCloud架构和SpringBoot框架)
一.启动Euerka服务 1.在启动类里用@propertySource引入全局配置文件noteapp-service.properties: 如上图.左侧为某服务配置文件properties,右侧为 ...
- 常见的anaconda的操作
以前对anaconda的理解比较少,以为它就是一个比较大的python库,现在发现它原来不止是这样,它还有很多其他用途. Anaconda指的是一个开源的Python发行版本,其包含了conda.Py ...