1. Asp.net(C#) 获取 执行sql server 语句/存储过程后的 多个返回值
如果返回
标量
值的话,例者消如文章的个数,可以使用储存过程的输出(OUTPUT)参数。在定义存储过过程时为参数指定OUTPUT关键字。C#调用
存储过程
时指定参数
SqlParameter
对象的
Direction
属性吵闹为Output。
如果是返回多个
结果集
的话,可以直接在存储过程中使用多升嫌罩个select查询就行。在C#代码中使用SqlDataReader对象的NextResult方法提取下一个结果集。
2. sqlcommand怎么样执行多条sql语句
多个语句写在一起,每条之间用“;”隔开就行了啊
一次就全部执行了啊
3. 执行SQl语句之后把结果赋给一个变量怎么写
你这个问题
要看你是要把唤简这个结果赋值给那个域内的整形变量了
如果是直接赋值给SQL语句内的一个变量
那么就像上面的回答一样
如果是赋值给你程序内的变量
那么可以使用多个方法,现假定你使用C#:
1.使用一个SqlCommand执行命令
并且得到一个SqlDataReader
然后通过SqlDataReader获得变量
对应SQL语句:
SELECT
Grade
from
mstSalaryGrade
where
EmployeeManagementID
in(SELECT
EmployeeManagementID
from
mstEmployeeBasic
where
EmployeeCode=26
2.还是使用一个SqlCommand执行存储过程或语句
不过Grade作为一个输出参数传回来
再进行获取州埋
:
exec
sp_execute
'SELECT
@Grade=Grade
from
mstSalaryGrade
where
EmployeeManagementID
in(SELECT
EmployeeManagementID
from
mstEmployeeBasic
where
EmployeeCode=26',N'@Grade
int
output',0
3.使用SqlCommand执行存储过程
Grade作为返回值册链蚂传递回来
:
declare
@Grade
int
SELECT
@Grade
=Grade
from
mstSalaryGrade
where
EmployeeManagementID
in(SELECT
EmployeeManagementID
from
mstEmployeeBasic
where
EmployeeCode=26
return
Grade;
4. 关于Sqlcommand
设置一下cmd的命令类型,
在178行后加:
cdm.commandtype=text;
5. Winform中执行SQL语句的参数问题
你是怎激祥么执行sql语句的 是像下面这样吗?还有就是你的sql语句明滚搏是怎么构造的?能贴出备者来看看么?
public static int ExecuteCommand(string safeSql, params SqlParameter[] values)
{
try
{
SqlConnection conn = new SqlConnection();
conn.ConnectionString = @"your connection string";
using (SqlCommand cmd = new SqlCommand(safeSql, conn))
{
conn.Open();
cmd.Parameters.AddRange(values);
int count = cmd.ExecuteNonQuery();
conn.Close();
return count;
}
}
catch (SqlException ex)
{
throw ex;
}
}
6. 如何用sqlcommand执行sql脚本
string sConnectionString = @"蠢尺server=(local)\SQLEXPRESS;database=Forum;Trusted_Connection=True";
using (SqlConnection conn = new SqlConnection(sConnectionString))
{
conn.Open();
using (SqlCommand cmd = new SqlCommand())
{
// 绑定有效的数据库连接
cmd.Connection = conn;
// 定义操作1的SQL语句
cmd.CommandText = "Insert into tbClass (ClassName) values ('网页设计')";
// 完成操作1并输出相应的记录数
Response.Write(string.Format("在tbClass中插入了{0}条记录<br>", cmd.ExecuteNonQuery()));
// 定义操作2的SQL语句
cmd.CommandText = "Select ClassID from tbClass where ClassName='网页设计'";
// 完成操作2
string sClassID = cmd.ExecuteScalar().ToString();
// 输出操作2的结果
Response.Write(string.Format("ClassID为{0}<br>", sClassID));
// 定义操作3的SQL语句
cmd.CommandText = string.Format("Insert into tbBoard (BoardName,BoardClassID) values ('PHOTOSHOP','{0}');Insert into tbBoard (BoardName,BoardClassID) values ('FIREWORKS','{0}')", sClassID);
// 完成操作3并输出相应的记录数
Response.Write(string.Format("在tbBoard中插入仿档稿了{0}条记录<br>", cmd.ExecuteNonQuery()));
// 定义操作4的SQL语句
cmd.CommandText = "Update tbBoard set BoardName='PS技术' where BoardName='PHOTOSHOP'";
// 完成操作4并输出相应的记录数
Response.Write(string.Format("在备孝tbBoard中修改了{0}条记录<br>", cmd.ExecuteNonQuery()));
// 定义操作5的SQL语句
cmd.CommandText = string.Format("Delete from tbBoard where BoardClassID='{0}'", sClassID);
// 完成操作5并输出相应的记录数
Response.Write(string.Format("在tbBoard中删除了{0}条记录<br>", cmd.ExecuteNonQuery()));
// 定义操作6的SQL语句
cmd.CommandText = string.Format("Delete from tbClass where ClassID='{0}'", sClassID);
// 完成操作6并输出相应的记录数
Response.Write(string.Format("在tbClass中删除了{0}条记录<br>", cmd.ExecuteNonQuery()));
}
}
7. C#执行sql语句的问题(或者说C#让SQL语句换行)。
换行是可以,但是你还是不能用GO
SqlCommand发出的语句是一次性执行完的,不允许使用GO
所以你需要把你的SQL语句分解开,多次执行
8. SQL命令怎么用
SQL语句:
通过SQL语句可以完成对数据库、表、数据的操作,也就是我们本教程要学习的主要内容。
一条SQL语句类似这样,它的含义是:从Users表中取出列名为UserName的数据。
一些重要的SQL命令:
SELECT – 从数据库中提取数据
UPDATE – 更新数据库中的数据
DELETE – 从数据库中删除数据
INSERT INTO – 向数据库中插入新数据
CREATE DATABASE – 创建新数据库
ALTER DATABASE – 修改数据库
CREATE TABLE – 创建新表
ALTER TABLE – 变更数据库表
DROP TABLE – 删除表
CREATE INDEX – 创建索引
DROP INDEX – 删除索引
-from shulanxt
9. 写出使用SqlCommand与SqlConnection向数据库执行一个名为Sql1的SQL查询
oracle 10g的DBMS_XPLAN包中display_cursor函数不同于display函数,display_cursor用于显示SQL语句的真实的执行计划,在大多数情况下,
显示真实的执行计划有助于更好的分析SQL语句的全过程,尤其是运行此SQL语句实时的I/O开销。通过对比预估的I/O与真实的I/O开销来判断
SQL语句所存在问题,如缺少统计信息,SQL语句执行的次数,根据搏旁实际中间结果集的大小来选择合适的连接方式等。本文仅仅讲述
display_cursor函数的使用。
一、display_cursor函数用法
1、display_cursor函数语法
DBMS_XPLAN.DISPLAY_CURSOR(
sql_id IN VARCHAR2 DEFAULT NULL,
cursor_child_no IN NUMBER DEFAULT NULL,
format IN VARCHAR2 DEFAULT 'TYPICAL');
2、display_cursor函数参数描述
sql_id
指定位于库基缓橡缓存执行计划中SQL语句的父游标。默认值为null。当使用默认值时当前会话的最后一条SQL语句的执行计划将被返回
可以通过查询V$SQL 或V$SQLAREA的SQL_ID列来获得SQL语句的SQL_ID。
cursor_child_no
指定父游标下子游标的序号。即指定被返回执行计划的SQL语句的子游标。默认值为0。如果为null,则sql_id所指父游标下所有子游标
的执行计划都将被返回。
format
控制SQL语句执行计划的输出部分,即哪些可以显示哪些不显示。使用与display函哪贺数的format参数与修饰符在这里同样适用。
除此之外当在开启statistics_level=all时或使用gather_plan_statistics提示可以获得执行计划中实时的统计信息
有关详细的format格式描述请参考:dbms_xplan之display函数的使用 中format参数的描述
下面给出启用统计信息时format新增的修饰符
iostats 控制I/O统计的显示
last 默认,显示所有执行计算过的统计。如果指定该值,则只显示最后一次执行的统计信息
memstats 控制pga相关统计的显示
allstats 此为iostats memstats的快捷方式,即allstats包含了iostats和memstats
run_stats_last 等同于iostats last。只能用于oracle 10g R1
run_stats_tot 等同于iostats。只能用于oracle 10g R1
抓一个最近一小时最消耗IO的SQL:
SELECT sql_id, COUNT(*)
FROM gv$active_session_history ash, gv$event_name evt
WHERE ash.sample_time > SYSDATE - 1 / 24
AND ash.session_state = 'WAITING'
AND ash.event_id = evt.event_id
AND evt.wait_class = 'User I/O'
GROUP BY sql_id
ORDER BY COUNT(*) DESC;
执行上面的SQL:
SQL> SELECT sql_id, COUNT(*)
FROM gv$active_session_history ash, gv$event_name evt
2 3 WHERE ash.sample_time > SYSDATE - 1 / 24
4 AND ash.session_state = 'WAITING'
5 AND ash.event_id = evt.event_id
6 AND evt.wait_class = 'User I/O'
7 GROUP BY sql_id
8 ORDER BY COUNT(*) DESC;
SQL_ID COUNT(*)
------------- ----------
g7fu6qba82m6b 668
63r47zyphdk06 526
9f5m4wd88nc1h 514
593p47drw5fhk 232
br91w16jzy4fu 120
4fvwyjpnh6tp7 78
gm0nrbfuj8kzr 70
2184k363hw4xd 68
gc4dajs7g5myy 46
8vrk9sfuwfdgq 42
ccpnb4dwdmq21 40
查看SQL的执行计划:
SELECT * FROM TABLE(dbms_xplan.display_cursor('g7fu6qba82m6b'));
在SQLPLUS中执行:
SQL> set pagesize 2000
SQL> SELECT * FROM TABLE(dbms_xplan.display_cursor('g7fu6qba82m6b'));
PLAN_TABLE_OUTPUT
------------------------------------------------------------------------------------------------------------------------
SQL_ID g7fu6qba82m6b, child number 0
-------------------------------------
UPDATE "CPDDS_PDATA"."CDM_LEDGER" SET "CSTM_NAME" = :a1,"CSTM_NO" =
:a2,"PAPER_TYPE" = :a3,"PAPER_NO" = :a4,"CURR_TYPE" = :a5,"SVT_NO" =
:a6,"BAL_DIR" = :a7,"BAL" = :a8,"AVAL_BAL" = :a9,"NORM_FRATIO" =
:a10,"PK_BAL" = :a11,"DR_ACCU" = :a12,"CR_ACCU" = :a13,"LAST_TRAN_DATE" =
:a14,"LAST_TRAN_TIME" = :a15,"PRT_LINE_NUM" = :a16,"NOREG_PK_REC_NUM" =
:a17,"PK_NO" = :a18,"PWD" = :a19,"FLAG" = :a20,"FRZ_FLAG" =
:a21,"CARD_HOLD_FLAG" = :a22,"PK_HOLD_FLAG" = :a23,"BGN_INT_DATE" =
:a24,"OPEN_DATE" = :a25,"ACC_HOLD_FLAG" = :a26,"CLS_DATE" =
:a27,"OPEN_TLR" = :a28,"CLS_TLR" = :a29,"CLS_INT" = :a30,"OPEN_INST" =
:a31,"ADD_NUM" = :a32,"DAC" = :a33,"FRZ_TIMES1" = :a34,"FRZ_TIMES2" =
:a35,"HOST_SEQNO" = :a36,"D_UPDATE_DATE" = :a37 WHERE "ACC" = :b0
Plan hash value: 319441092
-----------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
-----------------------------------------------------------------------------------
| 0 | UPDATE STATEMENT | | | | 3 (100)| |
| 1 | UPDATE | CDM_LEDGER | | | | |
|* 2 | INDEX UNIQUE SCAN| I_CDM_LEDGER | 1 | 269 | 2 (0)| 00:00:01 |
-----------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
2 - access("ACC"=:B0)
29 rows selected.
总结
1、与display函数不同,display_cursor显示的为真实的执行计划
2、对于format参数,使用与display函数的各个值,同样适用于display_cursor函数
3、当statistics_level为all或使用gather_plan_statistics提示可以获得执行时的统计信息
4、根据真实与预估的统计信息可以初步判断SQL效率低下的原因,如统计信息的准确性、主要的开销位于那些步骤等
10. 如何在mysql shell命令中执行sql命令行
本文介绍 MySQL 8.0 shell 子模块 Util 的两个导入特性 importTable/import_table(JS和python 版本的命名差异)、importJson/import_json的使用方法。
其中 import_table 是通过传统 MySQL 协议来通信,Import_json 是通过 X 插件协议来通信。MySQL 一直以来提供导入文件 SQL 命令 load data infile(单线程)以及对应的可执行文件 mysqlimport(多线程)。
比如我导入 100W 行示例数据到表 ytt.tl1,花了 24 秒。这个已经是 MySQL 默认导入来的最快的。分析那我们现在看下 mysqlimport 工具的升级版,mysqlshell 的 util 工具集。
使用这两个工具之前,必须得临时开启 local_infile 选项。1. import_table建立 3306 端口的新连接我这里切换为 python 模式清空掉示例表 Ytt.tl1import_table 有两个参数,第一个参数定义导入文件的路径,第二个定义相关选项,比如导入的格式,并发的数量等。定义文件路径(参数1)定义选项(参数2)执行导入:只花了不到 17 秒,比传统 mysqlimport 快了不少。
我们上面指定了显式指定了字段分隔符,那有没有已经定义好的组合格式呢? 答案是有的,选项 dialect 可以指定以下格式:csv,tsv,json,csv-unix那么上面的导入,我们可以更简单,改下变量 y_options1 的定义导入时间差不多。这里要说明下,dialect 选项的优先级比较低,比如添加了'linesTerminatedBy':' ', 则覆盖他自己的' '。
选项 diaelect 还有一个可选值为 json,可以直接把 json 结果导入到文档表里。比如我新建一张表 tl1_json重新定义文件以及导入选项。导入 JSON 数据速度也还可以,不到 24 秒。那导入 json 数据,就必须得提到以 X 插件协议通信的工具 import_json了。2. imort_json我们切换到 mysqlx 端口import_json 参数和 Import_table 参数类似,这里我改下选项我在手册上没有看到多线程的选项,所以单线程跑 35 秒慢了些。查看刚刚导入的数据import_json 不仅仅可以导入 Json 数据,更重要的是可以在 BSON 和 JSON 之间平滑的转换,有兴趣的同学可以去 TRY 下。