【ITOO 2】.NET 动态建库建表:使用SQL字符串拼接方式
导读:在最近接手的项目(高效云平台)中,有一个需求是要当企业用户注册时,给其动态的新建一个库和表。刚开始接手的时候,是一点头绪都没有,然后查了一些资料,也问了问上一版本的师哥师姐,终于有了点头绪。目前是有两种方案,第一:应用SQL字符串拼接;第二,使用codeFirst。现在,总结第一种方案。
一、总体概述
既然是使用SQL字符串拼接,那么就涉及到我们操作SQL 创建数据库和表的逻辑了。当我们建库的时候,需要判断这个库是否存在,然后是不存在则创建。同理,建表也是如此。所以,在这里就涉及到了4个方法:1,判断欲建的数据库是否存在;2,判断欲建的表单是否存在;3,建库;4,建表。
在写好了这四个方法之后,就是对于方法的调用。
二、具体代码实例
2.1,判断数据库是否存在
<span style="font-family:KaiTi_GB2312;font-size:18px;">/// <summary>
/// 是否存在将要创建的数据库
/// </summary>
/// <param name="strDatabaseName">数据库名称</param>
/// <param name="strDbIP">数据库服务器连接地址</param>
/// <returns>存在返回true,不存在返回false</returns>
private bool isExsitDatabase(string strDatabaseName,string strDbIP)
{
SqlConnection conn = new SqlConnection(strDbIP);
conn.Open();
string strSql = " select * from master.dbo.sysdatabases where name " + "= '" + strDatabaseName + "'"; ;
SqlCommand cmd=new SqlCommand(strSql,conn);
SqlDataReader sdr = null;
DataTable dt = new DataTable();
using (sdr=cmd.ExecuteReader(CommandBehavior.CloseConnection))
{
dt.Load(sdr);
}
if (dt.Rows.Count > 0)
{
return true;
}
else {
return false;
}
}</span>
2.2,判断表单是否存在
<span style="font-family:KaiTi_GB2312;font-size:18px;"> /// <summary>
/// 是否存在欲要建立的表单
/// </summary>
/// <param name="StrDatabaseName">数据库名称</param>
/// <param name="strDbIP">数据库服务器连接地址</param>
/// <param name="strTableName">将要建立的表单名称</param>
/// <returns>存在返回true,不存在返回false</returns>
private bool isExsitTable(string StrDatabaseName, string strDbIP, string strTableName) {
SqlConnection conn = new SqlConnection(strDbIP);
conn.Open();
string strSQL = "use " + StrDatabaseName + " select 1 from sysobjects where id = object_id('" + strTableName + "') and type ='U'";
SqlCommand cmd = new SqlCommand(strSQL, conn);
int res = cmd.ExecuteNonQuery();
DataTable dt = new DataTable();
SqlDataReader sdr = null;
using (sdr=cmd.ExecuteReader(CommandBehavior.CloseConnection))
{
dt.Load(sdr);
}
if (dt.Rows.Count > 0)
{
return true;
}
else {
return false;
}
}</span>
2.3,建库
<span style="font-family:KaiTi_GB2312;font-size:18px;"> /// <summary>
/// 创建一个新库
/// </summary>
/// <param name="strDatabaseName">数据库名称</param>
/// <param name="strDbIP">数据库连接地址</param>
private void CreateDatabase(string strDatabaseName, string strDbIP) {
bool flag = isExsitDatabase(strDatabaseName, strDbIP);
if (flag == true)
{
throw new Exception("当前数据库已经存在,无法重复创建");
}
else
{
string strSQL = "Create database " + strDatabaseName;
SqlConnection conn = new SqlConnection(strDbIP);
conn.Open();
SqlCommand cmd = new SqlCommand(strSQL, conn);
cmd.ExecuteNonQuery();
conn.Close(); }
}</span>
2.4,建表
<span style="font-family:KaiTi_GB2312;font-size:18px;">/// <summary>
/// 在指定的数据库中创建表单
/// </summary>
/// <param name="strDatabaseName">数据库名称</param>
/// <param name="strDbIP">数据库连接地址</param>
/// <param name="strTableName">表单名称</param>
/// <param name="dic">表单内容</param>
private void CreateTable(string strDatabaseName, string strDbIP, string strTableName,Dictionary<string ,string >dic) {
bool flag = isExsitDatabase(strDatabaseName, strDbIP);
if (flag == false)
{
throw new Exception("当前数据库不存在存在,请先创建数据库");
}
if (isExsitTable(strDatabaseName,strDbIP,strTableName)==true)
{
throw new Exception("当前表单已经存在,请修改!");
}
else
{
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 strSQL = "use " + strDatabaseName + " create table " + strTableName + "(" + content + ")";
SqlConnection conn = new SqlConnection(strDbIP);
conn.Open();
SqlCommand cmd = new SqlCommand(strSQL, conn);
cmd.ExecuteNonQuery();
conn.Close();
}
}</span>
2.4,具体应用
建表:
<span style="font-family:KaiTi_GB2312;font-size:18px;"> protected void btnCreateTable_Click(object sender, EventArgs e)
{
string strDefaultIP = TextBox1.Text;
string strMyIP = TextBox2.Text;
string strDatabaseName = "AngelTest";
string strConnMine = "data source=" + "**********" + "; initial catalog=" + strDatabaseName + " ;" + "persist security info=True;user id=sa;password=*******";
Dictionary<string, string> dic = new Dictionary<string, string>();
dic.Add("sex ", " varchar(2)");
dic.Add("name ", " varchar(8)");
string strTableName = "TestTable";
CreateTable(strDatabaseName,strConnMine,strTableName,dic); }</span>
建库:和建表差不多,就不展示了。
三、总结
如果说是用这种方式实现一个动态建库建表的话,这根本就不是什么新奇的东西。以前都学过这些,但是为什么自己一直还都不会熟练的应用,这是一个问题。接下来的博客,会介绍使用EF的codefirst方式,实现动态建库建表。
【ITOO 2】.NET 动态建库建表:使用SQL字符串拼接方式的更多相关文章
- 【ITOO 3】.NET 动态建库建表:实用EF框架提供的codeFirst实现动态建库
导读:在上篇博客中,介绍了使用SQL字符拼接的方式,实现动态建库建表的方法.这样做虽然也能够实现效果,但是,太麻烦,而且,如果改动表结构,字段的话,会对代码修改很多.但是EF给我们提供了一种代码先行的 ...
- MySQL建库建表
一直使用SQL SERVER 数据库:最近项目使用MY SQL感觉还是有一点不适应.不过熟悉之后就会好很多. MY SQL 安装之后会有一个管理工具MySQL Workbench 感觉不太好用,数据库 ...
- SQL Server建库-建表-建约束
----------------------------------------SQL Server建库-建表-建约束创建School数据库------------------------------ ...
- 使用T-sql建库建表建约束
为什么要使用sql语句建库建表? 现在假设这样一个场景,公司的项目经过测试没问题后需要在客户的实际环境中进行演示,那就需要对数据进行移植,现在问题来了:客户的数据库版本和公司开发阶段使用的数据库不兼容 ...
- mysql那些事(4)建库建表编码的选择
mysql建数据库或者建表的时候会遇到选择编码的问题,以前我们都是习惯性的选择utf8,但是在mysql在5.5.3版本后加了utf8mb4的编码,utf8mb4可以存4个字节Unicode,mb4就 ...
- C# 利用*.SQL文件自动建库建表等的类
/// <summary> /// 自动建库建表 /// </summary> public class OperationSqlFile { SqlConnection sq ...
- Mysql建库建用户建表等常用命令
格式: mysql -h主机地址 -u用户名 -p用户密码 1.连接到本机上的MYSQL.首先打开DOS窗口,然后进入目录mysql\bin,再键入命令mysql -u root -p,回车后提示你输 ...
- oracle 11g 建库 建表 增 删 改 查 约束
一.建库 1.(点击左上角带绿色+号的按钮) 2.(进入这个界面,passowrd为密码.填写完后点击下面一排的Test按钮进行测试,无异常就点击Connect) 二.建表 1-1. create t ...
- MySql 建库建表脚本
1.建库 CREATE DATABASE test DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci; 2.建表脚本 CREATE TABLE `c ...
随机推荐
- 485 Max Consecutive Ones 最大连续1的个数
给定一个二进制数组, 计算其中最大连续1的个数.示例 1:输入: [1,1,0,1,1,1]输出: 3解释: 开头的两位和最后的三位都是连续1,所以最大连续1的个数是 3.注意: 输入的数组只包 ...
- scau 17967 大师姐唱K的固有结界 分类暴力 + RMQ
由于能放两次,那么分类, 1.连续使用,(这个直接O(n^2)暴力) 2.分开使用. 分开使用的话,首先暴力枚举,用T时间,能从第1个位置,唱到第几首歌,然后剩下的就是从pos + 1, n这个位置, ...
- .net core区域设置方式
在Startup中配置 默认路由是这个,并不包含区域路由 routes.MapRoute( name: "default", template: "{controller ...
- Jenkins视图使用--添加删除视图
job建立的特别多的时候,我们可能不太容易找到自己的某个job,这时,我们就可以在Jenkins中建立视图.job的视图类似于我们电脑上的文件夹.可以通过一些过滤规则,将已经建好的job过滤到视图中, ...
- ios水果风暴游戏源码项目下载
这是一款ios水果风暴游戏源码下载,介绍给大家一下,喜欢的朋友可以下载学习一下吧.应用介绍:这是一个以获得高分和挑战更高难度为目的的游戏.游戏中有九种不同的卡通水果,您可以交换屏幕中两个相邻水果的位置 ...
- 洛谷 P1765 手机_NOI导刊2010普及(10)
题目描述 一般的手机的键盘是这样的: 1 2 abc 3 def 4 ghi 5 jkl 6 mno 7 pqrs 8 tuv 9 wxyz * 0 # 要按出英文字母就必须要按数字键多下.例如要按出 ...
- Mysql数据库表的迁移和表的复制
同一台服务器上的,数据库之间的表的迁移: create table db.tablename as select * from db2.tablename; 此sql使用于mysql,从一台服务器上的 ...
- windows常用bat脚本
windows常用bat脚本 https://blog.csdn.net/longyan_csc/article/details/78737722 Windows_批处理+任务计划实现文件夹定时备份 ...
- EEPROM的存储大小
学习单片机时,常见的EEPROM如24C02的大小为2Kbit(有的也称2KB).这里的2KB到底能存储多少数据呢? 2KB中,B表示单位bit,K表示1024. 单片机编程中常用的数据类型为unsi ...
- JavaEE-02 JSP数据交互01
学习要点 request对象 response对象 转发与重定向 session对象 include指令 课程回顾 需求描述:编写JSP页面,计算2000—3000年中存在几个闰年. 实现分析:判断闰 ...