页面上太多内容要写入数据库了,大概80个字段,页面上80个收集数据的TextBox1~80。怎么样才能快速写入、读出数据库呢?

OOOqqqOOO 2010-04-03 11:15:57
页面上太多内容要写入数据库了,大概80个字段,页面上80个收集数据的TextBox1~80。怎么样才能快速写入、读出数据库呢?
...全文
205 18 打赏 收藏 转发到动态 举报
写回复
用AI写文章
18 条回复
切换为时间正序
请发表友善的回复…
发表回复
kkbac 2010-04-05
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 sxy445566 的回复:]

如果要效率,那么就需要把TEXTBOX的每个值与数据库中字段对应得特别紧密,不能出一个差错,可以不考虑字段的名字,根据下标来用循环直接写入、读取。
但是这样很容易出错,一旦中间有一个错的,那后面的就全部错误,所以还是劝楼主,累就累点吧,捷径也是有很大风险的。
[/Quote]

这个不错.
OOOqqqOOO 2010-04-05
  • 打赏
  • 举报
回复
是内部用的

但这么多字段,修改、写入比较麻烦啊,不知道如何是好。
蛮大人LT 2010-04-05
  • 打赏
  • 举报
回复
路过 学习
sunzhong2003 2010-04-05
  • 打赏
  • 举报
回复
像这种不能只考虑自己,要考虑到用户体验
也就是分步录入,把属性归类才行
xray2005 2010-04-05
  • 打赏
  • 举报
回复
分开录入。不要一次性
polarissky 2010-04-05
  • 打赏
  • 举报
回复
[Quote=引用 12 楼 jimu8130 的回复:]

建议:
1 一个页面尽量不要一次显示80个字段,用户也会厌烦这么多项目
2 有些字段能有默认值就给默认值,没人愿意一边动鼠标一边输入
3 可将这80个字段按照关联性分成多个页让用户输入,每输完一页就保存。
[/Quote]
UP!
让用户,能少写的就少写,能不写的就不写,能用鼠标点的不用键盘写。
xxp27 2010-04-05
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 wuyq11 的回复:]

foreach (Control control in c.Controls)
{
if (control is TextBox)
{
TextBox txt = (TextBox)control;
}
}
[/Quote]

很好的方法,我也是用这个
zhujiazhi 2010-04-05
  • 打赏
  • 举报
回复
把textbox的ID设为跟数据库字段名一样的,
可以根据反射来获取页面上输入的内容
jimu8130 2010-04-05
  • 打赏
  • 举报
回复
建议:
1 一个页面尽量不要一次显示80个字段,用户也会厌烦这么多项目
2 有些字段能有默认值就给默认值,没人愿意一边动鼠标一边输入
3 可将这80个字段按照关联性分成多个页让用户输入,每输完一页就保存。
txgaozhao 2010-04-05
  • 打赏
  • 举报
回复
用动软的代码生成器吧
OOOqqqOOO 2010-04-05
  • 打赏
  • 举报
回复
[Quote=引用 9 楼 vip__888 的回复:]
引用 7 楼 oooqqqooo 的回复:
是内部用的

但这么多字段,修改、写入比较麻烦啊,不知道如何是好。

分开录入。不要一次性
[/Quote]

一个表分开成几个表?
vip__888 2010-04-05
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 oooqqqooo 的回复:]
是内部用的

但这么多字段,修改、写入比较麻烦啊,不知道如何是好。
[/Quote]
分开录入。不要一次性
丰云 2010-04-03
  • 打赏
  • 举报
回复
再快也要受你的网络/机器/服务器/带宽等等条件的制约....
所以,不必要太苛求,尽力而为就可以拉.
huiming_zhou 2010-04-03
  • 打赏
  • 举报
回复
Control[] userControl = new Control[i]
这个 i 换成多少个控件就换多少 //80
sxy445566 2010-04-03
  • 打赏
  • 举报
回复
如果要效率,那么就需要把TEXTBOX的每个值与数据库中字段对应得特别紧密,不能出一个差错,可以不考虑字段的名字,根据下标来用循环直接写入、读取。
但是这样很容易出错,一旦中间有一个错的,那后面的就全部错误,所以还是劝楼主,累就累点吧,捷径也是有很大风险的。
huiming_zhou 2010-04-03
  • 打赏
  • 举报
回复
DataTable 读取数据 dt
if(dt.Rows.Count>0){
Control[] userControl = new Control[i]
userControl[i] = (TextBox)this.Page.FindControl("TextBox" + i + "");
for(int i=0;i<80;i++)
{
userControl[i].Text=dt.Rows[0][i];
}
}
你自己试下
wuyq11 2010-04-03
  • 打赏
  • 举报
回复
foreach (Control control in c.Controls)
{
if (control is TextBox)
{
TextBox txt = (TextBox)control;
}
}
huiming_zhou 2010-04-03
  • 打赏
  • 举报
回复
获取TextBox的值可以用循环获取
但是insert的时候还是得需要一个个字段的写

62,050

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