C#反射获取数据库字段
static string sqlselect = "insert into {0}({1}) values ({2})";
(这个方法可以适用于任何数据库的插入语句)
public static int managerRegister<T>(T field) {
string fieldName = "";
string fieldList = "";
string fieldValue = "";
int k = ;
Type tf = typeof(T);
fieldName = tf.Name;//获取类型名称
PropertyInfo[] pinfo = tf.GetProperties();//获取属性
string[] paraList = new string[pinfo.Length];//参数化查询字段的数组
List<SqlParameter> para = new List<SqlParameter>();//用于放置参数化查询
foreach (PropertyInfo p in pinfo)
{
fieldList += p.Name + ",";
fieldValue += "'" + p.GetValue(field).ToString() + "'" + ",";
paraList[k] = p.Name;
para.Add(new SqlParameter("@" + paraList[k], fieldValue));
k = k + ;//当循环执行时k加一使得数组能够连续获取到字段
}
fieldList = fieldList.Substring(, fieldList.Length - );//去除最后一个逗号
fieldValue = fieldValue.Substring(, fieldValue.Length - );
sqlselect = string.Format(sqlselect, fieldName, fieldList, fieldValue);
int value = DBhelper.ExcuteQuery(sqlselect, para.ToArray());//调用自己写的一个数据库插入语句并返回一个值
return value;//返回插入语句的情况
}
以下是我的数据库字段

下面是我的插入语句
public static int ExcuteQuery(string sql, SqlParameter[] para) {
int value;
SqlCommand cmd = SqlCmd(sql);
cmd.Parameters.AddRange(para);
try
{
value = cmd.ExecuteNonQuery();
return value;
}
catch
{
return -;
}
}
下面是调用界面
protected void Btn_Save_Click(object sender, EventArgs e)
{
Bc_Login a = new Bc_Login() { username = txt_Username.Text, pwd = txt_Repassword.Text };
if (txt_Password.Text != "" && txt_Username.Text != "" && txt_Repassword.Text != "")
{
int value = ManagerRegister.managerRegister<Bc_Login>(a);
if (value > )
{
Response.Write("<script>alert(\"注册成功!\")</script>");
Response.Redirect("index.aspx");
}
else
{
Response.Write("<script>alert(\"注册失败!请检查用户名或密码后重试!\")</script>");
}
}
else {
Response.Write("<script>alert(\"请检查用户名或密码!\")</script>");
}
}
插入页面的效果

