>백엔드 개발 >C#.Net 튜토리얼 >ASP.NET Core MySql varchar 문자열 가로채기 예제 튜토리얼 해결

ASP.NET Core MySql varchar 문자열 가로채기 예제 튜토리얼 해결

零下一度
零下一度원래의
2017-06-23 16:13:002128검색

MySql은 ASP.NET Core에서 사용됩니다. 필드 유형이 varchar인 경우 설정 기간에 관계없이 데이터를 삽입하거나 업데이트할 때 자동으로 잘립니다(255자). varchar,不管设置多少长度,插入或更新数据的时候,会自动截断(截取 255 长度的字符)。

出现问题的原因,就是使用了MySql.Data.EntityFrameworkCore程序包(我使用的版本是7.0.7-m6),可能是其版本问题,升级版本的话,可能问题不会出现了。

解决方式:将 MySql 所有字段类型为varchar(字段长度大于 255)的字段,类型都改为text

문제의 원인은 MySql.Data.EntityFrameworkCore 패키지(제가 사용하고 있는 버전은 7.0.7-m6)의 사용 때문일 수 있습니다. 버전 문제입니다. 버전을 업그레이드하면 문제가 발생하지 않을 수 있습니다.

해결책: varchar(필드 길이가 255보다 큼)인 모든 MySql 필드의 유형을 text(선택 사항)로 변경합니다. 기본값은 0)입니다.
그런 다음 EF Core 매핑 구성은 다음과 같이 수정됩니다.

protected override void OnModelCreating(ModelBuilder modelBuilder)
{var entity = modelBuilder.Entity<Entity>();

    entity.Property(p => p.Body).HasColumnType("text"); //add HasColumnType("text")base.OnModelCreating(modelBuilder);
}
  • 참조:

  • .Net Core Entity Framework MySQL - 문자열 필드는 255개의 기호만 저장합니다.

.Net 코어용 MySql 커넥터는 텍스트를 자릅니다. 최대 255자🎜🎜🎜

위 내용은 ASP.NET Core MySql varchar 문자열 가로채기 예제 튜토리얼 해결의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.