gridview 数字排序问题,为什么1,10,3三个数字排序出来为1,10,3;而不是1,3,10呢?求救

Bettyh 2009-01-23 12:37:36
如题!
...全文
413 13 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
13 条回复
切换为时间正序
请发表友善的回复…
发表回复
liujiayu10 2009-01-23
  • 打赏
  • 举报
回复
转换为INT型或是加上前导0让位数相同
zorou_fatal 2009-01-23
  • 打赏
  • 举报
回复
你的数据类型不是int吧.
homesos 2009-01-23
  • 打赏
  • 举报
回复
可以查一下MSDN,看看。
homesos 2009-01-23
  • 打赏
  • 举报
回复
排序规则 就是这样的
常用的有Windows 排序规则、SQL 排序规则
cwmwss 2009-01-23
  • 打赏
  • 举报
回复
难道是按首数字排序了》
king19840811 2009-01-23
  • 打赏
  • 举报
回复
点每一列上面的小三角可以自动排序的
wfyfngu 2009-01-23
  • 打赏
  • 举报
回复
如果是使用C#控制排序而非使用Sql命令Order By:
在Page_Load()中将当前线程的语言改为中国就可以了。
或者将服务器的默认语言更改为中文(在控制面板的区域一项中)
blackmeit 2009-01-23
  • 打赏
  • 举报
回复
最好是在SQL语句查询的时候多加一列,用于排序。
例如:

select cast(listno as int) as intlistno
from Table.


这样排序DataView.SortExpression = "intlistno";
dengchenlu 2009-01-23
  • 打赏
  • 举报
回复
你的是字符串类型的吧
转换成INT就可以了
直接用SQL转 Convert(Int,ziduan)
雪狐 2009-01-23
  • 打赏
  • 举报
回复
不是int型的,这是string的排序
blackmeit 2009-01-23
  • 打赏
  • 举报
回复
ds.Tables[0].Columns.Add("listno",System.Type.GetType("System.Int32"));
ds.Tables[0].Columns["listno"].Expression = Convert(listno,'System.Int32');

sharpblade 2009-01-23
  • 打赏
  • 举报
回复
应该当成string排序了
Bettyh 2009-01-23
  • 打赏
  • 举报
回复
我的代码是这样的,后台:
Protected Sub GridView1_Sorting(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.GridViewSortEventArgs) Handles GridView1.Sorting
Dim sortEx As String
sortEx = e.SortExpression
If ViewState("SortOrder").ToString = sortEx Then
If ViewState("OrderDire").ToString = "desc" Then
ViewState("OrderDire") = "asc"
Else
ViewState("OrderDire") = "desc"
End If
Else
ViewState("SortOrder") = e.SortExpression
End If
Call gridsort()
End Sub

Private Sub gridsort()
conn.ConnectionString = System.Configuration.ConfigurationManager.ConnectionStrings("connstr").ConnectionString
conn.Open()
sda = New System.Data.SqlClient.SqlDataAdapter(strsql, conn.ConnectionString)
sda.Fill(ds, "sorttable")
view = ds.Tables("sorttable").DefaultView

Dim sortname As String = ViewState("SortOrder") + " " + ViewState("OrderDire")
view.Sort = sortname
GridView1.DataSource = view
GridView1.DataBind()
conn.Close()

End Sub

前台:

<asp:TemplateField HeaderText="编号" SortExpression= "listno" >
<ItemTemplate>
<%#Int(Eval("listno"))%>
</ItemTemplate>
</asp:TemplateField>

62,243

社区成员

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

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

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

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