|
在上篇文章我们生成了具有明确含义标准的XML,有了这样的XML要生成SQL就很容易。象我这样构建出相关的类之后,只要有涉及到引用时只要继承SQLRECORD这个类,并重写它的GetSqlValue方法。而后根据名称取得你对应的SQL生成器就行了。我相信即使还有许多要导入的EXCEL我也不怕了。那时我一个上午就完成了四张全都有引用表的导入工作,当然包括在EXCEL中设置伏笔等工作。记得那天我病得很重,头天晚上还打针。 data:image/s3,"s3://crabby-images/20141/201412a7cc6f8e034824698c6db1a3ac03ff1a54" alt="" 在这个导入设计中我还有些地方没有做好。比如XML,SQL生成的管理器我就做得很粗糙。
1 using System; 2 using System.Collections.Generic; 3 using System.Text; 4 using System.Xml; 5 using System.IO; 6 using Zxh.Pis.EntitiesTest.Xml; 7 EntitiesTest.Sql 8data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt="" data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt="" { 9 struct SqlColumn 10data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 11 private string _Name; 12 public string Name 13data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 14data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" get { return _Name; } 15data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" set { _Name = value; } 16 } 17 private string _Value; 18 public string Value 19data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 20data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" get { return _Value; } 21data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" set { _Value = value; } 22 } 23 private string _Type; 24 public string Type 25data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 26data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" get { return _Type; } 27data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" set { _Type = value; } 28 } 29 private string _Refrence; 30 public string Refrence 31data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 32data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" get { return _Refrence; } 33data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" set { _Refrence = value; } 34 } 35 private string _Restrict; 36 public string Restrict 37data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 38data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" get { return _Restrict; } 39data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" set { _Restrict = value; } 40 } 41 public SqlColumn(string name, string strValue) 42 : this(name, strValue,string.Empty) 43data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 44data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 45 } 46data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 47 public SqlColumn(string name, string strValue,string type) 48 : this(name, strValue, type,string.Empty) 49data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 50data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 51 } 52data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 53 public SqlColumn(string name, string strValue, string type,string refrence) 54 :this(name, strValue, type,refrence,string.Empty) 55data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 56data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 57 } 58data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 59 public SqlColumn(string name, string strValue, string type, string refrence,string restrict) 60data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 61 _Name = name; 62 _Value = strValue; 63 _Type = type; 64 _Refrence = refrence; 65 _Restrict = restrict; 66 } 67 } 68data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 69 class SqlConvrter 70data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 71 private XmlDocument _Doc; 72 public SqlConvrter(XmlDocument doc) 73data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 74 _Doc = doc; 75 } 76data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 77 public void ConvertToSql(string strFilePath) 78data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 79 TextWriter writer = new StreamWriter(strFilePath,false,Encoding.UTF8); 80 XmlNode root = _Doc.DocumentElement; 81 string strTableName = root.Attributes[XmlConstraint.NAME].Value; 82 SqlRecord sqlRecord = SqlRecord.GetSqlRecord(strTableName); 83 foreach (XmlNode node in _Doc.DocumentElement.ChildNodes) 84data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 85 sqlRecord.Clear(); 86 foreach (XmlNode columnNode in node.ChildNodes) 87data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 88 string name = columnNode.Attributes[XmlConstraint.NAME].Value; 89 string strValue = columnNode.Attributes[XmlConstraint.VALUE].Value; 90 string type = string.Empty; 91 string refrence = string.Empty; 92 string restrict = string.Empty; 93 if (columnNode.Attributes[XmlConstraint.REFRENCE] != null) 94data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 95 refrence = columnNode.Attributes[XmlConstraint.REFRENCE].Value; 96 } 97 if (columnNode.Attributes[XmlConstraint.RESTRICT] != null) 98data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 99 restrict = columnNode.Attributes[XmlConstraint.RESTRICT].Value; 100 } 101 if (columnNode.Attributes[XmlConstraint.TYPE] != null) 102data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 103 type = columnNode.Attributes[XmlConstraint.TYPE].Value; 104 } 105 sqlRecord.AddColumn(new SqlColumn(name, strValue, type, refrence, restrict)); 106 } 107 writer.WriteLine(); 108 sqlRecord.ConvertToSql(writer); 109 writer.WriteLine(); 110 writer.WriteLine("go"); 111 } 112 writer.Dispose(); 113 } 114 } 115data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 116 class SqlRecord 117data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 118 private string _TableName; 119 private string strInsert; 120 private int _Para = 0; 121data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 122 protected string GetNewParaName() 123data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 124 ++_Para; 125 return "@P" + _Para.ToString(); 126 } 127 StringBuilder strColumns = new StringBuilder(); 128 StringBuilder strValues = new StringBuilder(); 129 List<SqlColumn> _Columns = new List<SqlColumn>(); 130 public SqlRecord(string tableName) 131data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 132 _TableName = tableName; 133 strInsert = " insert into " + tableName; 134 } 135data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 136 public void AddColumn(SqlColumn column) 137data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 138 _Columns.Add(column); 139 } 140data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 141 public void Clear() 142data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 143 _Columns.Clear(); 144 _Para = 0; 145 strColumns.Remove(0,strColumns.Length); 146 strValues.Remove(0, strValues.Length); 147 } 148data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 149 public void ConvertToSql(TextWriter writer) 150data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 151 StringBuilder sb = new StringBuilder(); 152 foreach (SqlColumn sqlColumn in _Columns) 153data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 154 AddColumn(sqlColumn.Name); 155 string strFront = string.Empty; 156 string strValue = string.Empty; 157 GetSqlValue(sqlColumn,ref strFront,ref strValue); 158 sb.Append(strFront); 159 AddValue(strValue); 160 } 161 sb.Append(strInsert); 162 sb.Append("("); 163 sb.Append(strColumns); 164 sb.Append(") values("); 165 sb.Append(strValues); 166 sb.Append(") "); 167 writer.Write(sb.ToString()); 168 } 169data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 170 protected virtual void GetSqlValue(SqlColumn sqlColumn,ref string strFront,ref string strValue) 171data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 172 strValue = GetValueString(sqlColumn); 173 } 174data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 175 protected string GetValueString(SqlColumn sqlColumn) 176data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 177 if (sqlColumn.Type == XmlConstraint.INT) 178data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 179 return sqlColumn.Value; 180 } 181 else 182data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 183 return "'" + sqlColumn.Value + "'"; 184 } 185 } 186data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 187 protected void AddColumn(string strColumn) 188data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 189 if (strColumns.Length > 0) 190data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 191 strColumns.Append(','); 192 } 193 strColumns.Append(strColumn); 194 } 195data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 196 protected void AddValue(string strValue) 197data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 198 if (strValues.Length > 0) 199data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 200 strValues.Append(','); 201 } 202 strValues.Append(strValue); 203 } 204data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 205 public static SqlRecord GetSqlRecord(string name) 206data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 207 if ( name.ToLower()== "MemberOfCongress".ToLower()) 208data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 209 return new RepresentativeSqlRecord(name); 210 } 211 else if (name.ToLower() == "proposal") 212data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 213 return new ProposalSqlRecord(name); 214 } 215 else if (name.ToLower() == "proposalmember") 216data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 217 return new ProposalMemberSqlRecord(name); 218 } 219 else if (name.ToLower() == "proposaldepartmentalism") 220data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 221 return new ProposalDepartmentalismSqlRecord(name); 222 } 223 else 224data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 225 return new SqlRecord(name); 226 } 227 } 228 } 229data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 230 class RepresentativeSqlRecord : SqlRecord 231data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 232 public RepresentativeSqlRecord(string strTableName) 233 :base(strTableName) 234data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 235 } 236data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 237 protected override void GetSqlValue(SqlColumn sqlColumn,ref string strFront,ref string strValue) 238data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 239 if (string.IsNullOrEmpty(sqlColumn.Refrence)) 240data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 241 base.GetSqlValue(sqlColumn, ref strFront,ref strValue); 242 } 243 else 244data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 245 if (sqlColumn.Refrence.ToLower() == "entryitem") 246data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 247 string paraName = GetNewParaName(); 248 string strFormat = "declare {0} int\n" + 249 "declare {0}_1 int\n" + 250 "select {0}_1=Id from entrybase where name='{2}'\n" + 251 "select {0}=id\n" + 252 "from entrybase \n" + 253 "where name='{1} '\n" + 254 " and id in (select id from entryitem where entrycategory={0}_1)\n" + 255 "if({0} is null)\n" + 256 "begin \n" + 257 " insert into entrybase(Name,fixed) values('{1}',1)\n" + 258 " select {0}=IDENT_CURRENT('entrybase')\n" + 259 " insert into entryitem(id,entrycategory) values({0},{0}_1)\n" + 260 "end\n"; 261 strFront = string.Format(strFormat, paraName, sqlColumn.Value, sqlColumn.Restrict); 262 strValue = paraName; 263 } 264 else 265data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 266 if (sqlColumn.Refrence.ToLower() == "congress") 267data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 268 //if (sqlColumn.Value) 269 //{ 270data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 271 //} 272 } 273 } 274 } 275 } 276 } 277data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 278 class ProposalSqlRecord : SqlRecord 279data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 280 public ProposalSqlRecord(string strTableName) 281 :base(strTableName) 282data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 283 } 284data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 285 protected override void GetSqlValue(SqlColumn sqlColumn,ref string strFront,ref string strValue) 286data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 287 if (string.IsNullOrEmpty(sqlColumn.Refrence)) 288data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 289 base.GetSqlValue(sqlColumn, ref strFront,ref strValue); 290 } 291 else 292data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 293 if (sqlColumn.Refrence.ToLower() == "entryitem") 294data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 295 string paraName = GetNewParaName(); 296 string strFormat = "declare {0} int\n" + 297 "declare {0}_1 int\n" + 298 "select {0}_1=Id from entrybase where name='{2}'\n" + 299 "select {0}=id\n" + 300 "from entrybase \n" + 301 "where name='{1} '\n" + 302 " and id in (select id from entryitem where entrycategory={0}_1)\n" + 303 "if({0} is null)\n" + 304 "begin \n" + 305 " insert into entrybase(Name,fixed) values('{1}',1)\n" + 306 " select {0}=IDENT_CURRENT('entrybase')\n" + 307 " insert into entryitem(id,entrycategory) values({0},{0}_1)\n" + 308 "end\n"; 309 strFront = string.Format(strFormat, paraName, sqlColumn.Value, sqlColumn.Restrict); 310 strValue = paraName; 311 } 312 } 313 } 314 } 315data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 316 class ProposalMemberSqlRecord : SqlRecord 317data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 318 public ProposalMemberSqlRecord(string strTableName) 319 : base(strTableName) 320data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 321 } 322data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 323 protected override void GetSqlValue(SqlColumn sqlColumn, ref string strFront, ref string strValue) 324data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 325 if (string.IsNullOrEmpty(sqlColumn.Refrence)) 326data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 327 base.GetSqlValue(sqlColumn, ref strFront, ref strValue); 328 } 329 else 330data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 331 if (sqlColumn.Refrence.ToLower() == "proposal") 332data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 333 string paraName = GetNewParaName(); 334 string strFormat = "declare {0} int\n" + 335 "select {0}=id \n" + 336 "from proposal \n" + 337 "where ProposalNO='{1}'\n" + 338 "if {0} is null\n" + 339 "print '{1}'\n"; 340 strFront = string.Format(strFormat, paraName, sqlColumn.Value); 341 strValue = paraName; 342 } 343 else if (sqlColumn.Refrence.ToLower() == "MemberOfCongress".ToLower()) 344data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 345 string paraName = GetNewParaName(); 346 string strFormat = "declare {0} int\n" + 347 "select {0}=id \n" + 348 "from memberofcongress \n" + 349 "where name='{1}'\n" + 350 "if {0} is null\n" + 351 "print '{1}'\n"; 352 strFront = string.Format(strFormat, paraName, sqlColumn.Value); 353 strValue = paraName; 354 } 355 } 356 } 357 } 358data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 359 class ProposalDepartmentalismSqlRecord : SqlRecord 360data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 361 public ProposalDepartmentalismSqlRecord(string strTableName) 362 : base(strTableName) 363data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 364 } 365data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="" 366 protected override void GetSqlValue(SqlColumn sqlColumn, ref string strFront, ref string strValue) 367data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 368 if (string.IsNullOrEmpty(sqlColumn.Refrence)) 369data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 370 base.GetSqlValue(sqlColumn, ref strFront, ref strValue); 371 } 372 else 373data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 374 if (sqlColumn.Refrence.ToLower() == "proposal") 375data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 376 string paraName = GetNewParaName(); 377 string strFormat = "declare {0} int\n" + 378 "select {0}=id \n" + 379 "from proposal \n" + 380 "where ProposalNO='{1}'\n" + 381 "if {0} is null\n" + 382 "print '{1}'\n"; 383 strFront = string.Format(strFormat, paraName, sqlColumn.Value); 384 strValue = paraName; 385 } 386 else if (sqlColumn.Refrence.ToLower() == "Departmentalism".ToLower()) 387data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 388 string paraName = GetNewParaName(); 389 string strFormat = "declare {0} int\n" + 390 "select {0}=id \n" + 391 "from Departmentalism \n" + 392 "where name like '{1}'+'%'\n" + 393 "if {0} is null\n" + 394 "print '{1}'\n"; 395 strFront = string.Format(strFormat, paraName, sqlColumn.Value); 396 strValue = paraName; 397 } 398 else if (sqlColumn.Refrence.ToLower() == "entryitem") 399data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" { 400 string paraName = GetNewParaName(); 401 string strFormat = "declare {0} int\n" + 402 "declare {0}_1 int\n" + 403 "select {0}_1=Id from entrybase where name='{2}'\n" + 404 "select {0}=id\n" + 405 "from entrybase \n" + 406 "where name='{1} '\n" + 407 " and id in (select id from entryitem where entrycategory={0}_1)\n" + 408 "if({0} is null)\n" + 409 "begin \n" + 410 " insert into entrybase(Name,fixed) values('{1}',1)\n" + 411 " select {0}=IDENT_CURRENT('entrybase')\n" + 412 " insert into entryitem(id,entrycategory) values({0},{0}_1)\n" + 413 "end\n"; 414 strFront = string.Format(strFormat, paraName, sqlColumn.Value, sqlColumn.Restrict); 415 strValue = paraName; 416 } 417 } 418 } 419 } 420 } 421data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
|