引言
在项目中需要用到动态在数据库中动态的创建新表的需求,所以需要我们在代码中完成建表的功能,这个需求
对于自己来说是比较新鲜的,原先自己接触的东西都是在已有的数据库的基础上进行操作的,没有用到过动态建表的
功能,所以对这一块的代码是比较感兴趣的,下面和大家分享这一块的知识;
调用代码
<span style="font-size:18px;"> List<string> listNewTableName = new List<string>();
for (int i = 0; i < listCourseQuestionType.Count(); i++)
{
listNewTableName.Add(listCourseQuestionType[i].AnswerRecordMappingTableName.ToString());
}
//拿到我们新建表中的字段
List<Dictionary<string, string>> listFields = AnswerRecordFields(listCourseQuestionType.Count());
dynamicCreationBLL.CreateDataTable("ITOOExam", listNewTableName, listFields, "ITOOExamEntities"); //QuestionEntities</span>
创建多个表 的表结构 及其数据类型
<span style="font-size:18px;"> /// <summary>
/// 创建多个表 的表结构 及其数据类型
/// </summary>
/// <param name="DictionaryCount"></param>
/// <returns></returns>
public List<Dictionary<string, string>> AnswerRecordFields(int DictionaryCount)
{
List<Dictionary<string, string>> listDictionary = new List<Dictionary<string, string>>();
for (int i = 0; i < DictionaryCount; i++)
{
listDictionary.Add(AnswerRecordField());
}
return listDictionary;
}</span>
创建一个答题记录表的字段及其数据类型
<span style="font-size:18px;"> /// <summary>
/// 创建一个答题记录表 的 字段及其数据类型
/// </summary>
/// <returns></returns>
public Dictionary<string, string> AnswerRecordField()
{
Dictionary<string, string> field = new Dictionary<string, string>();
field.Add("answerRecordId", "varchar(40)");
field.Add("examineeId", "varchar(40)");
field.Add("rightAnswer", "varchar(max)");
field.Add("examineeAnswer", "varchar(max)");
field.Add("finalScore", "decimal(5,2)");
field.Add("examineeIsJudgment", "int");
field.Add("questionId", "varchar(40)");
field.Add("questionNoOrder", "varchar(10)");
field.Add("optionNoOrder", "varchar(10)");
field.Add("userId", "varchar(40)");
field.Add("timeStamp", "DateTime default getdate() ");
field.Add("reUserId", "varchar(40)");
field.Add("isReJudge", "int");
field.Add("reJudgeScore", "decimal(5,2)");
field.Add("preScore", "decimal(5,2)");
field.Add("IsDeleteAnswerRecord", "int");
field.Add("ExamId", "varchar(40)");
field.Add("CollegeId", "varchar(40)"); //学院ID
field.Add("OnClassId", "varchar(40)");//上课班ID
field.Add("OnClassName", "varchar(40)");//上课班name
field.Add("CollegeName", "varchar(40)");//学院name
return field;
}</span>
建表方法
<span style="font-size:18px;"> /// <summary>
/// 在指定的数据库中,创建数据表
/// </summary>
/// <param name="db">指定的数据库</param>
/// <param name="listDt">要创建的数据表集合</param>
/// <param name="dic">数据表中的字段及其数据类型 Dictionary集合</param>
/// <param name="connKey">数据库的连接Key</param>
public void CreateDataTable(string db, List<string> listDt, List<Dictionary<string, string>> dic, string connKey)
{
SQLHelper helper = new SQLHelper(connKey);
string connToMaster = ConfigurationManager.ConnectionStrings[connKey].ToString();
//判断数据库是否存在
if (IsDBExist(db, connKey) == false)
{
throw new Exception("数据库不存在!");
}
for (int i = 0; i < listDt.Count(); i++)
{
//如果数据库表存在,则抛出错误
if (IsTableExist(db, listDt[i], connKey) == true)
{
//如果数据库表已经存在,则跳过该表
continue;
}
else//数据表不存在,创建数据表
{
//其后判断数据表是否存在,然后创建数据表
string createTableStr = PinjieSql(db, listDt[i], dic[i]);
helper.ExecuteNonQuery(createTableStr, CommandType.Text);
}
}
}</span>
判断数据库是否存在和数据库中表是否存在的方法,见上一篇博客
拼接创建数据库表的Sql语句
<span style="font-size:18px;"> /// <summary>
/// 拼接创建数据库表的Sql语句
/// </summary>
/// <param name="db">指定的数据库</param>
/// <param name="dt">要创建的数据表</param>
/// <param name="dic">数据表中的字段及其数据类型</param>
/// <returns>拼接完的字符串</returns>
public string PinjieSql(string db, string dt, Dictionary<string, string> dic)
{
//拼接字符串,(该串为创建内容)
string content = "serial int identity(1,1) primary key ";
//取出dic中的内容,进行拼接
List<string> test = new List<string>(dic.Keys);
for (int i = 0; i < dic.Count(); i++)
{
content = content + " , " + test[i] + " " + dic[test[i]];
}
//其后判断数据表是否存在,然后创建数据表
string createTableStr = "use " + db + " create table " + dt + " (" + content + ")";
return createTableStr;
}</span>
小结
在接触到大项目之后发现自己知道的东西真的是太少了,有很多的东西都没有接触过,自己认为不能实现的东西在
别人哪已经非常成熟的实现了,所以当我们遇到难题的时候需要多看一些资料