为什么此代码不起作用以及如何检查数据库中是否存在表

问题描述

|| 我正在尝试在页面加载时创建数据库表。我尝试了这段代码
System.Data.sqlClient.sqlConnection conn2 = new System.Data.sqlClient.sqlConnection(@\"connectionstring\");

string user2 = Page.User.Identity.Name + \"imgs\";
System.Data.sqlClient.sqlCommand ccmd = new System.Data.sqlClient.sqlCommand(\"CREATE TABLE \'\" + user2 + \"\' (id INT NOT NULL IDENTITY(1,1) PRIMARY KEY,img VARCHAR(225))\",conn2);
conn2.open();
ccmd.ExecuteNonQuery();
conn2.Close();
...但这对我不起作用。我究竟做错了什么? 另外-如何检查数据库中是否存在表?我正在使用asp.net 3.5     

解决方法

        改变这个;
CREATE TABLE \'\" + user2 + \"\' 
(id INT NOT NULL IDENTITY(1,1) 
PRIMARY KEY,img VARCHAR(225))
CREATE TABLE \" + user2 + \" 
(id INT NOT NULL IDENTITY(1,img VARCHAR(225))
    ,        要检查MSSQL中是否存在表,可以使用此表(示例表名称为\'users \'):
IF EXISTS 
(    SELECT TABLE_NAME 
     FROM INFORMATION_SCHEMA.TABLES 
     WHERE TABLE_NAME = \'users\'
) 
    DROP TABLE users;
...或者事后要做对表的任何操作,而不仅仅是将其明显删除。