當前位置:首頁 » 編程語言 » sql添加修改
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

sql添加修改

發布時間: 2023-02-08 11:48:50

Ⅰ Mybatis 常用sql之批量添加和修改

Dao層

int updateByList(List list);

Mappe層

批量修改

<update id="updateByList" parameterType="java.util.List">

<foreach collection="list" item="item" index="index" separator=";">

update jt_fin_repayment_plan

<set >

erestTotal != null" >

ORG_INTEREST_TOTAL = #{item.orgInterestTotal},

</if>

<if test="item.delFlag != null" >

DEL_FLAG = #{item.delFlag},

</if>

<if test="item.state != null" >

STATE = #{item.state},

</if>

<if test="item.createBy != null" >

CREATE_BY = #{item.createBy},

</if>

<if test="item.createTime != null" >

CREATE_TIME = #{item.createTime},

</if>

<if test="item.updateBy != null" >

UPDATE_BY = #{item.updateBy},

</if>

UPDATE_TIME = #{NOW(),

</set>

where REPAYMENT_ID = #{item.repaymentId}

</foreach>

</update>

----------------------------------------------------------------------------------------------------------



//批量添加

int addList(List list);

Map層

批量添加

<insert id="addList" parameterType="java.util.List">

insert into jt_fin_adjust_rates_project_history (

ID,ADJUST_RATES_ID,PROJECT_ID,START_WHOLE,

END_WHOLE,START_WITHOUT,END_WITHOUT,PROJECT_DATE,

KEEP,AUDIT_FLAG,STATUS,REMARK,DEL_FLAG,

CREATE_BY,CREATE_TIME,UPDATE_TIME,UPDATE_BY

)

values

<foreach collection="list" separator="," item="item" index="index">

