您好,初学,请教一个insert语句,一个集合问题。(50分)

  • 主题发起人 主题发起人 pcgod
  • 开始时间 开始时间
P

pcgod

Unregistered / Unconfirmed
GUEST, unregistred user!
您好, 在sql server2000中,有一张表,字段:id (int,标识字段),name,phoen (均为char). 我想向其中插入一个记录,只有name值,phone值为空,我该怎样写query的sql语句?要用insert语句。在insert 中标识字段该怎样处理?

还有,在delphi中怎样定义并使用集合? (我想将 2 5 7 9 99 ,放在一个集合中,然后看输入的变量是不是等于这些值,还有一列想使用集合的量, ak bk dk fk gk ,对于这个我该怎样采用集合去处理? )
 
1.
insert into TABLENAME (id ,name,phoen )
values(0,'NameStr',null)

2.
If 集合的值 in [] then
例子: if dataset.State in [dsBrowse, dsEdit, dsInsert, dsCalcFields] then
if (State = dsBrowse) then
 
1 你的标识字段不是自增型字段?
如果是自增型字段,在插入记录时可以忽略这个字段的,由数据库自身控制,而phone
可以不用去理会,或者就是写个空值给它。
insert into tabname(name) values('aaa')
如果不是自增型字段, 那说明你的想法有问题。标识字段的内容应该必须是唯一的。

2 应该是用类型enum去定义和应用。
 
1.
insert into tablename(id,name,phoen) values(null,'name',null)
 
集合
集合是P a s c a l特有的数据类型,在Visual Basic、C或C + +都没有(虽然C++ Builder提供了一种模板
类称为集合,它模仿P a s c a l集合的行为)。集合用一种有效的手段来表示一组有序数、字符和枚举值。
声明一个集合用关键字set of,并在其后跟上有序类型或一个集合可能值的有限子集。示例如下:
t y p e
TCharSet=set of char; // 可能的值:# 0 - # 2 5 5
T E n u m = ( M o n d a y, Tu e s d a y, We d n e s d a y, T h u r s d a y, F r i d y ) ;
TEnumSet=set of TEnum; // 包含了T E n u m值的任何组合
TSubrangeSet=set of 1..10; // 可能的值:1 - 1 0
TAlphaSet=Set of 'A'..'z'; // 可能的值:' A ' - ' z '
注意,一个集合最多只能有2 5 5个元素。另外,只有有序的类型才能跟关键字set of,因此下列的
代码是非法的:
t y p e
TIntSet=set of Integer; // 非法:太多的元素
TStrSet=set of string; // 非法:不是有序的类型
集合在内部以位的形式存储它的元素,这使得在速度和内存利用上更有效。集合如果少于3 2个元
素,它就存储在C P U的寄存器中,这样效率就更高了,为了用集合类型得到更高的效率。记住,集合
的基本类型的元素数目要小于3 2。
1. 使用集合
当使用集合的元素时,使用方括号。下面代码表明如何使用集合类型的变量并给它赋值。
type
tcharset=set of har;
tenum=(a,b,c,d);
var
charset:Tcharst;
enumset:TEnumset;
subrangeSet: Set of 1..10;
AophaSet: Set of 'a'..'z';
begin
charset:=['a'..'j','a','m'];
enumset:=[a,b];
alphaset:=[];
end;
2. 集合操作符
Object Pascal提供了几个用于集合的运算符,用这些运算符可以判断集合和集合之间的关系,对
集合增删元素,对集合进行求交集运算。
(1) 关系运算
用i n运算符来判断一个给定的元素是否在一个集合中,下面的代码判断在前面所定义的集合
C h a r S e t中是否有字母‘S’:
if 'S' in CharSet then
/ /继续运行
下面的代码判断在E n u m S e t中是否没有M o n d a y :
if not (Monday in EnumSet) then
/ /继续运行
(2) 增删元素
用+、-运算符或I n c l u d e ( )和E x c l u d e ( )过程,能对一个集合变量增删元素:
Include(CharSet, 'a'); / /在集合中增加' a ' ;
C h a r S e t : = C h a r S e t + [ ' b ' ] ; / /在集合中增加' b ' ;
Exclude(CharSet, 'x'); / /在集合中删除' x ' ;
CharSet:=CharSet-['y', 'z']; / /在集合中删除' y '和' z ' ;
提示尽可能地用Include()和Exclude()来增删元素,尽可能地少用+、-运算符。因为Include()和
Exclude()仅需要一条机器指令,而+和-需要13+6n(n是集合的按位的长度)条机器指令。
(3) 交集
用*运算符来计算两个集合的交集,表达式S e t 1 * S e t 2的结果是产生的集合的元素在S e t 1和S e t 2集合
中都存在,下面的例子用来判断在一个给定的集合中是否有某几个元素:
if {'a', 'b', 'c'}*CharSet={'a', 'b', 'c'} then
/ /继续程序
说明:我认为没必要用集合,直接用Pos(substr,str)不是更好吗?

insert into tablename(id,name,phoen) values(null,'aaa',null)
 
如果没有特殊要求的话用字符串好,操作和显示都方便。
 
armyjiang : 您的解释是对的。标识字段唯一。
 
后退
顶部