sql引用变量
A. 如何在sql语句中引用变量
declare @id int
set @id=1
select * from table where id=@id
B. sql中引用日期变量
declare@suffixvarchar(1000)
declare@sqlvarchar(2000)--这里定义了一个变量
select@suffix=CONVERT(varchar(100),GETDATE(),112)
set@sql='select*fromtest_'+@suffix+''--需要指定动态sql
exec(@sql)--这句是执行
C. SQL中的变量引用方法
strSQL = "selet * from table1 where name = ' " &UserName& " '"
上面这个语句肯定是在你的asp文件中的了。
asp字符串连接符是&,这个你知道的,所以,不难看出,strSQL是由三部分组成的:
1. "selet * from table1 where name = ' "
2. UserName
3. " '"
如果你把语句显示到页面上,你就可以看到,真正的语句如下(假设UserName变量的值是‘王明’):
selet * from table1 where name = '王明'
这也是最终你的数据库要执行的语句。
这就很容易解释了,双引号在ASP中定义字符,"'"这个是一个字符串,不过这个字符串只有一个字符,就是那个单引号,这个单引号要用到数据库SQL语句中使用。
一句话,双引号是ASP用来定义字符串的,&符号是用来连接两个字符串的。
祝好运。
D. 如何在SQL语句中使用变量
使用变量一般是在存储过程、方法、触发器等T-Sql编程的时候用的,使用Declare 来定义变量,在方法/存储过程/触发器等里面进行调用。
E. JSP中SQL引用变量的问题
String operation1="insert into "+tableName+"values ("+nameInsert+","+sexInsert+","+age+")";
后面多了几个引号,不管变量什么类型,写sql语句时,加上就行了,能解析铅吵散出来的。。。
如果插入的不是所有字段,需要在tableName(这是变量么,碰源不是要放在前面的引号里)的后面加个括号“(里面写后面的插入列对应的数据库列名。。。)”
希望可槐氏以帮助你,谢谢采纳。。。
F. C++中,查询sqlserver时 sql语言中如何引用int变量
CString sql;
sql.Format(_T("SELECT * FROM 表名 Where ID=%d"),i);
USES_CONVERSION;
LPSTR strSQL=T2A(sql);
m_pRecordset->Open(strSQL,
m_pConnection.GetInterfacePtr(),
adOpenStatic,
adLockOptimistic,
adCmdText);
如上,把int型变量i 组合成cstring字符串,然后汪埋类型转换闷陵笑,就可以用了。
可以组合各种数据类型,char要加'%s'例如蚂含char str;sql.Format(_T("SELECT * FROM 表名 Where ID='%s'"),str);
G. oracle pl/sql中如何使用变量
定义并使用变量
PL/SQL有四种类型:标量类型,复合类型,引用类型 (reference),LOB(Large Obejct)类型
一、标量类型
最常用的就是标量类型,是指只能存放单个数值的变量,包括数字类型、字符类型、日期类型和布尔类型,每种类型又包含相应的子类型。
常量标量类型如下:
VARCHAR2 (n) , CHAR (n), NUMBER (p,s),DATE, TIMESTAMP , LONG , LONG RAW ,BOOLEAN,BINARY_INTEGER(仅 PL / SQL使用),BINARY_FLOAT和BINARY_DOUBLE(10g新引入的)
定义标量:
identifier [CONSTANT] datatype [NOT NULL] [:=| DEFAULT expr]
使用标量需要注意的是=号被:=取代,与delphi一样的赋值符号@_@
例子:
v_name VARCHAR2 ( 10 );
v_rate CONSTANTS NUMBER ( 4 , 2 ) : = 3.04 ;
为了防止定义的变量类型与表中的字段类型不一致,可以使用%TYPE来定义:
v_name employee.name % TYPE;
如上面所示,v_name的类型就与表 employee中的name字段类型一样!!
二、复合变量:
用于存放多个值的变量称为复合变量,包括PL/SQL记录,PL/SQL表,嵌套表和VARRAY四种类型
1.PL/SQL记录
类似于C/C++中的结构概念:
declare
TYPE employee_record is RECORD(
id employee.id % TYPE,
name employee.name % TYPE,
email employee.email % TYPE);
em_record employee_record;
begin
select id,name,email into em_record from employee where name =& name;
dbms_output.put_line( ' 雇员名: ' || em_record.name || ' 雇员ID: ' || em_record.id);
end ;
2.PL/SQL表,类似于数组概念,不同的是PL/SQL表允许负值下标,而且没有上下限,如:
declare
TYPE employee_table is table of employee.name % TYPE index by BINaRY_INTEGER;
em_table employee_table;
begin
select name into em_table( - 1 ) from employee where name =& name;
dbms_output.put_line( ' 雇员名: ' || em_table( - 1 ));
end ;
3.嵌套表,与PL/SQL 表相似,不同的是嵌套表可以做表列的数据类型,而PL/SQL表不能,使用嵌套表作为表列时,必须为其指定专门的存储表,如:
create or replace TYPE emp_type as OBJECT(name VARCHAR2 ( 10 ),salary NUMBER ( 6 , 2 ),hiredate DATE);
CREATE OR REPLACE TYPE emp_array IS TABLE OF emp_type;
CREATE TABLE department(
deptno NUMBER ( 2 ),dname VARCHAR2 ( 10 ),
employee emp_array)NESTED TABLE employee STORE as employee_dept;
4.VARRAY(变长数组),与嵌套表相似,也可以做为表列的数据类型,但是嵌套表没有个数限制,而VARRAY有个数限制,如:
CREATE TYPE TEST_ARRAY IS VARRAY(20) OF emp_type;
三、引用变量(reference)
类似于C++中的指针或者JAVA中引用的概念,用于存放数值指针的变量,使用此变量,可以使得应用程序共享相同对象,降低占用空间。此类有两种类型:游标(REF CURSOR)和对象类型(REF OBJECT)
1.REF CURSOR,定义时同时指定SELECT语句的游标称为显式或者静态游标,在打开时才指定SELECT语句的游标称为动态游标,如:
DECLARE
TYPE c1 IS REF CURSOR ;
emp_cursor c1;
v_name employee.name % TYPE;
v_sal employee.salary % TYPE;
begin
open emp_cursor for
SELECT name,salary FROM EMPLOYEE ;
LOOP
FETCH emp_cursor INTO v_name,v_sal;
EXIT WHEN emp_cursor % NOTFOUND;
dbms_output.put_line(v_name);
END LOOP;
close emp_cursor;
end ;
2.REF OBJECT,与JAVA的引用概念相同,存储的是指向对象的指针
四、LOB类型
LOB类型是指用于存储大批量数据的变量,包括内部的3种(CLOB,BLOB,NCLOB)和外部LOB(BFILE)。
CLOB,NCLOB用于存储大量的字符数据。
BLOB用于存储大批量二进制数据(如图象)。
BFILE则存储指向OS文件的指针。
H. sql server 2005触发器中如何引用指定的变量值
可以定义一个无论何时用INSERT语句向表中插入数据时都慎纤悄会执行的触发器。
当触发INSERT触发器时,新的数据行就会被插入到触发器表和inserted表中。inserted表是一个逻辑表,它包含了已经插入的数据行的一个副本。inserted表包含了INSERT语句中已记录的插入动作。inserted表还允许引用由初始化INSERT语句而产生的日志数据。触发器通过检查inserted表来确定是否执行触发器动作或如何执行它。inserted表中的行总是触发器表中一行或多行的副本。
日志记录了所有修改数据的动作(INSERT、UPDATE和DELETE语句),但在事务日志中的信息是不可读的。然而,inserted表允许你引用由INSERT语句引起的日志变化,这样就可以将插入数据与发生的变化进行比较,来验证它们或采取进一步的动作。也可以直接引用插入的数据,而不必竖宴将它们存储到变量中。
示例
在本例中,将创建一个触发器。无论何时订购产品(无论何时向Order Details表中插入一条记录),这个触发器都将更新Procts表中的一列(UnitsInStock)。用原来的值减去订宽渣购的数量值即为新值。
USE Northwind
CREATE TRIGGER OrdDet_Insert
ON [Order Details]
FOR INSERT
AS
UPDATE P SET
UnitsInStock = P.UnitsInStock – I.Quantity
FROM Procts AS P INNER JOIN Inserted AS I
ON P.ProctID = I.ProctID
DELETE触发器的工作过程
当触发DELETE触发器后,从受影响的表中删除的行将被放置到一个特殊的deleted表中。deleted表是一个逻辑表,它保留已被删除数据行的一个副本。deleted表还允许引用由初始化DELETE语句产生的日志数据。
使用DELETE触发器时,需要考虑以下的事项和原则:
·当某行被添加到deleted表中时,它就不再存在于数据库表中;因此,deleted表和数据库表没有相同的行。
·创建deleted表时,空间是从内存中分配的。deleted表总是被存储在高速缓存中。
·为DELETE动作定义的触发器并不执行TRUNCATE TABLE语句,原因在于日志不记录TRUNCATE TABLE语句。
示例 在本例中,将创建一个触发器,无论何时删除一个产品类别(即从Categories表中删除一条记录),该触发器都会更新Procts表中的Discontinued列。所有受影响的产品都标记为1,标示不再使用这些产品了。
USE Northwind
CREATE TRIGGER Category_Delete
ON Categories
FOR DELETE
AS
UPDATE P SET Discontinued = 1
FROM Procts AS P INNER JOIN deleted AS d
ON P.CategoryID = d.CategoryID