有如下SQL语句:
s_sql = "select * from T_gjdq where fjdid='" + t_parent.Value + "' order by ID"
问下怎么修改可以提高运行的性能?

解决方案 »

  1.   

    不要直接拼sql语句,不安全。
    尽量不要使用*,影响查询速度。
      

  2.   

    1、*号用具体的字段列表替代,尽可能的减少返回的字段数目。
    2、针对fjdid字段创建索引
      

  3.   

    有如下SQL语句: 
    s_sql = "select * from T_gjdq where fjdid='" + t_parent.Value + "' order by ID" 
    问下怎么修改可以提高运行的性能? 
    想要优化结果!就是不要用*来查询!你需要哪个字段就用哪个字段就好了哦!比如"select 字段1,字段2 from T_gjdq where fjdid='" + t_parent.Value + "' order by ID" 
      

  4.   


    不直接拼sql语句那怎么写呀?
    不要使用*要表示查找全部的怎么写呢?
      

  5.   


    怎么针对fjdid字段创建索引?
      

  6.   

    CREATE INDEX
    为给定表或视图创建索引。只有表或视图的所有者才能为表创建索引。表或视图的所有者可以随时创建索引,无论表中是否有数据。可以通过指定限定的数据库名称,为另一个数据库中的表或视图创建索引。语法
    CREATE [ UNIQUE ] [ CLUSTERED | NONCLUSTERED ] INDEX index_name
        ON { table | view } ( column [ ASC | DESC ] [ ,...n ] ) 
    [ WITH < index_option > [ ,...n] ] 
    [ ON filegroup ]< index_option > ::= 
        { PAD_INDEX |
            FILLFACTOR = fillfactor |
            IGNORE_DUP_KEY |
            DROP_EXISTING |
        STATISTICS_NORECOMPUTE |
        SORT_IN_TEMPDB  
    }A. 使用简单索引
    下面的示例为 authors 表的 au_id 列创建索引。SET NOCOUNT OFF
    USE pubs
    IF EXISTS (SELECT name FROM sysindexes 
          WHERE name = 'au_id_ind')
       DROP INDEX authors.au_id_ind
    GO
    USE pubs
    CREATE INDEX au_id_ind
       ON authors (au_id)
    GOB. 使用唯一聚集索引
    下面的示例为 emp_pay 表的 employeeID 列创建索引,并且强制唯一性。因为指定了 CLUSTERED 子句,所以该索引将对磁盘上的数据进行物理排序。 SET NOCOUNT ON
    USE pubs
    IF EXISTS (SELECT * FROM INFORMATION_SCHEMA.TABLES 
          WHERE TABLE_NAME = 'emp_pay')
       DROP TABLE emp_pay
    GO
    USE pubs
    IF EXISTS (SELECT name FROM sysindexes 
          WHERE name = 'employeeID_ind')
       DROP INDEX emp_pay.employeeID_ind
    GO
    USE pubs
    GO
    CREATE TABLE emp_pay
    (
     employeeID int NOT NULL,
     base_pay money NOT NULL,
     commission decimal(2, 2) NOT NULL
    )
    INSERT emp_pay
       VALUES (1, 500, .10)
    INSERT emp_pay 
       VALUES (2, 1000, .05)
    INSERT emp_pay 
       VALUES (3, 800, .07)
    INSERT emp_pay
       VALUES (5, 1500, .03)
    INSERT emp_pay
       VALUES (9, 750, .06)
    GO
    SET NOCOUNT OFF
    CREATE UNIQUE CLUSTERED INDEX employeeID_ind
       ON emp_pay (employeeID)
    GOC. 使用简单组合索引
    下面的示例为 order_emp 表的 orderID 列和 employeeID 列创建索引。SET NOCOUNT ON
    USE pubs
    IF EXISTS (SELECT * FROM INFORMATION_SCHEMA.TABLES 
          WHERE TABLE_NAME = 'order_emp')
       DROP TABLE order_emp
    GO
    USE pubs
    IF EXISTS (SELECT name FROM sysindexes 
          WHERE name = 'emp_order_ind')
       DROP INDEX order_emp.emp_order_ind
    GO
    USE pubs
    GO
    CREATE TABLE order_emp
    (
     orderID int IDENTITY(1000, 1),
     employeeID int NOT NULL,
     orderdate datetime NOT NULL DEFAULT GETDATE(),
     orderamount money NOT NULL
    )INSERT order_emp (employeeID, orderdate, orderamount)
       VALUES (5, '4/12/98', 315.19)
    INSERT order_emp (employeeID, orderdate, orderamount)
       VALUES (5, '5/30/98', 1929.04)
    INSERT order_emp (employeeID, orderdate, orderamount)
       VALUES (1, '1/03/98', 2039.82)
    INSERT order_emp (employeeID, orderdate, orderamount)
       VALUES (1, '1/22/98', 445.29)
    INSERT order_emp (employeeID, orderdate, orderamount)
       VALUES (4, '4/05/98', 689.39)
    INSERT order_emp (employeeID, orderdate, orderamount)
       VALUES (7, '3/21/98', 1598.23)
    INSERT order_emp (employeeID, orderdate, orderamount)
       VALUES (7, '3/21/98', 445.77)
    INSERT order_emp (employeeID, orderdate, orderamount)
       VALUES (7, '3/22/98', 2178.98)
    GO
    SET NOCOUNT OFF
    CREATE INDEX emp_order_ind
       ON order_emp (orderID, employeeID)D. 使用 FILLFACTOR 选项
    下面的示例使用 FILLFACTOR 子句,将其设置为 100。FILLFACTOR 为 100 将完全填满每一页,只有确定表中的索引值永远不会更改时,该选项才有用。SET NOCOUNT OFF
    USE pubs
    IF EXISTS (SELECT name FROM sysindexes 
          WHERE name = 'zip_ind')
       DROP INDEX authors.zip_ind
    GO
    USE pubs
    GO
    CREATE NONCLUSTERED INDEX zip_ind
       ON authors (zip)
       WITH FILLFACTOR = 100E. 使用 IGNORE_DUP_KEY
    下面的示例为 emp_pay 表创建唯一聚集索引。如果输入了重复的键,将忽略该 INSERT 或 UPDATE 语句。SET NOCOUNT ON
    USE pubs
    IF EXISTS (SELECT * FROM INFORMATION_SCHEMA.TABLES 
          WHERE TABLE_NAME = 'emp_pay')
       DROP TABLE emp_pay
    GO
    USE pubs
    IF EXISTS (SELECT name FROM sysindexes 
          WHERE name = 'employeeID_ind')
       DROP INDEX emp_pay.employeeID_ind
    GO
    USE pubs
    GO
    CREATE TABLE emp_pay
    (
     employeeID int NOT NULL,
     base_pay money NOT NULL,
     commission decimal(2, 2) NOT NULL
    )
    INSERT emp_pay
       VALUES (1, 500, .10)
    INSERT emp_pay 
       VALUES (2, 1000, .05)
    INSERT emp_pay 
       VALUES (3, 800, .07)
    INSERT emp_pay
       VALUES (5, 1500, .03)
    INSERT emp_pay
       VALUES (9, 750, .06)
    GO
    SET NOCOUNT OFF
    GO
    CREATE UNIQUE CLUSTERED INDEX employeeID_ind
       ON emp_pay(employeeID)
       WITH IGNORE_DUP_KEYF. 使用 PAD_INDEX 创建索引
    下面的示例为 authors 表中的作者标识号创建索引。没有 PAD_INDEX 子句,SQL Server 将创建填充 10% 的叶级页,但是叶级之上的页几乎被完全填满。使用 PAD_INDEX 时,中间级页也填满 10%。说明  如果没有指定 PAD_INDEX,唯一聚集索引的索引页上至少会出现两项。
    SET NOCOUNT OFF
    USE pubs
    IF EXISTS (SELECT name FROM sysindexes 
          WHERE name = 'au_id_ind')
       DROP INDEX authors.au_id_ind
    GO
    USE pubs
    CREATE INDEX au_id_ind
       ON authors (au_id)
       WITH PAD_INDEX, FILLFACTOR = 10G. 为视图创建索引
    下面的示例将创建一个视图,并为该视图创建索引。然后,引入两个使用该索引视图的查询。USE Northwind
    GO--Set the options to support indexed views.
    SET NUMERIC_ROUNDABORT OFF 
    GO 
    SET ANSI_PADDING,ANSI_WARNINGS,CONCAT_NULL_YIELDS_NULL,ARITHABORT,QUOTED_IDENTIFIER,ANSI_NULLS ON
    GO--Create view.
    CREATE   VIEW V1 
    WITH   SCHEMABINDING 
    AS 
       SELECT SUM(UnitPrice*Quantity*(1.00-Discount)) AS Revenue, OrderDate, ProductID, COUNT_BIG(*) AS COUNT 
       FROM   dbo.[Order Details] od, dbo.Orders o 
       WHERE   od.OrderID=o.OrderID 
       GROUP BY   OrderDate, ProductID
    GO--Create index on the view.
    CREATE UNIQUE CLUSTERED INDEX IV1 ON V1 (OrderDate, ProductID)
    GO--This query will use the above indexed view.
    SELECT SUM(UnitPrice*Quantity*(1.00-Discount)) AS Rev, OrderDate, ProductID
    FROM   dbo.[Order Details] od, dbo.Orders o
    WHERE   od.OrderID=o.OrderID AND ProductID in (2, 4, 25, 13, 7, 89, 22, 34)
       AND OrderDate >= '05/01/1998'
    GROUP BY OrderDate, ProductID
    ORDER BY Rev DESC--This query will use the above indexed view.
    SELECT  OrderDate, SUM(UnitPrice*Quantity*(1.00-Discount)) AS Rev
    FROM   dbo.[Order Details] od, dbo.Orders o
    WHERE   od.OrderID=o.OrderID AND DATEPART(mm,OrderDate)= 3
       AND DATEPART(yy,OrderDate) = 1998
    GROUP BY OrderDate
    ORDER BY OrderDate ASC
      

  7.   

    简单点就是:CREATE INDEX idx_T_gjdq ON T_gjdq (fjdid)
      

  8.   


    应该写为s_sql = "select * from T_gjdq where fjdid='" + t_parent.Value.replace("'","''") + "' order by ID"这样才符合SQL Server语法(字符串常量中的每一个单引号必须处理成两个单引号)。数据库方面,对关键字段(例如fjdid)设置必要的索引就可以了。至于说*是不是就影响效率,有很多这样看似总是正确的说法,你应该实际去做测试,看看那些东西到底重不重要。实际上,优化了的好程序是尽可能不去重复查询数据库,这样才能真正大概规模地提高效率。而不是仅仅在数据库索引方面下点工夫。
      

  9.   

    楼主的 t_parent.Value 是个hidden 控件值,一般是自己提供的页面传递参数,所以没必要replace,如果实在从安全角度讲,还是写select * from T_gjdq where fjdid='@fjdid' order by ID然后给SqlCommand创建一个new SqlParameter("@fjdid",  t_parent.Value)数据库设计中,索引不是乱建的,建了也不一定快(查询的时候快了,但Insert和Update的时候要重建索引,这时就慢了)。像金蝶K3的表单,几乎所有的字段都开放给用户作为备查询字段,难不成为每个字段建索引?
      

  10.   

    你可以找一个专门执行SQL语句的控件.dll的!
    而写语句时格式也要鲜明,那样便于你寻找错误.若是C#竟量
    用String.Format用,它会屏蔽好多非发输入!