分享人: 广州华软 无名

一. 前言

虽然SharePoint提供可视化界面建表,但是,不利于开发自动化部署。通常,如果通过手动建表,我们先在测试环境建表,然后存为模板,再上传到实际环境,最后根据模板来创建列表。况且,有些列表也就一次使用,也就没必要存为模板。

二. 目录

1.代码建表作用

2.如何使用代码建表

2.1前置条件

2.2关键代码

3总结

三. 代码建表作用

开发环境和实际使用环境是分离的,避免重复在各个环境手动建表;

代码和建表分离,如果增减字段,后期要维护多个地方的数据,通过代码,可通过网站或网站集功能统一处理。

通过可视化界面建表,我们需要先建内部名称,然后再修改显示名称,通过代码可以一次搞定。

四. 如何使用代码建表

代码建表有多种方式,一种是通过SharePoint提供的开发模板创建列表,一种是通过SharePoint对象模型创建列表,这里介绍的是使用SSOM对象模型创建列表。

4.1 前置条件

引用Microsoft.SharePoint.DLL类库

引用命名空间Microsoft.SharePoint;

当前登录用户有创建列表权限

4.2 关键代码

先创建列表,在创建表关联字段。

4.2.1 创建列表

var sPWeb= SPContext.Current.Web;

Guid guid = sPWeb.Lists.Add(列表内部名,列表描述, SPListTemplateType.GenericList);

SPList lst = sPWeb.Lists[guid];

lst.Title = “列表显示名称”;

lst.Update();

4.2.2 创建文本字段

SPField tempFld = new SPField(flds, SPFieldType.Text.ToString(), 字段内部名称);

SPFieldText fld = flds.GetFieldByInternalName(flds.Add(tempFld)) as SPFieldText;

fld.MaxLength = 长度限制;

fld.DefaultValue = 默认值;

fld.Title = 字段名称;

fld.EnforceUniqueValues = 唯一值;

fld.Required = 必填

fld.Update();

4.2.3 创建是否字段

SPField tempFld = new SPField(flds, SPFieldType.Boolean.ToString(), 字段内部名称);

SPField fld = flds.GetFieldByInternalName(flds.Add(tempFld));

fld.DefaultValue = 默认值;

fld.Title = 字段名称;

fld.Update();

4.2.4 创建数字字段

SPField tempFld = new SPField(flds, SPFieldType.Number.ToString(), 字段内部名称);

SPField fld = flds.GetFieldByInternalName(flds.Add(tempFld));

fld.DefaultValue = 默认值;

fld.Title = 字段名称;

fld.Update();

4.2.5 创建整数字段

SPField tempFld = new SPField(flds, SPFieldType.Integer.ToString(), 字段内部名称);

SPField fld = flds.GetFieldByInternalName(flds.Add(tempFld));

fld.DefaultValue = 默认值;

fld.Title = 字段名称;

fld.Update();

4.2.6 创建选项字段

SPField tempFld = new SPField(flds, SPFieldType.Choice.ToString(), 字段内部名称);

SPFieldChoice fld = flds.GetFieldByInternalName(flds.Add(tempFld)) as SPFieldChoice;

fld.Choices.AddRange(new string[]{选项值});

fld.DefaultValue = 默认值;

fld.Title = 字段名称;

fld.Update();

4.2.7 创建时间字段

SPField tempFld = new SPField(flds, this.FieldType.ToString(), 字段内部名称);

SPFieldDateTime fld = flds.GetFieldByInternalName(flds.Add(tempFld)) as SPFieldDateTime;

fld.DefaultValue = 默认值;

fld.Title = 字段名称;

fld.DisplayFormat = 日期格式;

fld.FriendlyDisplayFormat = 日期显示风格;

fld.Update();

4.2.8 创建查阅项字段

string internalName = flds.AddLookup(字段内部名称,被关联表guid, 是否必填);

SPFieldLookup fld = flds.GetFieldByInternalName(internalName) as SPFieldLookup;

fld.Title = 字段名称;

fld.LookupField =被关联字段;

fld.Update();

4.2.9 创建用户字段

SPField tempFld = new SPField(flds, SPFieldType.User.ToString(),字段内部名称);

SPFieldUser fld = flds.GetFieldByInternalName(flds.Add(tempFld)) as SPFieldUser;

fld.Title =字段名称;

fld.AllowMultipleValues =是否多值;

fld.SelectionMode = 设置选择组还是用户;

fld.Update();

4.2.10 创建链接字段

SPField tempFld = new SPField(flds, SPFieldType.URL.ToString(), 自动内部名);

SPFieldUrl fld = flds.GetFieldByInternalName(flds.Add(tempFld)) as SPFieldUrl;

fld.Title = 字段名称;            fld.Required = 是否必填

fld.Indexed =是否建立索引;

fld.EnforceUniqueValues =是否唯一

fld.DisplayFormat =显示图片还是链接

fld.Update();

五. 总结

对于开发而言,把创建表的过程写在代码里面,方便在同个地方统一维护。

如果一个列表被多个网站使用到,可以将列表作为网站功能。一激活,则多个地方都可以同时使用。

SharePoint给我们提供了很多建立表的api,给我们开发带来便利,提高了开发效率。

