gordem 2021-09-23 10:57 采纳率: 100%
浏览 46
已结题

请教一个Linq To SQL的奇怪问题(Substring相关)

代码:

img


结果:
这里错误的结果,第一列:

img


正确的结果应该是这样:

img

原数据:

img

IQueryable<UserEmployeeResult> queryUser = from Emp in query                                                      
                                                   join User in DataContext2.Read.UserTable.Where(table => table.isAppUser == true) on Emp.SID equals User.EmployeeSID into JUser
                                                   from User in JUser.DefaultIfEmpty()
                                                   select new UserEmployeeResult
                                                   {
                                                       SID = Emp.SID,
                                                       Number = Emp.Number,
                                                       Name = Emp.Name,
                                                       PartNumber = Emp.PartNumber,
                                                       PartName = Emp.PartName,
                                                       SubjectNumber = Emp.SubjectNumber,
                                                       SubjectName = Emp.SubjectName,
                                                       Sex = Emp.Sex,
                                                       GroupNumber = Emp.GroupNumber,
                                                       GroupName = Emp.GroupName,
                                                       ClassNumber = Emp.ClassNumber,
                                                       ClassName = Emp.ClassName,
                                                       PartNo4 = Emp.PartNo4,
                                                       PartName4 = Emp.PartName4,
                                                       PartNo5 = Emp.PartNo5,
                                                       PartName5 = Emp.PartName5,
                                                       PartNo6 = Emp.PartNo6,
                                                       PartName6 = Emp.PartName6,
                                                       PartNo7 = Emp.PartNo7,
                                                       PartName7 = Emp.PartName7,
                                                       PartName0 = Emp.PartName0,
                                                       userID = User.AutoID,
                                                       userName = User.ID.Substring(1),//APP账号列,User.ID是原数据图里的ID列,正确数据应该是User.ID去最前面的#
                                                       hasAppUser = (User != null),
                                                       password = Emp.PassWord,
                                                       EmployeeAdmin = User.EmployeeAdmin,
                                                       ApproveAdmin = User.ApproveAdmin
                                                   };

为什么Substring(1)不应该是截取从索引1到最后的字符串么,怎么会去头去尾了??还是不定长的去尾(好像也定长,就字符串一半长度)

补充:结果图里APP账号一列的数据应该为数据图里ID一列去#,所以用的方法是User.ID.Substring(1),但对比数据可看出User.ID.Substring(1)截取的把ID后半也去掉了

  • 写回答

1条回答 默认 最新

  • CSDN专家-showbo 2021-09-23 11:24
    关注

    6002333,1004998这个2个是正常的啊。取1开始到最后字符串,哪个是截取出错的。。
    题主数据库记录截图排序和页面显示不一致,没看出哪个被乱截取了。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 9月23日
  • 已采纳回答 9月23日
  • 修改了问题 9月23日
  • 修改了问题 9月23日
  • 展开全部

悬赏问题

  • ¥15 在若依框架下实现人脸识别
  • ¥15 网络科学导论,网络控制
  • ¥100 安卓tv程序连接SQLSERVER2008问题
  • ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同