Python SQLite-데이터 삭제
SQLite 테이블에서 레코드를 삭제하려면 DELETE FROM 문을 사용해야합니다. 특정 레코드를 제거하려면 WHERE 절을 함께 사용해야합니다.
특정 행을 업데이트하려면 WHERE 절을 함께 사용해야합니다.
통사론
다음은 SQLite의 DELETE 쿼리 구문입니다.
DELETE FROM table_name [WHERE Clause]
예
다음 쿼리를 사용하여 이름이 CRICKETERS 인 테이블을 생성했다고 가정합니다.
sqlite> CREATE TABLE CRICKETERS (
First_Name VARCHAR(255),
Last_Name VARCHAR(255),
Age int,
Place_Of_Birth VARCHAR(255),
Country VARCHAR(255)
);
sqlite>
그리고 INSERT 문을 사용하여 5 개의 레코드를 삽입했다면-
sqlite> insert into CRICKETERS values('Shikhar', 'Dhawan', 33, 'Delhi', 'India');
sqlite> insert into CRICKETERS values('Jonathan', 'Trott', 38, 'CapeTown', 'SouthAfrica');
sqlite> insert into CRICKETERS values('Kumara', 'Sangakkara', 41, 'Matale', 'Srilanka');
sqlite> insert into CRICKETERS values('Virat', 'Kohli', 30, 'Delhi', 'India');
sqlite> insert into CRICKETERS values('Rohit', 'Sharma', 32, 'Nagpur', 'India');
sqlite>
다음 문장은 성이 '상악 카라'인 크리켓 선수의 기록을 삭제합니다.
sqlite> DELETE FROM CRICKETERS WHERE LAST_NAME = 'Sangakkara';
sqlite>
SELECT 문을 사용하여 테이블의 내용을 검색하면 하나를 삭제했기 때문에 4 개의 레코드 만 볼 수 있습니다.
sqlite> SELECT * FROM CRICKETERS;
First_Name Last_Name Age Place_Of_B Country
---------- ---------- ---- ---------- -------------
Shikhar Dhawan 46 Delhi India
Jonathan Trott 39 CapeTown SouthAfrica
Virat Kohli 31 Delhi India
Rohit Sharma 33 Nagpur India
sqlite>
WHERE 절없이 DELETE FROM 문을 실행하면 지정된 테이블의 모든 레코드가 삭제됩니다.
sqlite> DELETE FROM CRICKETERS;
sqlite>
모든 레코드를 삭제 했으므로 CRICKETERS 테이블의 내용을 검색하려고하면 SELECT 문을 사용하여 아래와 같이 빈 결과 집합을 얻게됩니다.
sqlite> SELECT * FROM CRICKETERS;
sqlite>
Python을 사용하여 데이터 삭제
SQLite 데이터베이스의 기존 테이블에 레코드를 추가하려면-
sqlite3 패키지를 가져옵니다.
데이터베이스 이름을 매개 변수로 전달 하여 connect () 메서드를 사용하여 연결 객체를 만듭니다 .
그만큼 cursor()메서드는 SQLite3와 통신 할 수있는 커서 객체를 반환합니다. (위에서 만든) Connection 객체에서 cursor () 객체를 호출하여 커서 객체를 만듭니다.
그런 다음 DELETE 문을 매개 변수로 전달하여 커서 개체에서 execute () 메서드를 호출합니다.
예
다음 python 예제는 나이 값이 25보다 큰 EMPLOYEE 테이블에서 레코드를 삭제합니다.
import sqlite3
#Connecting to sqlite
conn = sqlite3.connect('example.db')
#Creating a cursor object using the cursor() method
cursor = conn.cursor()
#Retrieving contents of the table
print("Contents of the table: ")
cursor.execute('''SELECT * from EMPLOYEE''')
print(cursor.fetchall())
#Deleting records
cursor.execute('''DELETE FROM EMPLOYEE WHERE AGE > 25''')
#Retrieving data after delete
print("Contents of the table after delete operation ")
cursor.execute("SELECT * from EMPLOYEE")
print(cursor.fetchall())
#Commit your changes in the database
conn.commit()
#Closing the connection
conn.close()
산출
Contents of the table:
[('Ramya', 'Rama priya', 27, 'F', 9000.0),
('Vinay', 'Battacharya', 21, 'M', 6000.0),
('Sharukh', 'Sheik', 26, 'M', 8300.0),
('Sarmista', 'Sharma', 26, 'F', 10000.0),
('Tripthi', 'Mishra', 24, 'F', 6000.0)]
Contents of the table after delete operation
[('Vinay', 'Battacharya', 21, 'M', 6000.0),
('Tripthi', 'Mishra', 24, 'F', 6000.0)]