反射获得字段,其实是浪费资源性能的做法,但是有些时候为了少写代码,还是会用到反射,这只是个最基础的例子,
别看界面做的好看,但是内部还是挺乱的,最后补充反射的原理
在运行状态中,对于任意一个类,都能够获取到这个类的所有属性和方法,对于任意一个对象,都能够调用它的任意一个方法和属性(包括私有的方法和属性),这种动态获取的信息以及动态调用对象的方法的功能就称为反射机制。通俗点讲,通过反射,类对我们来说是完全透明的,想要获取任何东西都可以。
对于反射说明我随机挑选了一个不错的例子供大家参考:https://www.cnblogs.com/sxw117886/p/5687590.html
原作者:幻影星辰
反射我前面有一个图片,一个C#程序运行时是先经过编译器编译后经过IL编译之后到JIT/CLR最后再到二进制能被机器所认识的代码
其实反射是从内存中反向获得assembly!
其余的以后再补充。
C#反射获取数据库字段的更多相关文章
- MSSQL 获取数据库字段类型
SELECT col.name AS 列名, typ.name as 数据类型, col.max_length AS 占用字节数, col.precision AS 数字长度, col.scale A ...
- java通过反射获取bean字段注解@Column中的信息
直接上代码吧: Field field; Field[] fields=clas.getDeclaredFields(); for (int i = 0; i <fields.length ; ...
- mysql数据库连接池使用(三)数据库元数据信息反射数据库获取数据库信息
1.1. mysql数据库连接池使用(三)数据库元数据信息反射数据库获取数据库信息 有时候我们想要获取到数据库的基本信息,当前程序连接的那个数据库,数据库的版本信息,数据库中有哪些表,表中都有什么字段 ...
- Java反射机制(获取Class对象的三种方式+获取Class中的构造函数进行对象的初始化+获取反射类的字段+获取反射类的一般方法)
反射技术其实就是动态加载一个指定的类,并获取该类中的所有内容.而且将字节码文件封装成对象,并将字节码文件中的内容都封装成对象,这样便于操作这些成员,简单来说:反射技术可以对一个类进行解剖,反射大大增强 ...
- Java-Reflection反射-获取包括父类在内的所有字段
前言 今天Android移动端要加个新功能,所以回归Android程序员的身份.开发的过程中,发现了之前的代码写的有很多问题,真的应该把时间抽出来重构一下了. 其中有反射的一个坑,工具类某方法反射获取 ...
- 浏览器中上传Excel文件,服务器获取Excel字段。写入的数据库中。操作Excel的方式jxl和poi。
从Excel中获取字段,官方给我们提供了方法,地址https://poi.apache.org/components/spreadsheet/quick-guide.html#CellContents ...
- go语言通过反射获取和设置结构体字段值的方法
本文实例讲述了go语言通过反射获取和设置结构体字段值的方法.分享给大家供大家参考.具体实现方法如下: type MyStruct struct { N int } n := MyStruct{ 1 } ...
- sql获取数据库的所有表以及名称字段
获取数据库中所有的表 SELECT SysObjects.name AS Tablename FROM sysobjects WHERE xtype = 'U' 获取数据库中所有表的列名 SELECT ...
- C#通过反射获取对象属性,打印所有字段属性的值
获取所有字段的值: public void PrintProperties(Object obj) { Type type = obj.GetType(); foreach( PropertyInfo ...
随机推荐
- 【SWUST626】分数分解
Position: * http://acm.swust.edu.cn/problem/0626/ * List SWUST626 分数分解 List Description Input Output ...
- [BZOJ 3132] 上帝造题的七分钟
[题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=3132 [算法] 二维树状数组 [代码] #include<bits/stdc+ ...
- js获取后台数据
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>& ...
- Django day29 视图,路由控制,响应器
一:视图 1.视图的几种方式: (1) 第一种 from rest_framework.mixins import ListModelMixin, CreateModelMixin class Pub ...
- 什么是JavaScript的转义字符?譬如\n有什么作用?
在JavaScript字符串中,反斜线(\)有着特殊的用途,反斜线后加一个字符,就不再表示它们的字面义了,比如\n就是一个转义字符(escape sequence),它表示的是一个换行符.在表格3-1 ...
- VUE修改每个页面title
//index.js routes: [ { name:'home', path: '/home/:openname', component: Home, meta: { title: '首页' } ...
- HyperLedger Fabric部署与链码解读
1.Fabric简介 Fabric是超级账本中的一个项目,用以推进区块链技术.和其他区块链类似,它也有一个账本,使用智能合约,且是一个参与者可以分别管理自身交易的系统.它是一个联盟链.Fabric与其 ...
- RabbitMQ~消费者实时与消息服务器保持通话
这个文章主要介绍简单的消费者的实现,rabbitMQ实现的消费者可以对消息服务器进行实时监听,当有消息(生产者把消息推到服务器上之后),消费者可以自动去消费它,这通常是开启一个进程去维护这个对话,它与 ...
- Js打开QQ聊天对话窗口
function openQQ() { var qq = $(this).attr('data-qq');//获取qq号 window.open('http://wpa.qq.com/msgrd?v= ...
- iOS动画——DynamicAnimate
力学动画 以dynamicAnimate为首的力学动画是苹果在iOS7加入的API,里面包含了很多力学行为,这套API是基于Box2d实现的.其中包含了重力.碰撞.推.甩.和自定义行为. 涉及到的类如 ...