mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 07:48:51 +00:00 
			
		
		
		
	 287b84de93
			
		
	
	
		287b84de93
		
	
	
	
	
		
			
			The sqlit3.Connection object doesn't call its close() method when it's used as a context manager.
		
			
				
	
	
		
			24 lines
		
	
	
	
		
			611 B
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			24 lines
		
	
	
	
		
			611 B
		
	
	
	
		
			Python
		
	
	
	
	
	
| import sqlite3
 | |
| 
 | |
| persons = [
 | |
|     ("Hugo", "Boss"),
 | |
|     ("Calvin", "Klein")
 | |
|     ]
 | |
| 
 | |
| con = sqlite3.connect(":memory:")
 | |
| 
 | |
| # Create the table
 | |
| con.execute("create table person(firstname, lastname)")
 | |
| 
 | |
| # Fill the table
 | |
| con.executemany("insert into person(firstname, lastname) values (?, ?)", persons)
 | |
| 
 | |
| # Print the table contents
 | |
| for row in con.execute("select firstname, lastname from person"):
 | |
|     print(row)
 | |
| 
 | |
| print("I just deleted", con.execute("delete from person").rowcount, "rows")
 | |
| 
 | |
| # close is not a shortcut method and it's not called automatically,
 | |
| # so the connection object should be closed manually
 | |
| con.close()
 |