sql server2008r2 添加、修改、删除、查询

1.插入数据行

insert [into] 表名 [(列名)] values(值列表)

例:在对应的数据库school中新建查询,insert into+表名students(列名)+values+(值列表)

insert into students(name,address,grade,emaill,sex)
values('张青ming',DEFAULT,1,'zhang@163',1)

2.通过 insert select 语句将现有表中的数据添加到已存在的表中去

insert into <表名>(列名) select <列名> from <源表名>

例:

insert into new_table(uname,uaddress)
select name,address
from students

3.通过select into 语句将现有表中的数据添加到新表中(适用于备份表,只可用一次)

select <列名> into(表名) from <源表名>

例:

select name,address,grade,emaill,sex
into student_bak
from students

4.通过 union 关键字合并数据进行插入

insert into <列名>(表名)

select <列名> union

select <列名> union

select <列名> union

......

例:

insert into students(name,address,grade,emaill,sex)
select '大宝','湖北',1,null,1 union
select '二宝','湖北',1,null,1 union
select '三宝','湖北',1,null,1

5.使用 update 更新数据行

update <表名> set 列名 = 更新值,列名 = 更新值....[where 更新条件]

例:

update students set name = '张清山' where name = '张青ming'
update students set grade = grade + 90 where grade <=90
update students set name = 'zhangwen',address = '湖北chacha' where code = 3

6.使用 delete 删除数据行

delete [from] <表名> [where<删除条件>]

例:

delete from students where address = ''

7.使用truncate 删除数据行

truncate table 表名

例:truncate table students 

相当于:delete from students 

8.查询语法

select <列名> from <表名> [where <查询条件>] [order by <排序的列名>[asc或desc]]

例:

select code,name,address from students where sex =1 order by code 
select * from students where sex =1 order by code 
select * from students order by code 
select * from students 

9.使用as命名列

例:

select code as '编号',name as '姓名',address as '地址' from students
select  '编号'= code,'姓名' = name,'地址' = address from students
select grade + 5 as '成绩加5显示'from students

 

10.限制行数

限制固定行数

例:

select top 5 * from students
select top 5 name,address from students
select top 5 name,address from students where sex = 1

按百分比返回

select top 20 percent * from students 
select top 20 percent name,address from students
select top 20 percent name,address from students where sex = 1

 11.排序

升序排序

select * from students order by grade  
select * from students order by grade asc

降序

select * from students order by grade desc

多列排序

select * from students order by grade,code 
select * from students order by grade desc,code desc

 

转载于:https://www.cnblogs.com/pengp/p/7520004.html

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQL Server 2008 R2 中,没有内置的 FOR JSON 子句,但你可以使用 SQLCLR 扩展来实现将查询结果集转换为 JSON 格式。 以下是一个使用 SQLCLR 扩展的示例: 1. 创建 C# 项目,添加 System.Web.Extensions 引用。 2. 在项目中添加以下代码: ``` using System; using System.Data; using System.Data.SqlClient; using System.Web.Script.Serialization; using System.Collections.Generic; using Microsoft.SqlServer.Server; public partial class StoredProcedures { [SqlProcedure] public static void QueryToJson(SqlString sqlQuery, out SqlString jsonString) { // Create a connection to the database using (SqlConnection conn = new SqlConnection("context connection=true")) { conn.Open(); // Create a command to execute the query SqlCommand cmd = new SqlCommand(sqlQuery.Value, conn); // Execute the query and get the results SqlDataReader reader = cmd.ExecuteReader(); DataTable dt = new DataTable(); dt.Load(reader); // Convert the results to JSON var rows = new List<Dictionary<string, object>>(); foreach (DataRow row in dt.Rows) { var dict = new Dictionary<string, object>(); foreach (DataColumn col in dt.Columns) { dict[col.ColumnName] = row[col]; } rows.Add(dict); } var serializer = new JavaScriptSerializer(); jsonString = serializer.Serialize(rows); } } } ``` 3. 编译项目,并将生成的 DLL 文件部署到 SQL Server 中。 4. 创建存储过程,调用上面的 QueryToJson 方法: ``` CREATE PROCEDURE QueryToJson(@sqlQuery NVARCHAR(MAX), @jsonString NVARCHAR(MAX) OUT) AS EXTERNAL NAME YourAssembly.StoredProcedures.QueryToJson ``` 5. 调用存储过程,并传递要执行的查询语句: ``` DECLARE @jsonString NVARCHAR(MAX) EXEC QueryToJson 'SELECT id, name, age FROM mytable', @jsonString OUT SELECT @jsonString ``` 这将返回一个 JSON 格式的字符串,其中包含查询结果集的所有行和列。你可以使用类似的方法来构建更复杂的 JSON 结构。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值