《aso.net项目开发案例全程实录》数据库连接不上的问题,急求帮助!急急急!
发表在ASP.NET图书答疑 2011-12-19
是否精华
版块置顶:
《aso.net项目开发案例全程实录》数据库连接不上的问题,急求帮助!
我要开发一个小项目,因为手还生,就买这本书做参考,但将第一章目录拷到硬盘中,并且也按照光盘中的安装视频所示的都做到了,但一运行01目录中的供求信息网中dafault.aspx,就提示出现登录数据库错误!详细错误情况在下面列出!
我的系统是xp sp3,.net开发环境是 vs2005,数据库是2005sql express!
但奇怪的是,我也附加了数据库,也修改了web.config中的连接字符串,而且在sql中和vs2005的“服务资源管理器”中的db_SIS.mdf数据库都能打开,就是在运行文件时报错,还有,当sql能打开数据库时,如果一旦运行vs2005环境下01中的dafault.aspx后就提示数据库已被另一个进程占用,然后在打开sql中的db_SIS数据库原本能访问的现在就又报错了,真是太奇怪了。
我在网上搜了两天,我也研究了两天,但仍然无法解决问题,都急死我了,所以才来急求老师们能帮我解决实际问题,在此表示真心感谢,为了能让老师们更好的诊断问题,能快速的帮我解决问题,我尽可能的把错误信息和截图都放山来!再次急请老师们救火啊!
怎么上传附件不能使啊,这是怎么回事呢?只能在下面列出文字了!

1、s2005运行default.aspx出错信息:
“/SIS”应用程序中的服务器错误。
--------------------------------------------------------------------------------

无法打开登录所请求的数据库 "db_SIS"。登录失败。
用户 'sa' 登录失败。 
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。 

异常详细信息: System.Data.SqlClient.SqlException: 无法打开登录所请求的数据库 "db_SIS"。登录失败。
用户 'sa' 登录失败。

源错误: 


行 36:         }
行 37:         if (con.State == System.Data.ConnectionState.Closed)
行 38:             con.Open();
行 39: 
行 40:     }
 

源文件: d:\TM\01\SIS\App_Code\DataBase.cs    行: 38 

堆栈跟踪: 


[SqlException (0x80131904): 无法打开登录所请求的数据库 "db_SIS"。登录失败。
用户 'sa' 登录失败。]
   System.Data.SqlClient.SqlInternalConnection.OnError(SqlException exception, Boolean breakConnection) +171
   System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning(TdsParserStateObject stateObj) +199
   System.Data.SqlClient.TdsParser.Run(RunBehavior runBehavior, SqlCommand cmdHandler, SqlDataReader dataStream, BulkCopySimpleResultSet bulkCopyHandler, TdsParserStateObject stateObj) +2300
   System.Data.SqlClient.SqlInternalConnectionTds.CompleteLogin(Boolean enlistOK) +34
   System.Data.SqlClient.SqlInternalConnectionTds.OpenLoginEnlist(SqlConnection owningObject, SqlConnectionString connectionOptions, String newPassword, Boolean redirectedUserInstance) +606
   System.Data.SqlClient.SqlInternalConnectionTds..ctor(DbConnectionPoolIdentity identity, SqlConnectionString connectionOptions, Object providerInfo, String newPassword, SqlConnection owningObject, Boolean redirectedUserInstance) +193
   System.Data.SqlClient.SqlConnectionFactory.CreateConnection(DbConnectionOptions options, Object poolGroupProviderInfo, DbConnectionPool pool, DbConnection owningConnection) +502
   System.Data.ProviderBase.DbConnectionFactory.CreatePooledConnection(DbConnection owningConnection, DbConnectionPool pool, DbConnectionOptions options) +28
   System.Data.ProviderBase.DbConnectionPool.CreateObject(DbConnection owningObject) +429
   System.Data.ProviderBase.DbConnectionPool.UserCreateRequest(DbConnection owningObject) +70
   System.Data.ProviderBase.DbConnectionPool.GetConnection(DbConnection owningObject) +510
   System.Data.ProviderBase.DbConnectionFactory.GetConnection(DbConnection owningConnection) +85
   System.Data.ProviderBase.DbConnectionClosed.OpenConnection(DbConnection outerConnection, DbConnectionFactory connectionFactory) +89
   System.Data.SqlClient.SqlConnection.Open() +160
   DataBase.Open() in d:\TM\01\SIS\App_Code\DataBase.cs:38
   DataBase.CreateDataAdaper(String procName, SqlParameter[] prams) in d:\TM\01\SIS\App_Code\DataBase.cs:184
   DataBase.RunProcReturn(String procName, String tbName) in d:\TM\01\SIS\App_Code\DataBase.cs:165
   Operation.SelectLeaguerInfo(Boolean All, String infoType, Int32 top) in d:\TM\01\SIS\App_Code\Operation.cs:232
   _Default.Page_Load(Object sender, EventArgs e) in d:\TM\01\SIS\Default.aspx.cs:19
   System.Web.Util.CalliHelper.EventArgFunctionCaller(IntPtr fp, Object o, Object t, EventArgs e) +13
   System.Web.Util.CalliEventHandlerDelegateProxy.Callback(Object sender, EventArgs e) +45
   System.Web.UI.Control.OnLoad(EventArgs e) +80
   System.Web.UI.Control.LoadRecursive() +49
   System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +3745

 


