动态批量新建SQL数据库中的表

简介: 动态批量新建SQL数据库中的表

引言


在项目中需要用到动态在数据库中动态的创建新表的需求,所以需要我们在代码中完成建表的功能,这个需求对于自己来说是比较新鲜的,原先自己接触的东西都是在已有的数据库的基础上进行操作的,没有用到过动态建表的功能,所以对这一块的代码是比较感兴趣的,下面和大家分享这一块的知识;


调用代码

<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>


小结


在接触到大项目之后发现自己知道的东西真的是太少了,有很多的东西都没有接触过,自己认为不能实现的东西在别人哪已经非常成熟的实现了,所以当我们遇到难题的时候需要多看一些资料,多和别人交流,多看别人的代码。这

样也许会给我一些灵感,让我们在迷茫中找到方向,所以我们需要在项目中继续学习!!


目录
相关文章
|
3月前
|
SQL 机器学习/深度学习 人工智能
从“写SQL”到“聊数据”:NL2SQL如何用自然语言解锁数据库?
本文系统性地阐述了自然语言转SQL(NL2SQL) 技术如何让非技术背景的业务分析师实现数据自助查询,从而提升数据驱动决策的效率与准确性。
从“写SQL”到“聊数据”:NL2SQL如何用自然语言解锁数据库?
|
2月前
|
SQL 人工智能 Linux
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
320 5
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
|
1月前
|
SQL 存储 监控
SQL日志优化策略:提升数据库日志记录效率
通过以上方法结合起来运行调整方案, 可以显著地提升SQL环境下面向各种搜索引擎服务平台所需要满足标准条件下之数据库登记作业流程综合表现; 同时还能确保系统稳健运行并满越用户体验预期目标.
160 6
|
2月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
|
2月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
2月前
|
SQL Oracle 关系型数据库
Oracle数据库创建表空间和索引的SQL语法示例
以上SQL语法提供了一种标准方式去组织Oracle数据库内部结构,并且通过合理使用可以显著改善查询速度及整体性能。需要注意,在实际应用过程当中应该根据具体业务需求、系统资源状况以及预期目标去合理规划并调整参数设置以达到最佳效果。
243 8
|
3月前
|
SQL 人工智能 Java
用 LangChain4j+Ollama 打造 Text-to-SQL AI Agent,数据库想问就问
本文介绍了如何利用AI技术简化SQL查询操作,让不懂技术的用户也能轻松从数据库中获取信息。通过本地部署PostgreSQL数据库和Ollama模型,结合Java代码,实现将自然语言问题自动转换为SQL查询,并将结果以易懂的方式呈现。整个流程简单直观,适合初学者动手实践,同时也展示了AI在数据查询中的潜力与局限。
376 8
|
3月前
|
SQL 人工智能 Linux
SQL Server 2025 RC0 发布 - 从本地到云端的 AI 就绪企业数据库
SQL Server 2025 RC0 发布 - 从本地到云端的 AI 就绪企业数据库
248 5
|
2月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。
|
4月前
|
SQL 缓存 监控
SqlRest让SQL秒变Http API,还支持20+数据库(含国产数据库)
杭州奥零数据科技有限公司成立于2023年,专注于数据中台业务,维护开源项目AllData并提供商业版解决方案。AllData提供数据集成、存储、开发、治理及BI展示等一站式服务,支持AI大模型应用,助力企业高效利用数据价值。