插入空值并返回ID的问题终于解决

上次存储过程那个问题终于解决了,哎

SQL语句产生的数据集要用Cmd.ExecuteReader()读取,怎么看执行一条SQL语句后产生的是数据集,个人感觉是查询出来的是一个表格的形式就是数据集,读取这些信息的话就用Cmd.ExecuteReader().

就上次的需求代码如下:

存储过程:

 

 
  
drop proc Reader
go
create procedure Reader
@dtname varchar ( 50 )
as
declare @sqlcmd varchar ( 100 )
set @sqlcmd = ' insert into ' + @dtname + ' default values select SCOPE_IDENTITY() '
exec ( @sqlcmd )

 C#代码: 

SqlConnection con = new SqlConnection("Data Source=.;Initial Catalog=Test;Integrated Security=True");
con.Open();
SqlCommand cmd
= new SqlCommand("Reader",con);
cmd.CommandType
= CommandType.StoredProcedure;
cmd.Parameters.AddWithValue(
"@dtname","Student");
SqlDataReader reader
= cmd.ExecuteReader();
while (reader.Read())
{
Console.WriteLine(reader[
0].ToString());
}
Console.ReadKey();

 这样就可以向一个表中插入一条空的记录并返回这条记录的ID值,嘎嘎

另外还有几个SQL语句比较有意思:

(1) 获取SQL中的所有数据库:

     exec sp_helpdb
     执行后会产生一个结果集(以表形式出现)
     如何用C#代码调用的话

 

 
  
SqlDataReader reader = Cmd.ExecuteReader()
while (reader.Read())
{
combobox.items.add(reader[
0 ].Tostring());
}

reader.Close();

 

 

(2)获取数据库中的所有表,除去系统表,这个可以通过判断

   SQL语句:SELECT name FROM sysobjects WHERE type = 'U' and name<>'dtproperties'

   C#代码:

 

 
  
SqlDataAdapter da = new SqlDataAdapter(
  " SELECT name FROM sysobjects WHERE type = 'U' and name<>'dtproperties' " , DBcon);
DataTable dt
= new DataTable( " sysobjects " );
da.Fill(dt);
listBox1.DataSource
= dt.DefaultView;

 

转载于:https://www.cnblogs.com/wangshuai/archive/2009/12/30/1635692.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值