SharePoint代码建表(实战)的更多相关文章

  1. MySQL用程序代码建表(1)

    一.创建表格代码格式 create table <表名>( <列名> <数据类型及长度> [not null], <列名> <数据类型及长度> ...

  2. MatrixOne从入门到实战04——MatrixOne的连接和建表

    MatrixOne从入门到实战--MatrixOne的连接和建表 前景回顾 前几篇文章,为大家介绍了MatrixOne这个产品,以及编译.部署MatrixOne的服务. 直通车: MatrixOne从 ...

  3. vue.js+koa2项目实战(六)数据库建表

    数据库建表 1.打开 MySQL 终端 2.查看所有数据库 show databases 3.创建数据库 create database pet 4.进入数据库 use pet 5.创建数据表 cre ...

  4. Hibernate不能自动建表解决办法

    最近开始学Hibernate,看的是李刚的那本<轻量级java ee企业应用实战>.头一个hibernate程序,我原原本本的按照书上例子写下来,同时只是改动了些mysql的连接参数,并且 ...

  5. 【hbase】——Java操作Hbase进行建表、删表以及对数据进行增删改查,条件查询

    1.搭建环境 新建JAVA项目,添加的包有: 有关Hadoop的hadoop-core-0.20.204.0.jar 有关Hbase的hbase-0.90.4.jar.hbase-0.90.4-tes ...

  6. [转]Hibernate不能自动建表解决办法及Hibernate不同数据库的连接及SQL方言

    最近开始学Hibernate,看的是李刚的那本<轻量级java ee企业应用实战>.头一个hibernate程序,我原原本本的按照书上例子写下来,同时只是改动了些mysql的连接参数,并且 ...

  7. (转)Java操作Hbase进行建表、删表以及对数据进行增删改查,条件查询

    1.搭建环境 新建JAVA项目,添加的包有: 有关Hadoop的hadoop-core-0.20.204.0.jar 有关Hbase的hbase-0.90.4.jar.hbase-0.90.4-tes ...

  8. Oracl用代码建标

    建标还可以通过编写代码的方式实现,这样在建许多类似的表的时候可以极高建表的效率. create table SCORE                   --建立表名(                ...

  9. PowerDesigner连接Oracle数据库建表序列号实现自动增长

    原文:PowerDesigner连接Oracle数据库建表序列号实现自动增长 创建表就不说了.下面开始介绍设置自动增长列. 1 在表视图的列上创建.双击表视图,打开table properties — ...

随机推荐

  1. 强化学习(十二) Dueling DQN

    在强化学习(十一) Prioritized Replay DQN中,我们讨论了对DQN的经验回放池按权重采样来优化DQN算法的方法,本文讨论另一种优化方法,Dueling DQN.本章内容主要参考了I ...

  2. Redis调用的流程(新手使用)

    就用查省市为例,别人还没查就把所有都弄好,很浪费资源和时间,redis是为了存储常用的查询操作的[结果],以此来减少直接查询数据库的次数,以下内容仅供参考,请勿照抄.(如有说得不好之处,请指点.) 言 ...

  3. Python中使用type、metaclass动态创建方法和属性

    1: type() 我们知道动态语言和静态语言最大的不同,就是函数和类的定义,不是编译时定义的,而是运行时动态创建的. 比方说我们要定义一个Person的class: class Person(obj ...

  4. Java并发——volatile关键字

    什么是内存可见性? 这里就要提一下JMM(Java内存模型).当线程在运行的时候,并不是直接直接修改电脑主内存中的变量的值.线程间通讯也不是直接把一个线程的变量的值传给另一个线程,让其刷新变量.下面是 ...

  5. Android自动解析html带图片,实现图文混排

    在android中,如何将html代码转换为text,然后显示在textview中呢,有一个简单直接的方法: textView.setText(Html.fromHtml(content)); 然而用 ...

  6. 【Teradata SQL】一个字段为空即取另外一个字段(连续取4个字段)-case when

    目标:如果col1为空则取col2的值,如果col2也为空则取col3的值,如果col3还为则取col4的值,如果四个字段均为空则取默认值 1.数据准备 create multiset table t ...

  7. SLA服务可用性怎么达到?

    SLA:服务等级协议(简称:SLA,全称:service level agreement).是在一定开销下为保障服务的性能和可用性,服务提供商与用户间定义的一种双方认可的协定.通常这个开销是驱动提供服 ...

  8. Java相关资料分享(视频+电子书籍)

    正所谓“授人以鱼不如授人以渔”,你们想要的Java学习资料来啦!不管你是学生,还是已经步入职场的同行,希望你们都要珍惜眼前的学习机会,奋斗没有终点,知识永不过时. 关注底下的公众号,获取百度网盘提取码 ...

  9. ASP.NET MVC默认配置如有跳转到指定的Area区域中的对应程序中

    今天在搭建一个基于MVC的项目,因为项目涉及到了手机和pc端,为了方便和减少二者之间的耦合我在区域(Areas)中建立了两个 程序空间,那么问题来了我想让程序默认跳转到我所指定的areas中的对应项目 ...

  10. JavaSSM框架报HTTP Status 500 - Servlet.init() for servlet springMvc threw exception错误

    如下,刚搭建的项目报这样的错,刚学框架的我一脸懵逼...网上很多说是jdk或者springmvc的的jar的版本问题,但是我其他项目都可以啊,所以排除了这个问题. 经过几个小时的排查,发现了我的问题所 ...