100165617.htm

来自「C#高级编程(第三版),顶死你们。。 。up」· HTM 代码 · 共 127 行 · 第 1/2 页

HTM
127
字号


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head><title>
	
        21.9.2  SQL Server的键生成
</title></head>
<body>
    <div class="area">

        

        <div class="col1">
            <div class="lineBlue">
            </div>
            <!-- title -->
            <div class="arcTitle">
                <h1>
                    <a href="../16">
                        C#高级编程(第3版)
                    </a>
                </h1>
                <div style="text-align: center; font-size: 15px">
                    <a href="100165617.htm">
                        21.9.2  SQL Server的键生成
                    </a>
                </div>
                <div style="text-align: center; font-size: 15px">
                    <a class="url" href="../../default.htm">http://book.csdn.net/</a>
                    2006-10-13 14:41:00
                </div>
                <div style="margin: 0px auto; width: 700px; border: solid 1px #0b5f98;">
                    <div style="float: left; width: 16px; background-color: #0b5f98; color: White; padding: 1px;">
                        图书导读
                    </div>
                    <div style="float: right; width: 670px; text-align: left; line-height: 16pt; padding-left: 2px">
                        <!--导读-->
                        <h1 id="divCurrentNode" style="color: #b83507; width: 100%; text-align: left; font-size: 12px; padding-left: 2px">当前章节:<a href='100165617.htm'><font color='red'>21.9.2  SQL Server的键生成</font></a></h1>
                        <div id="divRelateNode" style="padding-left: 2px">
                        <div style='float:left;width:49%'>·<a href='100165614.htm'>21.8.2  写入XML输出结果</a></div><div style='float:right;width:49%'>·<a href='100165615.htm'>21.9  使用ADO.NET</a></div><div style='float:left;width:49%'>·<a href='100165616.htm'>21.9.1  分层开发</a></div><div style='float:right;width:49%'>·<a href='100165618.htm'>21.9.3  命名约定</a></div><div style='float:left;width:49%'>·<a href='100165619.htm'>21.10  小结</a></div><div style='float:right;width:49%'>·<a href='100165620.htm'>22.1  DataGrid控件</a></div></div>
                    </div>
                </div>
                </div>
            <!-- main -->
            <div id="main">
                <div id="text">
                  <div id="csdn_zhaig_ad_yahoo_2"></div>
                  
                 <link href="css.css" rel="stylesheet" type="text/css" /><h3 style="MARGIN-TOP: 8.15pt; MARGIN-LEFT: 0cm; MARGIN-RIGHT: 0cm; FTEL: 8.15pt"><a ftel="_Toc507815174"><span lang="EN-GB">21.9.2 &nbsp;SQL Server</span></a><span style="FONT-FAMILY: 黑体">的键生成</span></h3>
<p class="MsoNormal"><a ftel="SQLServerkeys"><span style="FONT-FAMILY: 宋体">本章前面给出的</span><span lang="EN-US">RegionInsert</span></a><span style="FONT-FAMILY: 宋体">存储过程在给数据库插入数据时生成了一个主键码值。生成该键的方法相当原始,没有很好地考虑,真正的应用程序应利用生成键的其他策略。</span></p>
<p class="MsoNormal"><span style="FONT-FAMILY: 宋体">首先要定义一个</span><span lang="EN-US">Identity</span><span style="FONT-FAMILY: 宋体">列,从存储过程中返回</span><span lang="EN-US" style="FONT-SIZE: 9pt">@@</span><span lang="EN-US">IDENTITY</span><span style="FONT-FAMILY: 宋体">值。下面的存储过程显示了如何为</span><span lang="EN-US">Northwind</span><span style="FONT-FAMILY: 宋体">示例数据库中的</span><span lang="EN-US">Categories</span><span style="FONT-FAMILY: 宋体">表定义该值。在</span><span lang="EN-US">SQL Query Analyzer</span><span style="FONT-FAMILY: 宋体">中输入这个存储过程,或者运行下载代码中的</span><span lang="EN-US">StoredProcs.sql</span><span style="FONT-FAMILY: 宋体">文件:</span></p>
<p class="2" style="MARGIN-TOP: 8.15pt; MARGIN-LEFT: 21.45pt; MARGIN-RIGHT: 0cm; FTEL: 18.45pt"><a ftel="IDENTITY"><span lang="EN-US">CREATE PROCEDURE CategoryInsert(@CategoryName NVARCHAR(15),</span></a></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; FTEL: 18.45pt"><span lang="EN-US">&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;@Description NTEXT,</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; FTEL: 18.45pt"><span lang="EN-US">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; @CategoryID INTEGER OUTPUT) AS</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; FTEL: 18.45pt"><span lang="EN-US">&nbsp;&nbsp; SET NOCOUNT OFF</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; FTEL: 18.45pt"><span lang="EN-US">&nbsp;&nbsp; INSERT INTO Categories (CategoryName, Description)</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; FTEL: 18.45pt"><span lang="EN-US">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; VALUES(@CategoryName, @Description)</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; FTEL: 18.45pt"><span lang="EN-US">&nbsp;&nbsp; SELECT @CategoryID = @@IDENTITY</span></p>
<p class="2" style="MARGIN-TOP: 0cm; MARGIN-LEFT: 21.45pt; MARGIN-RIGHT: 0cm; FTEL: 18.45pt"><span lang="EN-US">GO</span></p>
<p class="MsoNormal"><span style="FONT-FAMILY: 宋体">这将把一个新行插入到</span><span lang="EN-US">Category</span><span style="FONT-FAMILY: 宋体">表中,给调用者返回生成的主键码</span><span lang="EN-US">(CategoryID</span><span style="FONT-FAMILY: 宋体">列的值</span><span lang="EN-US">)</span><span style="FONT-FAMILY: 宋体">。在</span><span lang="EN-US">Query Analyzer</span><span style="FONT-FAMILY: 宋体">中输入下述</span><span lang="EN-US">SQL</span><span style="FONT-FAMILY: 宋体">命令,可以测试该过程:</span></p>
<p class="2" style="MARGIN-TOP: 8.15pt; MARGIN-LEFT: 21.45pt; MARGIN-RIGHT: 0cm; FTEL: 18.45pt"><span lang="EN-GB">DECLARE @CatID int;</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; FTEL: 18.45pt"><span lang="EN-GB">EXECUTE CategoryInsert 'Pasties' , 'Heaven Sent Food' , @CatID OUTPUT;</span></p>
<p class="2" style="MARGIN-TOP: 0cm; MARGIN-LEFT: 21.45pt; MARGIN-RIGHT: 0cm; FTEL: 18.45pt"><span lang="EN-GB">PRINT @CatID;</span></p>

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?