0

0

光脚丫学LINQ(043):为实体类的列成员指定在数据库中的数据类型

php中文网

php中文网

发布时间:2016-06-07 15:35:35

|

1346人浏览过

|

来源于php中文网

原创

视频演示: http://u.115.com/file/f21113c26 演示重点 通过给实体类成员的 ColumnAttribute 特性设置 DbType 属性, 就可以为列成员指定它在数据库中的数据类型了。 赋值给DbType的属性值是一个字符串。 此字符串可以包含数据类型,数据的大小,以及是否为

视频演示:http://u.115.com/file/f21113c26

演示重点
通过给实体类成员的columnattribute特性设置dbtype属性,
就可以为列成员指定它在数据库中的数据类型了。
赋值给dbtype的属性值是一个字符串。
此字符串可以包含数据类型,数据的大小,以及是否为空。
比如columnattribute.dbtype="nvarchar(40) not null"
事实上,只有当我们根据对象模型来创建数据库的时候,这个属性才是有用。
也就是调用数据上下文datacontext.createdatabase()方法时。
当调用此方法时,它才会读取dbtype的属性值,然后据此来确定所创建的数据表的列的数据类型。
而通常使用对象模型对数据进行增删查改这些基本操作的时候,貌似这个属性就没什么用武之地了。

另外,也演示了如何通过对象模型来创建数据库。
这其中分别涉及到了以下3个方法:
DataContext.DatabaseExists():确定是否已经存在指定的数据库。
DataContext.DeleteDatabase():删除指定的数据库。
DataContext.CreateDatabase():根据对象模型创建数据库。
使用对象模型创建数据库的时候,如果没有为实体类的列成员设置ColumnAttribute.DbType属性,
那么就会使用NVarchar(4000)作为默认数据类型。
基于这个理由,如果我们要使用对象模型创建数据库的话,
那最好还是显示而明确的设置实体类列成员的ColumnAttribute.DbType。
而且一定要设置为有效的类型,否则LINQ to SQL所生成的CREATE TABLE命令就会包含无效的数据类型,
自然也就不会被成功执行了。
但如果不用对象模型创建数据库的话,设置了此属性反而是多此一举了。^_^

关键代码
下面的代码演示如何为实体类的列成员指定它在数据库中的数据类型,重点是DbType属性。

下面的代码演示了如何让LINQ to SQL根据对象模型创建数据库。

研习记录
此代码主要是用来研习ColumnAttribute.DbType属性的。
当希望使用DataContext.CreateDtabase()这个方法根据对象模型创建数据库的时候,这个属性尤其重要。
那么是否不设置这个属性,或者这个属性值设置无效的情况下,都将不能正确创建数据库呢?
当给DbType属性设置了一个无效的数据类型时,LINQ to SQL并不能够确定其是否有效。
它只会简单的用这个DbType的字符串属性值组合成一个创建数据库的SQL命令,
当这个命令发送给数据库的时候,却无法正确地执行,因为某个列的数据类型是无效的。
从这点来看LINQ to SQL还是有笨的地方。-_-
如果不设置DbType属性也可以,不过此时LINQ to SQL会用NVarChar(4000)这个作为其默认类型。
看看这个,我觉得还是明确的指定出来数据类型吧!
如果对象模型的本身不是用来创建数据库,而仅仅是为了操作已经创建好的数据库中的数据,
那么完全可以不为列属性设置这个DbType属性值。
这并不会影响使用效果的。
但如果要想根据对象模型来创建数据库的话,那最好还是明确的指定出来数据类型吧!

光脚丫思考 2010-12-28

社研通
社研通

文科研究生的学术加速器

下载

相关专题

更多
c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

79

2026.01.09

c++框架学习教程汇总
c++框架学习教程汇总

本专题整合了c++框架学习教程汇总,阅读专题下面的文章了解更多详细内容。

46

2026.01.09

学python好用的网站推荐
学python好用的网站推荐

本专题整合了python学习教程汇总,阅读专题下面的文章了解更多详细内容。

121

2026.01.09

学python网站汇总
学python网站汇总

本专题整合了学python网站汇总,阅读专题下面的文章了解更多详细内容。

12

2026.01.09

python学习网站
python学习网站

本专题整合了python学习相关推荐汇总,阅读专题下面的文章了解更多详细内容。

15

2026.01.09

俄罗斯手机浏览器地址汇总
俄罗斯手机浏览器地址汇总

汇总俄罗斯Yandex手机浏览器官方网址入口,涵盖国际版与俄语版,适配移动端访问,一键直达搜索、地图、新闻等核心服务。

71

2026.01.09

漫蛙稳定版地址大全
漫蛙稳定版地址大全

漫蛙稳定版地址大全汇总最新可用入口,包含漫蛙manwa漫画防走失官网链接,确保用户随时畅读海量正版漫画资源,建议收藏备用,避免因域名变动无法访问。

370

2026.01.09

php学习网站大全
php学习网站大全

精选多个优质PHP入门学习网站,涵盖教程、实战与文档,适合零基础到进阶开发者,助你高效掌握PHP编程。

45

2026.01.09

php网站搭建教程大全
php网站搭建教程大全

本合集专为零基础用户打造,涵盖PHP网站搭建全流程,从环境配置到实战开发,免费、易懂、系统化,助你快速入门建站!

12

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
ASP 教程
ASP 教程

共34课时 | 3.4万人学习

PHP课程
PHP课程

共137课时 | 8.5万人学习

PHP入门速学(台湾同胞版)
PHP入门速学(台湾同胞版)

共10课时 | 1.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号