版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、成功信息网 C#数据库连接操作大全+sql语句大全下面是c#与数据库的连接及增删改除的各种操作,全部经过上机验证。学习软件的过程中,数据库起着至关重要的作用。软件行业里面有句老话,不会数据库就没有入门。软件思想可以慢慢培养,但是数据库的链接是一定要学会的。增删改查各种都不能少。创建数据库 创建之前判断该数据库是否存在 if exists (select * from sysdatabases where name='databaseName') drop database 'databaseName' go Create DATABASE database-na
2、me删除数据库 drop database dbname备份sql server - 创建 备份数据的 device USE master EXEC sp_addumpdevice 'disk', 'testBack', 'c:mssql7backupMyNwind_1.dat' - 开始 备份 BACKUP DATABASE pubs TO testBack创建新表 create table tabname(col1 type1 not null primary key,col2 type2 not null,.) 根据已有的表创建新表: A:
3、create table tab_new like tab_old (使用旧表创建新表) B:create table tab_new as select col1,col2 from tab_old definition only删除新表 drop table tabname增加一个列 Alter table tabname add column col type 注:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。添加主键 Alter table tabname add primary key(col) 说明:删除主键: Alter ta
4、ble tabname drop primary key(col)创建索引 create unique index idxname on tabname(col.) 删除索引:drop index idxname on tabname 注:索引是不可更改的,想更改必须删除重新建。创建视图 create view viewname as select statement 删除视图:drop view viewname几个简单的基本的sql语句 选择:select * from table1 where 范围 插入:insert into table1(field1,field2) values(
5、value1,value2) 删除:delete from table1 where 范围 更新:update table1 set field1=value1 where 范围 查找:select * from table1 where field1 like %value1% (所有包含value1这个模式的字符串)-like的语法很精妙,查资料! 排序:select * from table1 order by field1,field2 desc 总数:select count(*) as totalcount from table1 求和:select sum(field1) as
6、sumvalue from table1 平均:select avg(field1) as avgvalue from table1 最大:select max(field1) as maxvalue from table1 最小:select min(field1) as minvalue from table1separator几个高级查询运算词 A: UNION 运算符 UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出一个结果表。当 ALL 随 UNION 一起使用时(即 UNION ALL),不消除重复行。两种情况下,派生表的
7、每一行不是来自 TABLE1 就是来自 TABLE2。 B: EXCEPT 运算符 EXCEPT 运算符通过包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重复行而派生出一个结果表。当 ALL 随 EXCEPT 一起使用时 (EXCEPT ALL),不消除重复行。 C: INTERSECT 运算符 INTERSECT 运算符通过只包括 TABLE1 和 TABLE2 中都有的行并消除所有重复行而派生出一个结果表。当 ALL 随 INTERSECT 一起使用时 (INTERSECT ALL),不消除重复行。 注:使用运算词的几个查询结果行必须是一致的。使用外连接 A、left
8、outer join: 左外连接(左连接):结果集既包括连接表的匹配行,也包括左连接表的所有行。 SQL: select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c B:right outer join: 右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行。 C:full outer join: 全外连接:不仅包括符号连接表的匹配行,还包括两个连接表中的所有记录。编辑本段提升复制表 (只复制结构,源表名:a 新表名:b) (Access可用) 法一:select * into b fr
9、om a where 1<>1 法二:select top 0 * into b from a拷贝表 (拷贝数据,源表名:a 目标表名:b) (Access可用) insert into b(a, b, c) select d,e,f from b;跨数据库之间表的拷贝 (具体数据使用绝对路径) (Access可用) insert into b(a, b, c) select d,e,f from b in 具体数据库 where 条件 例子:.from b in '"&Server.MapPath("."&"data
10、.mdb" &"' where.子查询 (表名1:a 表名2:b) select a,b,c from a where a IN (select d from b 或者: select a,b,c from a where a IN (1,2,3)显示文章、提交人和最后回复时间 select a.title,a.username,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b外连接查询 (表名1:a 表名2:b) selec
11、t a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c在线视图查询 (表名1:a select * from (Select a,b,c FROM a) T where t.a > 1;between的用法 between限制查询数据范围时包括了边界值,not between不包括 select * from table1 where time between time1 and time2 select a,b,c, from table1 where a not between 数值1 and 数值2in
12、的使用方法 select * from table1 where a not in (值1,值2,值4,值6)删除主表中已经在副表中没有的信息 两张关联表delete from table1 where not exists ( select * from table2 where table1.field1=table2.field1四表联查问题 select * from a left inner join b on a.a=b.b right inner join c on a.a=c.c inner join d on a.a=d.d where .日程安排提前五分钟提醒 SQL: s
13、elect * from 日程安排 where datediff('minute',f开始时间,getdate()>5一条sql 语句搞定数据库分页 select top 10 b.* from (select top 20 主键字段,排序字段 from 表名 order by 排序字段 desc) a,表名 b where b.主键字段 = a.主键字段 order by a.排序字段前10条记录 select top 10 * form table1 where 范围选择排名 选择在每一组b值相同的数据中对应的a最大的记录的所有信息(类似这样的用法可以用于论坛每月排行
14、榜,每月热销产品分析,按科目成绩排名,等等.) select a,b,c from tablename ta where a=(select max(a) from tablename tb where tb.b=ta.b)派生结果表 包括所有在 TableA 中但不在 TableB和TableC 中的行并消除所有重复行而派生出一个结果表 (select a from tableA except (select a from tableB) except (select a from tableC)随机取出10条数据 select top 10 * from tablename order b
15、y newid()随机选择记录 select newid()删除重复记录 Delete from tablename where id not in (select max(id) from tablename group by col1,col2,.)列出数据库里所有的表名 select name from sysobjects where type='U'列出表里的所有的 select name from syscolumns where id=object_id('TableName')列示排列 列示type、vender、pcs字段,以type字段排列,
16、case可以方便地实现多重选择,类似select 中的case。 select type,sum(case vender when 'A' then pcs else 0 end),sum(case vender when 'C' then pcs else 0 end),sum(case vender when 'B' then pcs else 0 end) FROM tablename group by type 显示结果: type vender pcs 电脑 A 1 电脑 A 1 光盘 B 2 光盘 A 2 手机 B 3 手机 C 3初
17、始化表table1 TRUNCATE TABLE table1选择从10到15的记录 select top 5 * from (select top 15 * from table order by id asc) table_别名 order by id desc数据类型转换 declare numid int declare id varchar(50) set numid=2005 set id=convert(varchar,numid) 通过上述语句完成数据类型Int转换成varchar,其他转换类似,可参看convert函数编辑本段技巧1=1,1=2的使用 在SQL语句组合时用的较
18、多 “where 1=1” 是表示选择全部 “where 1=2”全部不选, 如: if strWhere !=' begin set strSQL = 'select count(*) as Total from ' + tblName + ' where ' + strWhere end else begin set strSQL = 'select count(*) as Total from ' + tblName + '' end 我们可以直接写成 set strSQL = 'select count(*
19、) as Total from ' + tblName + ' where 1=1 安定 '+ strWhere收缩数据库 -重建索引 DBCC REINDEX DBCC INDEXDEFRAG -收缩数据和日志 DBCC SHRINKDB DBCC SHRINKFILE压缩数据库 dbcc shrinkdatabase(dbname) 转移数据库给新用户以已存在用户权限 exec sp_change_users_login 'update_one','newname','oldname' go检查备份集 RESTORE
20、VERIFYONLY from disk='E:dvbbs.bak'修复数据库 Alter DATABASE dvbbs SET SINGLE_USER GO DBCC CHECKDB('dvbbs',repair_allow_data_loss) WITH TABLOCK GO Alter DATABASE dvbbs SET MULTI_USER GO日志清除 SET NOCOUNT ON DECLARE LogicalFileName sysname, MaxMinutes INT, NewSize INT USE tablename - 要操作的数据库名
21、 Select LogicalFileName = 'tablename_log', - 日志文件名 MaxMinutes = 10, - Limit on time allowed to wrap log. NewSize = 1 - 你想设定的日志文件的大小(M) - Setup / initialize DECLARE OriginalSize int Select OriginalSize = size FROM sysfiles Where name = LogicalFileName Select 'Original Size of ' + db_n
22、ame() + ' LOG is ' + CONVERT(VARCHAR(30),OriginalSize) + ' 8K pages or ' + CONVERT(VARCHAR(30),(OriginalSize*8/1024) + 'MB' FROM sysfiles Where name = LogicalFileName Create TABLE DummyTrans (DummyColumn char (8000) not null) DECLARE Counter INT, StartTime DATETIME, TruncLog
23、VARCHAR(255) Select StartTime = GETDATE(), TruncLog = 'BACKUP LOG ' + db_name() + ' WITH TRUNCATE_ONLY' DBCC SHRINKFILE (LogicalFileName, NewSize) EXEC (TruncLog) - Wrap the log if necessary. WHILE MaxMinutes > DATEDIFF (mi, StartTime, GETDATE() - time has not expired AND Original
24、Size = (Select size FROM sysfiles Where name = LogicalFileName) AND (OriginalSize * 8 /1024) > NewSize BEGIN - Outer loop. Select Counter = 0 WHILE (Counter < OriginalSize / 16) AND (Counter < 50000) BEGIN - update Insert DummyTrans VALUES ('Fill Log') Delete DummyTrans Select Count
25、er = Counter + 1 END EXEC (TruncLog) END Select 'Final Size of ' + db_name() + ' LOG is ' + CONVERT(VARCHAR(30),size) + ' 8K pages or ' + CONVERT(VARCHAR(30),(size*8/1024) + 'MB' FROM sysfiles Where name = LogicalFileName Drop TABLE DummyTrans SET NOCOUNT OFF更改某个表 exe
26、c sp_changeobjectowner 'tablename','dbo'存储更改全部表 Create PROCEDURE dbo.User_ChangeObjectOwnerBatch OldOwner as NVARCHAR(128), NewOwner as NVARCHAR(128) AS DECLARE Name as NVARCHAR(128) DECLARE Owner as NVARCHAR(128) DECLARE OwnerName as NVARCHAR(128) DECLARE curObject CURSOR FOR select
27、 'Name' = name, 'Owner' = user_name(uid) from sysobjects where user_name(uid)=OldOwner order by name OPEN curObject FETCH NEXT FROM curObject INTO Name, Owner WHILE(FETCH_STATUS=0) BEGIN if Owner=OldOwner begin set OwnerName = OldOwner + '.' + rtrim(Name) exec sp_changeobject
28、owner OwnerName, NewOwner end - select name,NewOwner,OldOwner FETCH NEXT FROM curObject INTO Name, Owner END close curObject deallocate curObject GOSQL SERVER中直接循环写入数据 declare i int set i=1 while i<30 begin insert into test (userid) values(i) set i=i+1 end一:数据库连接代码:SqlConnection objSqlConnection
29、= new SqlConnection ("server = ;uid = sa; pwd =;database =test");objSqlConnection.Open();二:数据库的添加记录代码: int i = 0; string s1 = "", s2 = "
30、" i = Convert.ToInt16(textBox1.Text); s1 = textBox2.Text; s2 = textBox3.Text;
31、; SqlConnection objSqlConnection = new SqlConnection("server = ;uid = sa; pwd =;database =test"); objSqlConnection.Open();
32、; MessageBox.Show("数据库连接成功", "好"); try
33、60; SqlCommand sqlcom = new SqlCommand("insert into info(id,name,sex) values( " + i + ",'" + s1 + "','" + s2 + "
34、9;)", objSqlConnection); sqlcom.ExecuteNonQuery(); MessageBox.Show("添加成功!&q
35、uot;, "啊"); catch (Exception a)
36、 MessageBox.Show(a.ToString(); MessageBox.
37、Show("添加成功!", "啊");三:数据库的修改代码: int i = 0; string s1 = "", s2 = ""
38、; s1 = textBox2.Text; s2 = textBox3.Text; if (textBox1.Text.Length = 0)
39、0; i = 0; else i = Convert.ToInt32(textBox1.Text); &
40、#160; SqlConnection objSqlConnection = new SqlConnection("server = ;uid = sa; pwd =;database =test"); objSqlConnection.Open(); Message
41、Box.Show("数据库连接成功", "好"); try SqlCommand s
42、qlcom = new SqlCommand("update info set name='"+s1+"',sex='"+s2+"'"+"where id=" + i, objSqlConnection); sqlcom.ExecuteNonQuery();
43、160; MessageBox.Show("修改成功!", "啊"); objSqlConnection.Close();
44、; catch (Exception a) MessageBox.Show(a.ToSt
45、ring(); 四:数据库的删除代码: int i = 0; string s1 = "", s2 = "" &
46、#160; s1 = textBox2.Text; s2 = textBox3.Text; if(textBox1.Text.Length=0)
47、60; i=0; else i = Convert.ToInt16(textBox1.Text); &
48、#160; SqlConnection objSqlConnection = new SqlConnection("server = ;uid = sa; pwd =;database =test"); &
49、#160;objSqlConnection.Open(); MessageBox.Show("数据库连接成功", "好"); try
50、 SqlCommand sqlcom = new SqlCommand("delete from info where id="+i, objSqlConnection); sqlcom.Execut
51、eNonQuery(); MessageBox.Show("删除成功!", "啊"); objSqlConnection.Close();
52、60; catch (Exception a)
53、160; MessageBox.Show(a.ToString(); 五:数据库的查询代码: 1.类开始:
54、0; DataTable dt1 = new DataTable(); SqlDataAdapter da1 = new SqlDataAdapter(); 2.按钮代码: &
55、#160; int i = 0,n=0; string s1 = "", s2 = "" s1 = textBox2.Text;
56、60; s2 = textBox3.Text; if (textBox1.Text.Length = 0) i = 0;
57、160; else i = Convert.ToInt32(textBox1.Text); SqlConnection objSqlConnection = new SqlConnection("server = ;u
58、id = sa; pwd =;database =test"); objSqlConnection.Open(); MessageBox.Show("数据库连接成功", "好"); &
59、#160; string query = "SELECT * from info where id="+i; DataSet objDataSet = new DataSet(); SqlDataAdapter obj = new SqlDataAd
60、apter(); obj.SelectCommand = new SqlCommand(query, objSqlConnection); obj.Fill(objDataSet, "i
61、nfo"); SqlCommand objSqlCommand = new SqlCommand(query, objSqlConnection); SqlDataReader objSqlReader = o
62、bjSqlCommand.ExecuteReader(); while (objSqlReader.Read()
63、0; n += 1; MessageBox.Show("编号: " + objSqlReader.Getvalue(0) + " 姓名:" + objSqlReader.Getvalue(1) + "
64、0; 性别" + objSqlReader.Getvalue(2); if (n = 0)
65、 MessageBox.Show("数据库中没有这样的记录!");六:数据库的查询代码: int i = 0; / int n = 0; &
66、#160; string s1 = "", s2 = "" string sql; s1 = textBox2.Text;
67、s2 = textBox3.Text; if (textBox1.Text.Length = 0) i = 0;
68、 else
69、160; i = Convert.ToInt32(textBox1.Text); SqlConnection objSqlConnection = new SqlConnection("server = ;uid = sa; pwd =;database =test");
70、160; objSqlConnection.Open(); MessageBox.Show("数据库连接成功", "好"); stri
71、ng query = "SELECT * from info where id="+i; if(i=0) sql = "select * from info "
72、0; else sql = "select * from info where id=" + i; da1 = new SqlDa
73、taAdapter(sql, objSqlConnection); dt1.Clear(); da1.Fill(dt1); dataGridView1.DataSource
74、= dt1;数据库的封装类代码:class DBClass public void dbclass(string sql) try
75、0; SqlConnection sqlcon = new SqlConnection("server = ;uid = sa; pwd =;database =test");
76、160; sqlcon.Open(); SqlTransaction objt = sqlcon.BeginTransaction(); /事物开始 SqlCommand sqlcom = new SqlCommand(sql, sqlcon);
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 《CB 562-1968胶管螺纹接头》专题研究报告
- 葫芦岛市公安机关2025年公开招聘警务辅助人员备考题库及答案详解一套
- 2025年白城市镇赉县人社局公开招聘47人备考题库及参考答案详解一套
- 中国科学院武汉病毒研究所第四季度集中招聘20人备考题库及参考答案详解1套
- 基于生成式AI的中学英语课堂阅读理解能力提升策略研究教学研究课题报告
- 2025江苏无锡市宜兴市部分机关事业单位招聘编外人员40人(A类)考试重点题库及答案解析
- 2025湖南益阳市南县人武部公开招聘编外聘用人员备考考试试题及答案解析
- 2025年海洋风电浮式基础技术五年发展与环境载荷报告
- 连南农商银行2026校园招聘备考核心试题附答案解析
- 2025四川内江隆昌市响石镇中心学校招聘1人考试重点题库及答案解析
- 2025安徽淮北相山区招考村(社区)后备干部66人模拟笔试试题及答案解析
- 扫床护理课件
- 酒厂合作协议书合同
- 空气能热泵中央热水系统调试
- JJF2085-2023低频角加速度台校准规范
- 《校园欺凌现象与学校社会工作干预的探索》14000字论文
- 微积分(I)知到智慧树章节测试课后答案2024年秋南昌大学
- AQ 1050-2008 保护层开采技术规范(正式版)
- MOOC 大数据与法律检索-湖南师范大学 中国大学慕课答案
- JTS180-2-2011 运河通航标准
- 肺癌健康教育宣教
评论
0/150
提交评论