我有一个已经获取完数据的DataTable,我想设定某一列数据的小数点位数 有什么好办法吗? 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 这涉及到更改表的结构,需要使用Alter Table命令。如果你是利用ADO.NET实现,可以构造一条关于alter table的sql语句字符串,然后构造一个Command对象,执行之ExecuteNonQuery()。 手动绑定,或者修改table的数据源 我建意最好的办法是:查询的时候,在数据库中操作,用函数处理效率较高。如果你把查询的数据存入到DataTable,然后把数据库读出来然后又存入,过程就慢了许多。因此,你还是在数据库就做处理吧。 问题不清,你是要修改内存表中的某个Column的实际数据的小数点还是页面呈现中的小数点,又或者数据库中物理表的小数点? 那你就在绑定事件中处理一下即可。后台增加一个方法:public void Page_Load(object sender,EventArgs e){ if(!IsPostBack) { //你不是获取到了DataTable值了嘛 rpt.DataSource = dt; rpt.DataBind(); }}//对从数据库取出的值进行//d_value是数值,point是精确位数public string GetNumber(string d_value,int point){ double ret = double.Parse(d_value.Trim()); return Math.Round(ret , point, MidpointRounding.AwayFromZero).ToString(); }然后前台绑定的时候调用下即可:<asp:Repeater ID="rpt" runat="server"> <ItemTemplate> <asp:Label ID="Label1" runat="server" Text='<%#GetNumber(Eval("字段名称").ToString(),2)%>'> </asp:Label> </ItemTemplate></asp:Repeater> 这样你试试吧,每个字段用SQL的 ROUND函数直接做截断处理吧 例如 ROUND(12.345,2)就是截取两位 [WinForm]在vs2010 使用 IrisSkin2.dll 的问题 想问下怎么用C#按照需求自动生成PPT winfrom 判断textbox C#数组拷贝效率问题 word页复制时出错,系统win2003 Excel套用模版打印问题 .net类库的源码是不是公开的? System.Data.OracleClient 需要 Oracle 客户端软件 8.1.7 或更高版本 讨论.用C#里面,操纵WORD 高分求HELP !我的一个报表里的字段值如何写进去!!!! 急着做软件向单位交差!!!谢谢谢谢!! 何种数据文件效率高? 跪求各位大哥给我一个三级联动的案列!!【十万火急】
后台增加一个方法:public void Page_Load(object sender,EventArgs e)
{
if(!IsPostBack)
{
//你不是获取到了DataTable值了嘛
rpt.DataSource = dt;
rpt.DataBind();
}
}//对从数据库取出的值进行
//d_value是数值,point是精确位数
public string GetNumber(string d_value,int point)
{
double ret = double.Parse(d_value.Trim());
return Math.Round(ret , point, MidpointRounding.AwayFromZero).ToString();
}然后前台绑定的时候调用下即可:<asp:Repeater ID="rpt" runat="server">
<ItemTemplate>
<asp:Label ID="Label1" runat="server" Text='<%#GetNumber(Eval("字段名称").ToString(),2)%>'> </asp:Label>
</ItemTemplate>
</asp:Repeater>