【发布时间】:2014-11-13 19:19:23
【问题描述】:
我正在尝试创建一个函数,将查询结果值更改为文本框中的值。我可以运行 LINQ 查询,获取值,并且 read 可以完美打印...但是当我尝试将查询值更改为文本框值时,出现以下错误:
Property or indexer 'AnonymousType#1.FirstName' cannot be assigned to -- it is read only
代码如下:
private void editQuery(int contactID)
{
ContactLINQDataContext context = new ContactLINQDataContext("Data Source=WORK-PC;Initial Catalog=Steve Harvey Team;Integrated Security=True");
var editContact = (from Contacts in context.Contacts
join prop in context.Properties on Contacts.Address equals prop.PropertyID
join spouse in context.Contacts on Contacts.Spouse equals spouse.ContactID
where Contacts.ContactID == contactID
select new
{
ID = Contacts.ContactID,
FirstName = Contacts.FirstName,
LastName = Contacts.LastName,
FirstName2 = spouse.FirstName,
LastName2 = spouse.LastName,
Street = prop.Street,
City = prop.City,
State = prop.State,
ZIP = prop.ZIP,
Phone1 = Contacts.Phone,
Phone2 = Contacts.AltPhone,
Email = Contacts.Email,
ContactType = Contacts.Type,
Assets = Contacts.Assets,
Notes = Contacts.Notes,
}).First();
editContact.FirstName = firstNameBox1.Text;
我认为这可能是因为我正在尝试更改 var 类型,但我不知道如何更改类型并仍然更新值。有什么想法吗?
更新
我找到了一个最终对我有用的解决方案。感谢那些回复并让我走上正轨的海报。我在下面的评论中详细说明了我的解决方案。
【问题讨论】:
标签: c# sql linq linq-to-sql