--------------------------------------------------------------------------------
版本信息: Microsoft .NET Framework 版本:2.0.50727.42; ASP.NET 版本:2.0.50727.42 


2、以下为sql express出现错误的提示:
由于文件不可访问,或者内存或磁盘空间不足,所以无法打开数据库 'D:\TM\01\SIS\APP_DATA\DB_SIS.MDF'。有关详细信息,请参阅 SQL Server 错误日志。 (.Net SqlClient Data Provider)

------------------------------
有关帮助信息,请单击: http://go.microsoft.com/fwlink?ProdName=Microsoft+SQL+Server&ProdVer=09.00.4035&EvtSrc=MSSQLServer&EvtID=945&LinkId=20476

------------------------------
服务器名称: HP-PC\SQLEXPRESS
错误号: 945
严重性: 14
状态: 2
行号: 1


------------------------------
程序位置:

   在 System.Data.SqlClient.SqlConnection.OnError(SqlException exception, Boolean breakConnection)
   在 System.Data.SqlClient.SqlInternalConnection.OnError(SqlException exception, Boolean breakConnection)
   在 System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning(TdsParserStateObject stateObj)
   在 System.Data.SqlClient.TdsParser.Run(RunBehavior runBehavior, SqlCommand cmdHandler, SqlDataReader dataStream, BulkCopySimpleResultSet bulkCopyHandler, TdsParserStateObject stateObj)
   在 System.Data.SqlClient.SqlDataReader.ConsumeMetaData()
   在 System.Data.SqlClient.SqlDataReader.get_MetaData()
   在 System.Data.SqlClient.SqlCommand.FinishExecuteReader(SqlDataReader ds, RunBehavior runBehavior, String resetOptionsString)
   在 System.Data.SqlClient.SqlCommand.RunExecuteReaderTds(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, Boolean async)
   在 System.Data.SqlClient.SqlCommand.RunExecuteReader(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, String method, DbAsyncResult result)
   在 System.Data.SqlClient.SqlCommand.RunExecuteReader(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, String method)
   在 System.Data.SqlClient.SqlCommand.ExecuteReader(CommandBehavior behavior, String method)
   在 System.Data.SqlClient.SqlCommand.ExecuteDbDataReader(CommandBehavior behavior)
   在 System.Data.Common.DbCommand.System.Data.IDbCommand.ExecuteReader(CommandBehavior behavior)
   在 System.Data.Common.DbDataAdapter.FillInternal(DataSet dataset, DataTable[] datatables, Int32 startRecord, Int32 maxRecords, String srcTable, IDbCommand command, CommandBehavior behavior)
   在 System.Data.Common.DbDataAdapter.Fill(DataSet dataSet, Int32 startRecord, Int32 maxRecords, String srcTable, IDbCommand command, CommandBehavior behavior)
   在 System.Data.Common.DbDataAdapter.Fill(DataSet dataSet)
   在 Microsoft.SqlServer.Management.Common.ServerConnection.ExecuteWithResults(String sqlCommand)



3、web.config中的修改后连接字符串:
<configuration>
<appSettings/>
  <connectionStrings>
    <add name="ConStr" connectionString="Server=HP-PC\SQLEXPRESS;DataBase=db_SIS;UID=sa;PWD=123456"/>
  </connectionStrings>
其中HP-PC\SQLEXPRESS是数据库存在的电脑名,这个是没错了,因为我测试连接正常!
分享到:
精彩评论 1
东方_mrkj
学分:0 LV1
2011-12-22
沙发
读者你好:
   尝试把web.config (配置文件)中的连接数据库的代码修改为下面的这种形式:
  <add key="ConnectionString" value="serverlocalhost\sqlexpress;uid=sa;pwd=111;database=News"/>
首页上一页 1 下一页尾页 1 条记录 1/1页
手机同步功能介绍
友情提示:以下图书配套资源能够实现手机同步功能
明日微信公众号
明日之星 明日之星编程特训营
客服热线(每日9:00-17:00)
400 675 1066
mingrisoft@mingrisoft.com
吉林省明日科技有限公司Copyright ©2007-2022,mingrisoft.com, All Rights Reserved长春市北湖科技开发区盛北大街3333号长春北湖科技园项目一期A10号楼四、五层
吉ICP备10002740号-2吉公网安备22010202000132经营性网站备案信息 营业执照