c#中的DataTable如何修改数据类型
DataTable中数据:IDNAMEState1A12B03C0State数据列为bit型,想把它改为char型,且原数据1变为“是”,0变为“否”。十分感谢China...
DataTable中数据:
ID NAME State
1 A 1
2 B 0
3 C 0
State数据列为bit型,想把它改为char型,且原数据1变为“是”,0变为“否”。
十分感谢ChinaGuoweixin的回答,不过因为刚接触没几天就被逼着搞这玩意,实在有些困难,这个datatable是返回的一个表,需要遍历实现state列的数据类型和数据值的修改,时间催得紧,不是非要做懒人,有请高人 展开
ID NAME State
1 A 1
2 B 0
3 C 0
State数据列为bit型,想把它改为char型,且原数据1变为“是”,0变为“否”。
十分感谢ChinaGuoweixin的回答,不过因为刚接触没几天就被逼着搞这玩意,实在有些困难,这个datatable是返回的一个表,需要遍历实现state列的数据类型和数据值的修改,时间催得紧,不是非要做懒人,有请高人 展开
展开全部
很简单。修改下值就可以。
我想LZ要学会自己思考。我想这个你都没有思考一看不会就发上来了。我给你写下如何生成DataTable的步骤。然后自己思考,修改下。
最简单的方式
DataTable dt=new DataTable("Table1"); //创建数据表
DataColumn dcID=new DataColumn("ID",typeof(int)); //创建ID列
DataColumn dcName=new DataColumn("Name",typeof(string));//创建姓名列
DataColumn dcState=new DataColumn("State",typeof(int));//创建状态列
//把创建的三列放在DataTable中
dt.Columns.Add(dcID); dt.Columns.Add(dcName);
dt.Columns.Add(dcState);
//创建数据行。
DataRow dr=dt.NewRow();
dr["ID"]=1; dr["Name"]=A; dr["State"]=1;
//把创建的行插入到数据表“Table1”中
dt.Rows.Add(dr);
//如上,这样就创建了一个如题所示的数据表的过程。
如果你想把bit型转换为char型。只需要候改下插入的列即可。
如将状态列改为:
DataColumn dcState=new DataColumn("State",typeof(char)); //此处将其改为Char类型。
//如上所示数据行
DataRow dr=dt.NewRow();
dr["ID"]=1; dr["Name"]=A; dr["State"]="是"; //把State列的值改为"是"或“否”即可。
打了半天,只希望楼主能从中体会如何自定义DataTable。
GoodLuck!!
我想LZ要学会自己思考。我想这个你都没有思考一看不会就发上来了。我给你写下如何生成DataTable的步骤。然后自己思考,修改下。
最简单的方式
DataTable dt=new DataTable("Table1"); //创建数据表
DataColumn dcID=new DataColumn("ID",typeof(int)); //创建ID列
DataColumn dcName=new DataColumn("Name",typeof(string));//创建姓名列
DataColumn dcState=new DataColumn("State",typeof(int));//创建状态列
//把创建的三列放在DataTable中
dt.Columns.Add(dcID); dt.Columns.Add(dcName);
dt.Columns.Add(dcState);
//创建数据行。
DataRow dr=dt.NewRow();
dr["ID"]=1; dr["Name"]=A; dr["State"]=1;
//把创建的行插入到数据表“Table1”中
dt.Rows.Add(dr);
//如上,这样就创建了一个如题所示的数据表的过程。
如果你想把bit型转换为char型。只需要候改下插入的列即可。
如将状态列改为:
DataColumn dcState=new DataColumn("State",typeof(char)); //此处将其改为Char类型。
//如上所示数据行
DataRow dr=dt.NewRow();
dr["ID"]=1; dr["Name"]=A; dr["State"]="是"; //把State列的值改为"是"或“否”即可。
打了半天,只希望楼主能从中体会如何自定义DataTable。
GoodLuck!!
展开全部
Select ID,Name,State,StateValue
case when state=1 then '是'
end as '否' from TableName
如果你要改State的值,就要改State这一列的 DataType.
方法如下:(我没测试,你试试行不行吧)
DataTable dt=new DataTable();
dt.Columns[2].DataType=Type.GetType("System.Char");
foreach (DataRow dr in dt.Rows)
{
dr[2] = (int)dr[2] == 1 ? '是' : '否';
}
case when state=1 then '是'
end as '否' from TableName
如果你要改State的值,就要改State这一列的 DataType.
方法如下:(我没测试,你试试行不行吧)
DataTable dt=new DataTable();
dt.Columns[2].DataType=Type.GetType("System.Char");
foreach (DataRow dr in dt.Rows)
{
dr[2] = (int)dr[2] == 1 ? '是' : '否';
}
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
DataTable dt=new DataTable("Table1"); //创建数据表
DataColumn dcID=new DataColumn("ID",typeof(int)); //创建ID列
DataColumn dcName=new DataColumn("Name",typeof(string));//创建姓名列
DataColumn dcState=new DataColumn("State",typeof(int));//创建状态列
//把创建的三列放在DataTable中
dt.Columns.Add(dcID); dt.Columns.Add(dcName);
dt.Columns.Add(dcState);
//创建数据行。
DataRow dr=dt.NewRow();
dr["ID"]=1; dr["Name"]=A; dr["State"]=1;
//把创建的行插入到数据表“Table1”中
dt.Rows.Add(dr);
//如上,这样就创建了一个如题所示的数据表的过程。
如果你想把bit型转换为char型。只需要候改下插入的列即可。
如将状态列改为:
DataColumn dcState=new DataColumn("State",typeof(char)); //此处将其改为Char类型。
//如上所示数据行
DataRow dr=dt.NewRow();
dr["ID"]=1; dr["Name"]=A; dr["State"]="是"; //把State列的值改为"是"或“否”即可。
打了半天,只希望楼主能从中体会如何自定义DataTable。
GoodLuck!!
DataColumn dcID=new DataColumn("ID",typeof(int)); //创建ID列
DataColumn dcName=new DataColumn("Name",typeof(string));//创建姓名列
DataColumn dcState=new DataColumn("State",typeof(int));//创建状态列
//把创建的三列放在DataTable中
dt.Columns.Add(dcID); dt.Columns.Add(dcName);
dt.Columns.Add(dcState);
//创建数据行。
DataRow dr=dt.NewRow();
dr["ID"]=1; dr["Name"]=A; dr["State"]=1;
//把创建的行插入到数据表“Table1”中
dt.Rows.Add(dr);
//如上,这样就创建了一个如题所示的数据表的过程。
如果你想把bit型转换为char型。只需要候改下插入的列即可。
如将状态列改为:
DataColumn dcState=new DataColumn("State",typeof(char)); //此处将其改为Char类型。
//如上所示数据行
DataRow dr=dt.NewRow();
dr["ID"]=1; dr["Name"]=A; dr["State"]="是"; //把State列的值改为"是"或“否”即可。
打了半天,只希望楼主能从中体会如何自定义DataTable。
GoodLuck!!
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询