开发者社区> 科技小先锋> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

在SQL Server数据库开发中的十大问题

简介:
+关注继续查看

在SQL Server数据库开发中的十大问题

在SQL Server中进行开发会让你身处险地,并且寻找快速解决方案。我们编辑了前十名关于SQL Server开发的常见问题。对常见的针对表和字段的名字约束进行探究。学习如何解决并发问题,并且在不了解T-SQL的情况下编写存储过程。查看这些解决方案的快速参考,并且了解更多内容。   在SQL Server开发问题中你可能会问到的十个问题:   1、什么是常见的对表和字段的名字约束?   2、有没有可能在不了解T-SQL的情况下编写存储过程   3、T-SQL 中如何比较CLR 存储过程和函数的性能?   4、我如何在一个存储过程中使用另一个存储过程产生的结果?   5、我如何解决SQL Server 2005的并发问题?   6、在SQL Server 2005中用什么工具替代了查询分析器?   7、你能提供一些有关SQL 和T-SQL的详细信息吗?   8、SQL Server 2005 有没有新的索引类型?   9、我如何创建一个脚本在表中进行选择?   10、我如何列出那些没有记录的数据库表?   对于表和字段的常见名字约束   专家回答:   SQL Server 2000下的表和字段名称有1到128字节的限制,并且遵循用于标识的规则。第一个字母必须是如下的一种:   Unicode Standard 2.0中规定的字母。   Unicode对字母的定义包括:拉丁字母,从A到Z,除了来自其他语言的字母之外。   下划线(_),at符号(@),或者数字符号(#)   在SQL Server中以这些符号作为标识符的开始具有特殊的含义。一个以at符号(@)开头的标识符表示一个本地的变量或者参数。一个以数字符号(#)开头的标识符代表一个临时表或者过程。一个以两个数字符号(##)开头的标识符标识的是一个全局临时对象。一些Transact-SQL函数的名字以两个at符号(@@)开头。为了避免与这些函数混淆,推荐你不要使用两个at符号(@@)开头的标识符。接下来的字母可以是以下的任意几种:   Unicode Standard 2.0定义的字母   来自基础拉丁文或者其他语音的十进制数字   at符号(@),美元符号($),数字符号(#),或者下划线   标识符绝对不能是Transact-SQL的保留字。SQL Server保留了一些大写和小写的保留字。内建的空间或者特殊的字母都不允许出现,尽管你可以在好的老版本的Northwind中看到它们包含了内建的空间。你必须通过把它们括在括号中才可以访问。   不具有任何T-SQL知识的情况下编写SQL Server2005存储过程吗?   作为过去几年里面微软试图用SQL Server 2005的.net集成来称霸市场的野心的结果,许多程序员都认为创建SQL Server存储过程不再必需T-SQL了。不幸的是(或者并非如此,这根据你的观点),这并不全是事实。在技术上是可以在不了解T-SQL的情况下创建存储过程的,但是没有T-SQL的话则无法访问任何的数据。   在CLR存储过程内部进行数据访问,是通过使用标准的ADO.NET类来完成的。开发人员会在应用程序层发现很多同样的没有用处的数据访问代码,这些代码会很轻易地转移到SQLCLR例程中去。当中间层的这些ADO.NET类需要使用T-SQL来访问数据的时候,在 CLR主机提供的环境中就会使用同样的类。   我要强调的是,从技术角度来说,不使用T-SQL来编写存储过程是可能的。那么有没有理由这么做呢?一种情况就是这是一个用来从普通文件或者网络服务中检索数据的CLR存储过程,并将数据格式设置为行集。这里可能就会用到不需要T-SQL的操作——但是这并不是对T -SQL存储过程能力的一个很好的比喻。   CLR存储过程vs. T-SQL存储过程   CLR存储过程和函数与T-SQL存储过程和函数相比,性能如何?   专家回答:   这里是用来比较T-SQL例程和CLR例程性能的一种常用的规则:用你的数据,在你的服务器上,测试两套配置,看看哪一个比较好。 就是说,许多人都运行过性能测试,一般的结果就是T-SQL在标准的CRUD(创建、读取、更新、删除)操作上表现要比好一点,而在复杂数学、字符串赋值和其他的超过数据访问的任务上,则是CLR的性能表现更好一点。 SQL Server 的专家Gustavo Larriera编辑了如下一些关于这个主题的有用链接:   在 SQL Server 2005中使用CLR Integration。   简单介绍在 SQL Server 2005中的 CLR Integration。   在 SQL Server 2005中对CLR 和T-SQL做出选择。   介绍 SQL Server 2005中的 CLR Integration。   SQL Server 闲谈: SQL Server 2005 Beta 2 CLR问题与回答。   数据库管理员的防御.NET。 ·用户自定义函数的性能比较。   如何在一个存储过程中使用另一个存储过程的结果   专家回答:   只要存储过程只产生了一个单个的结果,要在另外一个存储过程中使用这个存储过程产生的输出,这个技术是非常直接的。这个技术就是使用一个临时表来装载存储过程的巨额iguo,然后通过INSERT EXEC语句来执行这个过程并保存结果。一旦结果保留在临时表中了,他们就可以像使用其它表数据一样来使用它了。 这里是我们可能会复用的一个过程例子:   CREATE PROC usp_Demo_AllAuthors as   select * from pubs..authors   GO


本文转自yonghu86 51CTO博客,原文链接:http://blog.51cto.com/yonghu/1321479,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
在SQL Server数据库开发中的十大问题
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/chinahuyong/article/details/2563093 在SQL Server数据库开发中的十大问题 在SQL Server中进行开发会让你身处险地,并且寻找快速解决方案。
901 0
2. SQL Server数据库状态监控 - 错误日志
原文:2. SQL Server数据库状态监控 - 错误日志 无论是操作系统 (Unix 或者Windows),还是应用程序 (Web 服务,数据库系统等等) ,通常都有自身的日志机制,以便故障时追溯现场及原因。
1144 0
T-SQL查询:语句执行顺序
原文:T-SQL查询:语句执行顺序 读书笔记:《Microsoft SQL Server 2008技术内幕:T-SQL查询》   ===============  T-SQL查询的执行顺序 ===============      =============== T-SQL查询的示意图...
789 0
Sql Server用管理器建表后如何查看创建表的语句
右键建的那个表-->编写表脚本为-->CREATE到-->新建编辑器查看窗口,就会出现新建表的SQL语句.
1705 0
SQL GROUP BY 语句
合计函数 (比如 SUM) 常常需要添加 GROUP BY 语句。 GROUP BY 语句 GROUP BY 语句用于结合合计函数,根据一个或多个列对结果集进行分组。 SQL GROUP BY 语法 SELECT column_name, aggregate_function(column_name) FROM table_name WHERE column_nam
795 0
Sql语句把一个表的某几列的数据存到另一个表里的方法
原文地址:sql语句把一个表的某几列的数据存到另一个表里的方法作者:星星月亮 一、如何用slq语句把一个表中的某几个字段的数据插入到另一个新表中,就要用下面这条slq语句:     insert into 表名1(字段1,字段2) select 字段1,字段2 from 表名2 这里有一点值得注意的是这2个字段要一一对应,并且按顺序。 二、如果另一个表是已经有数据的表,只希望更
1570 0
6963
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载