代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
CSharp
】
根据对象生存新增和更新SQL
作者:
静
/ 发布于
2015/4/14
/
799
public static int getInsert(SqlConnection conn, SqlTransaction trans, object obj, string tablename) { if (obj == null) throw new Exception("数据不能为空!"); Type type = obj.GetType(); PropertyInfo[] pinfo = type.GetProperties(); List<SqlParameter> parames = new List<SqlParameter>(); StringBuilder keys = new StringBuilder(); StringBuilder values = new StringBuilder(); foreach (PropertyInfo item in pinfo) { if (item.GetValue(obj, null)!=null) { if (keys.Length > 0) { keys.Append(","); values.Append(","); } keys.Append(" " + item.Name.ToUpper()); values.Append(" @" + item.Name.ToUpper()); // if (item.PropertyType == typeof(System.Nullable<System.DateTime>)) { parames.Add(new SqlParameter("@" + item.Name.ToUpper(), item.GetValue(obj, null))); // } else { // parames.Add(new SqlParameter("@" + item.Name.ToUpper(), item.GetValue(obj, null))); // } } } string sql = "INSERT INTO " + tablename + "(" + keys.ToString() + " ) VALUES ( "+values.ToString()+")"; return SqlHelper.ExecuteNonQuery(conn, trans, CommandType.Text, sql, parames.ToArray()); } public static int getUpdate(SqlConnection conn,SqlTransaction trans,object obj, string tablename, string pkey) { if (obj == null) throw new Exception("数据不能为空!"); Type type = obj.GetType(); PropertyInfo[] pinfo = type.GetProperties(); List<SqlParameter> parames = new List<SqlParameter>(); StringBuilder keys = new StringBuilder(); object pkeyvalue = null; pkey = pkey.ToUpper(); foreach (PropertyInfo item in pinfo) { if (item.Name.ToUpper() == pkey) { pkeyvalue = item.GetValue(obj, null); } else { if (keys.Length > 0) { keys.Append(","); } keys.Append(" " + item.Name.ToUpper() + "=@" + item.Name.ToUpper()); if (item.GetValue(obj, null) == null) { parames.Add(new SqlParameter("@" + item.Name.ToUpper(), DBNull.Value)); } else { parames.Add(new SqlParameter("@" + item.Name.ToUpper(), item.GetValue(obj, null))); } } } parames.Add(new SqlParameter("@" + pkey, pkeyvalue)); string sql = "UPDATE " + tablename + " SET " + keys.ToString() + " WHERE " + pkey + "=@" + pkey + ""; return SqlHelper.ExecuteNonQuery(conn, trans, CommandType.Text, sql, parames.ToArray()); }
试试其它关键字
同语言下
.
文件IO 操作类库
.
Check图片类型[JPEG(.jpg 、.jpeg),TIF,GIF,BMP,PNG,P
.
机器名和IP取得(IPV4 IPV6)
.
Tiff转换Bitmap
.
linqHelper
.
MadieHelper.cs
.
RegHelper.cs
.
如果关闭一个窗体后激活另一个窗体的事件或方法
.
创建日志通用类
.
串口辅助开发类
可能有用的
.
文件IO 操作类库
.
Check图片类型[JPEG(.jpg 、.jpeg),TIF,GIF,BMP,PNG,P
.
机器名和IP取得(IPV4 IPV6)
.
Tiff转换Bitmap
.
linqHelper
.
MadieHelper.cs
.
RegHelper.cs
.
如果关闭一个窗体后激活另一个窗体的事件或方法
.
创建日志通用类
.
串口辅助开发类
静
贡献的其它代码
(
1
)
.
根据对象生存新增和更新SQL
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3