<?xml version="1.0"?>
<Entity>
	<Name>FunctionStructure</Name>
	<Type>Single</Type>
	<Table>
		<Name>FunctionStructure</Name>
		<Column>
			<Name>FunctionStructureCode</Name>
			<DataType>System.String</DataType>
			<IsKey>true</IsKey>
			<IsAllowNull>false</IsAllowNull>
			<ColumnSize>50</ColumnSize>
		</Column>
		<Column>
			<Name>FunctionStructureName</Name>
			<DataType>System.String</DataType>
			<IsKey>false</IsKey>
			<IsAllowNull>true</IsAllowNull>
			<ColumnSize>200</ColumnSize>
		</Column>
		<Column>
			<Name>ParentCode</Name>
			<DataType>System.String</DataType>
			<IsKey>false</IsKey>
			<IsAllowNull>true</IsAllowNull>
			<ColumnSize>50</ColumnSize>
		</Column>
		<Column>
			<Name>Deep</Name>
			<DataType>System.Int32</DataType>
			<IsKey>false</IsKey>
			<IsAllowNull>true</IsAllowNull>
			<ColumnSize>4</ColumnSize>
		</Column>
		<Column>
			<Name>Description</Name>
			<DataType>System.String</DataType>
			<IsKey>false</IsKey>
			<IsAllowNull>true</IsAllowNull>
			<ColumnSize>400</ColumnSize>
		</Column>
		<Column>
			<Name>ProjectSpecialDescription</Name>
			<DataType>System.String</DataType>
			<IsKey>false</IsKey>
			<IsAllowNull>true</IsAllowNull>
			<ColumnSize>400</ColumnSize>
		</Column>
		<Column>
			<Name>OtherSpecialDescription</Name>
			<DataType>System.String</DataType>
			<IsKey>false</IsKey>
			<IsAllowNull>true</IsAllowNull>
			<ColumnSize>400</ColumnSize>
		</Column>
		<Column>
			<Name>IsAvailable</Name>
			<DataType>System.Int32</DataType>
			<IsKey>false</IsKey>
			<IsAllowNull>true</IsAllowNull>
			<ColumnSize>4</ColumnSize>
		</Column>
		<Column>
			<Name>IsRightControlPoint</Name>
			<DataType>System.Int32</DataType>
			<IsKey>false</IsKey>
			<IsAllowNull>true</IsAllowNull>
			<ColumnSize>4</ColumnSize>
		</Column>
		<Column>
			<Name>IsSystemClass</Name>
			<DataType>System.Int32</DataType>
			<IsKey>false</IsKey>
			<IsAllowNull>true</IsAllowNull>
			<ColumnSize>4</ColumnSize>
		</Column>
		<Column>
			<Name>IsRoleControlPoint</Name>
			<DataType>System.Int32</DataType>
			<IsKey>false</IsKey>
			<IsAllowNull>true</IsAllowNull>
			<ColumnSize>4</ColumnSize>
		</Column>
		<Column>
			<Name>StringValue</Name>
			<DataType>System.String</DataType>
			<IsKey>false</IsKey>
			<IsAllowNull>true</IsAllowNull>
			<ColumnSize>200</ColumnSize>
		</Column>
		<Sql>
			<Name>Select</Name>
			<String>select *, (select count(*) from FunctionStructure Fc where Fc.ParentCode=FunctionStructure.FunctionStructureCode) as ChildCount from FunctionStructure where  FunctionStructureCode=@FunctionStructureCode</String>
			<CommandType>Text</CommandType>
			<Param>
				<Name>@FunctionStructureCode</Name>
				<Column>FunctionStructureCode</Column>
				<SqlDbType>VarChar</SqlDbType>
			</Param>
		</Sql>
		<Sql>
			<Name>SelectAll</Name>
			<String>select *, (select count(*) from FunctionStructure Fc where Fc.ParentCode=FunctionStructure.FunctionStructureCode) as ChildCount from FunctionStructure</String>
			<CommandType>Text</CommandType>
		</Sql>
		<Sql>
			<Name>Insert</Name>
			<String> Insert into FunctionStructure (  FunctionStructureCode, FunctionStructureName, ParentCode, Deep, Description, ProjectSpecialDescription, OtherSpecialDescription, IsAvailable, IsRightControlPoint, IsSystemClass, IsRoleControlPoint, StringValue ) values (  @FunctionStructureCode, @FunctionStructureName, @ParentCode, @Deep, @Description, @ProjectSpecialDescription, @OtherSpecialDescription, @IsAvailable, @IsRightControlPoint, @IsSystemClass, @IsRoleControlPoint, @StringValue )</String>
			<CommandType>Text</CommandType>
			<Param>
				<Name>@FunctionStructureCode</Name>
				<Column>FunctionStructureCode</Column>
				<SqlDbType>VarChar</SqlDbType>
			</Param>
			<Param>
				<Name>@FunctionStructureName</Name>
				<Column>FunctionStructureName</Column>
				<SqlDbType>VarChar</SqlDbType>
			</Param>
			<Param>
				<Name>@ParentCode</Name>
				<Column>ParentCode</Column>
				<SqlDbType>VarChar</SqlDbType>
			</Param>
			<Param>
				<Name>@Deep</Name>
				<Column>Deep</Column>
				<SqlDbType>Int</SqlDbType>
			</Param>
			<Param>
				<Name>@Description</Name>
				<Column>Description</Column>
				<SqlDbType>VarChar</SqlDbType>
			</Param>
			<Param>
				<Name>@ProjectSpecialDescription</Name>
				<Column>ProjectSpecialDescription</Column>
				<SqlDbType>VarChar</SqlDbType>
			</Param>
			<Param>
				<Name>@OtherSpecialDescription</Name>
				<Column>OtherSpecialDescription</Column>
				<SqlDbType>VarChar</SqlDbType>
			</Param>
			<Param>
				<Name>@IsAvailable</Name>
				<Column>IsAvailable</Column>
				<SqlDbType>Int</SqlDbType>
			</Param>
			<Param>
				<Name>@IsRightControlPoint</Name>
				<Column>IsRightControlPoint</Column>
				<SqlDbType>Int</SqlDbType>
			</Param>
			<Param>
				<Name>@IsSystemClass</Name>
				<Column>IsSystemClass</Column>
				<SqlDbType>Int</SqlDbType>
			</Param>
			<Param>
				<Name>@IsRoleControlPoint</Name>
				<Column>IsRoleControlPoint</Column>
				<SqlDbType>Int</SqlDbType>
			</Param>
			<Param>
				<Name>@StringValue</Name>
				<Column>StringValue</Column>
				<SqlDbType>VarChar</SqlDbType>
			</Param>
		</Sql>
		<Sql>
			<Name>Update</Name>
			<String> Update FunctionStructure set FunctionStructureName=@FunctionStructureName,ParentCode=@ParentCode,Deep=@Deep,Description=@Description,ProjectSpecialDescription=@ProjectSpecialDescription,OtherSpecialDescription=@OtherSpecialDescription,IsAvailable=@IsAvailable,IsRightControlPoint=@IsRightControlPoint,IsSystemClass=@IsSystemClass,IsRoleControlPoint=@IsRoleControlPoint,StringValue=@StringValue where  FunctionStructureCode=@FunctionStructureCode</String>
			<CommandType>Text</CommandType>
			<Param>
				<Name>@FunctionStructureCode</Name>
				<Column>FunctionStructureCode</Column>
				<SqlDbType>VarChar</SqlDbType>
			</Param>
			<Param>
				<Name>@FunctionStructureName</Name>
				<Column>FunctionStructureName</Column>
				<SqlDbType>VarChar</SqlDbType>
			</Param>
			<Param>
				<Name>@ParentCode</Name>
				<Column>ParentCode</Column>
				<SqlDbType>VarChar</SqlDbType>
			</Param>
			<Param>
				<Name>@Deep</Name>
				<Column>Deep</Column>
				<SqlDbType>Int</SqlDbType>
			</Param>
			<Param>
				<Name>@Description</Name>
				<Column>Description</Column>
				<SqlDbType>VarChar</SqlDbType>
			</Param>
			<Param>
				<Name>@ProjectSpecialDescription</Name>
				<Column>ProjectSpecialDescription</Column>
				<SqlDbType>VarChar</SqlDbType>
			</Param>
			<Param>
				<Name>@OtherSpecialDescription</Name>
				<Column>OtherSpecialDescription</Column>
				<SqlDbType>VarChar</SqlDbType>
			</Param>
			<Param>
				<Name>@IsAvailable</Name>
				<Column>IsAvailable</Column>
				<SqlDbType>Int</SqlDbType>
			</Param>
			<Param>
				<Name>@IsRightControlPoint</Name>
				<Column>IsRightControlPoint</Column>
				<SqlDbType>Int</SqlDbType>
			</Param>
			<Param>
				<Name>@IsSystemClass</Name>
				<Column>IsSystemClass</Column>
				<SqlDbType>Int</SqlDbType>
			</Param>
			<Param>
				<Name>@IsRoleControlPoint</Name>
				<Column>IsRoleControlPoint</Column>
				<SqlDbType>Int</SqlDbType>
			</Param>
			<Param>
				<Name>@StringValue</Name>
				<Column>StringValue</Column>
				<SqlDbType>VarChar</SqlDbType>
			</Param>
		</Sql>
		<Sql>
			<Name>Delete</Name>
			<String> Delete from FunctionStructure  where  FunctionStructureCode=@FunctionStructureCode</String>
			<CommandType>Text</CommandType>
			<Param>
				<Name>@FunctionStructureCode</Name>
				<Column>FunctionStructureCode</Column>
				<SqlDbType>VarChar</SqlDbType>
			</Param>
		</Sql>
		<Sql>
			<Name>SelectByParentCode</Name>
			<String>select *, (select count(*) from FunctionStructure Fc where Fc.ParentCode=FunctionStructure.FunctionStructureCode) as ChildCount from FunctionStructure where ParentCode=@ParentCode</String>
			<CommandType>Text</CommandType>
			<Param>
				<Name>@ParentCode</Name>
				<Column>ParentCode</Column>
				<SqlDbType>VarChar</SqlDbType>
			</Param>
		</Sql>
	</Table>
</Entity>