((select UUID()), #{item.adjustRatesId},#{item.projectId},#{item.startWhole},

#{item.endWhole},#{item.startWithout},#{item.endWithout},#{item.projectDate},

#{item.keep},#{item.auditFlag},#{item.status},#{item.remark},#{item.delFlag},

#{item.createBy},sysdate(), #{item.updateTime}, #{item.updateBy})

</foreach>

</insert>

注意:我的id VARCHAR類型 主鍵 不能遞增 在這里我用的是UUID生成的

原本,想寫一個批量添加,回顯id但是沒實現就不寫了,有大佬可以補充一下

Ⅱ 【求】 一些常用的SQL 添加 查詢 修改語句

(1) 數據記錄篩選:

sql="select * from 數據表 where 欄位名=欄位值 order by 欄位名 "
sql="select * from 數據表 where 欄位名 like 『%欄位值%『 order by 欄位名 "
sql="select top 10 * from 數據表 where 欄位名 order by 欄位名 "
sql="select * from 數據表 where 欄位名 in (『值1『,『值2『,『值3『)"
sql="select * from 數據表 where 欄位名 between 值1 and 值2"

(2) 更新數據記錄:

sql="update 數據表 set 欄位名=欄位值 where 條件表達式"
sql="update 數據表 set 欄位1=值1,欄位2=值2 …… 欄位n=值n where 條件表達式"

(3) 刪除數據記錄:

sql="delete from 數據表 where 條件表達式"
sql="delete from 數據表" (將數據表所有記錄刪除)

(4) 添加數據記錄:

sql="insert into 數據表 (欄位1,欄位2,欄位3 …) valuess (值1,值2,值3 …)"
sql="insert into 目標數據表 select * from 源數據表" (把源數據表的記錄添加到目標數據表)

(5) 數據記錄統計函數:

AVG(欄位名) 得出一個表格欄平均值
COUNT(*|欄位名) 對數據行數的統計或對某一欄有值的數據行數統計
MAX(欄位名) 取得一個表格欄最大的值
MIN(欄位名) 取得一個表格欄最小的值
SUM(欄位名) 把數據欄的值相加

引用以上函數的方法:

sql="select sum(欄位名) as 別名 from 數據表 where 條件表達式"
set rs=conn.excute(sql)

用 rs("別名") 獲取統的計值,其它函數運用同上。

(5) 數據表的建立和刪除:

CREATE TABLE 數據表名稱(欄位1 類型1(長度),欄位2 類型2(長度) …… )

例:CREATE TABLE tab01(name varchar(50),datetime default now())

DROP TABLE 數據表名稱 (永久性刪除一個數據表)

(6) 記錄集對象的方法:
rs.movenext 將記錄指針從當前的位置向下移一行
rs.moveprevious 將記錄指針從當前的位置向上移一行
rs.movefirst 將記錄指針移到數據表第一行
rs.movelast 將記錄指針移到數據表最後一行
rs.absoluteposition=N 將記錄指針移到數據表第N行
rs.absolutepage=N 將記錄指針移到第N頁的第一行
rs.pagesize=N 設置每頁為N條記錄
rs.pagecount 根據 pagesize 的設置返回總頁數
rs.recordcount 返回記錄總數
rs.bof 返回記錄指針是否超出數據表首端,true表示是,false為否
rs.eof 返回記錄指針是否超出數據表末端,true表示是,false為否
rs.delete 刪除當前記錄,但記錄指針不會向下移動
rs.addnew 添加記錄到數據表末端
rs.update 更新數據表記錄

判斷所填數據是數字型

if not isNumeric(request("欄位名稱")) then
response.write "不是數字"
else
response.write "數字"
end if

Ⅲ sql修改欄位值的范圍

1、欄位的修改
增加欄位
ALTER TABLE <表名> ADD <新欄位名><數據類型>[約束條件]

對語法格式的說明如下:

1.<表名> 為數據表的名字;

2.<新欄位名> 為所要添加的欄位的名字;

3.<數據類型> 為所要添加的欄位能存儲數據的數據類型;

4.[約束條件] 是可選的,用來對添加的欄位進行約束。

SQL 默認在表的最後位置添加新欄位,如果希望在開頭位置(第一列的前面)添加新欄位,那麼可以使用 FIRST 關鍵字,語法格式如下:

ALTER TABLE <表名> ADD <新欄位名> <數據類型> [約束條件] FIRST;

-- 給actor表首位添加create_date欄位
ALTER TABLE actor ADD COLUMN create_date datetime not null DEFAULT '2020-10-01 00:00:00' FIRST;
復制
刪除欄位
ALTER TABLE <表名> DROP COLUMN <欄位名>

-- 將actor_new表的actor_id欄位刪除
alter table actor_new drop column actor_id;
復制
修改欄位
1.修改欄位名

ALTER TABLE <表名> RENAME COLUMN A to B

-- 將actor_new表的first_name欄位名修改為first_name_new
alter table actor_new rename column first_name to first_name_new;
復制
2.修改欄位類型

ALTER TABLE <表名> MODIFY COLUMN <欄位名> <類型>

-- 將last_name欄位數據類型由varchar(45)修改為char(45)
alter table actor_new modify column last_name char(45) not null;
復制
3.修改欄位默認值

ALTER TABLE <表名> ALTER COLUMN <欄位名> SET DEFAULT <默認值>

若欄位有默認值,則需要先刪除欄位的約束,在添加新的默認值

根據約束名稱刪除約束

alter table <表名> alter column <欄位名> drop default

-- 若本身存在默認值,則先刪除
alter table actor_new alter column last_name drop default;
-- 給last_name添加默認值'洛'
alter table actor_new alter column last_name set default '洛';
復制
4.修改欄位位置

將欄位的位置修改為數據表的開頭位置,使用FIRST關鍵字將當前欄位修改為數據表的第一個欄位

ALTER TABLE <表名> MODIFY <欄位名> <數據類型> FIRST

-- 將欄位first_name調整到actor表的首位
ALTER TABLE actor modify first_name varchar(45) FIRST;
復制
將選中欄位修改到某欄位之後

ALTER TABLE <表名> MODIFY <欄位1名稱> <欄位1數據類型> AFTER <欄位2名稱>

-- 將欄位first_name調整到last_name之後
ALTER TABLE actor MODIFY first_name varchar(45) AFTER last_name;
復制
2、數據的修改
增加數據
添加數據在SQL篇-創建數據表中有粗略的介紹,這里進行詳細說明

1.插入一條新的數據 INSERT INTO <表名>[(列1,列2,列3,…)]VALUES(值1,值2,值3,…)

-- 插入數據的sql語句
insert into tablename(col1,col2,col3) values (value1,value2,value3);
復制
2.通過子查詢插入數據 INSERT INTO <表名>[(列1,列2,列3,…)]子查詢

-- 把actor_id=10的用戶復制一遍
insert into tablename SELECT * FROM actor WHERE actor_id=10;
復制
刪除數據
DELETE FROM <表名> [WHERE 刪除條件]

注意:不寫刪除條件表示刪除全部!

-- 刪除演員編號是6的演員信息
delete from actor WHERE actor_id=6;
復制
更新數據
1.指定要更新數據的內容

UPDATE <表名> SET [欄位=值,欄位=值…][WHERE 更新條件]

-- 將SMITH(雇員編號為7)的工資修改為3000元,並且每個月有500元的獎金
update myemp set sal=3000,comm=500 where empno=7;
2.基於子查詢的更新

UPDATE <表名> SET (列1,列2,…)=(SELECT 列1,列2,…FROM <表名>) [WHERE 查詢條件]

-- 將雇員7369的職位、基本工資、僱傭日期更新為與7839相同的信息
update myemp set (job,sal,hiredate) = (select job,sal,hiredate from myemp where empno=7839) where empno=7369;
3.更新替換

-- 將address欄位里的 「東」 替換為 「西」 ,如下
update test_tb set address=replace(address,'東','西') where id=2
4.插入替換

-- 將id=6的name欄位值改為wokou
replace into test_tb VALUES(6,'wokou','新九州島','日本')
注意:插入替換時,若進行部分替換,則表其餘欄位要有默認值,否則,要列出該列的所有值

總結:向表中「替換插入」一條數據,如果原表中沒有id=6這條數據就作為新數據插入(相當於insert into作用),
如果原表中有id=6這條數據就做替換(相當於update作用),對於沒有指定的欄位以默認值插入。

Ⅳ 表單中添加、修改和刪除的sql語句

1 使用insert插入數據行
Insert [into] <表名> [列名] values <值>
例如:insert into user1 (username,sex,idcard,birthday,email,rpwt)
values ('小黑','男','411083','1984/5/6','[email protected]','良好')
2 使用update修改數據
Update <表名> set <列名=更新值> [where <更新條件>]
例如:update user4 set sex='女' where rpwt='良好'
3 使用delete刪除數據
Delete fro <表名> [where <刪除條件>]
例如:delete from user2 where sex='男'

Ⅳ SQL語句怎麼添加刪除修改欄位

我們使用資料庫的時候經常需要操作欄位,那麼如何使用SQL進行欄位的增刪改呢?下面我給大家分享一下。

工具/材料

SQL Server Managment

首先我們打開SQL Server Managment,准備一個數據表,如下圖所示

然後我們就可以通過SQL中的Add語句進行欄位的增加,如下圖所示

接下來可以通過alter column進行欄位的修改,如下圖所示

最後通過drop column進行欄位的刪除,如下圖所示