1. '''SQLite数据库是一款非常小巧的嵌入式开源数据库软件,也就是说
  2. 没有独立的维护进程,所有的维护都来自于程序本身。
  3. 在python中,使用sqlite3创建数据库的连接,当我们指定的数据库文件不存在的时候
  4. 连接对象会自动创建数据库文件;如果数据库文件已经存在,则连接对象不会再创建
  5. 数据库文件,而是直接打开该数据库文件。
  6. 连接对象可以是硬盘上面的数据库文件,也可以是建立在内存中的,在内存中的数据库
  7. 执行完任何操作后,都不需要提交事务的(commit)
  8.  
  9. 创建在硬盘上面: conn = sqlite3.connect('c:\\test\\test.db')
  10. 创建在内存上面: conn = sqlite3.connect('"memory:')
  11.  
  12. 下面我们一硬盘上面创建数据库文件为例来具体说明:
  13. conn = sqlite3.connect('c:\\test\\hongten.db')
  14. 其中conn对象是数据库链接对象,而对于数据库链接对象来说,具有以下操作:
  15.  
  16. commit() --事务提交
  17. rollback() --事务回滚
  18. close() --关闭一个数据库链接
  19. cursor() --创建一个游标
  20.  
  21. cu = conn.cursor()
  22. 这样我们就创建了一个游标对象:cu
  23. 在sqlite3中,所有sql语句的执行都要在游标对象的参与下完成
  24. 对于游标对象cu,具有以下具体操作:
  25.  
  26. execute() --执行一条sql语句
  27. executemany() --执行多条sql语句
  28. close() --游标关闭
  29. fetchone() --从结果中取出一条记录
  30. fetchmany() --从结果中取出多条记录
  31. fetchall() --从结果中取出所有记录
  32. scroll() --游标滚动
  33.  
  34. '''

下面是我做的demo,在demo中,我做了很详细的注释和功能的演示,详情如下:

运行效果:

SHOW_SQL = False的时候:

  1. Python 3.3.2 (v3.3.2:d047928ae3f6, May 16 2013, 00:03:43) [MSC v.1600 32 bit (Intel)] on win32
  2. Type "copyright", "credits" or "license()" for more information.
  3. >>> ================================ RESTART ================================
  4. >>>
  5. show_sql : False
  6. 删除数据库表测试...
  7. 硬盘上面:[c:\test\hongten.db]
  8. 删除数据库表[student]成功!
  9. 创建数据库表测试...
  10. 硬盘上面:[c:\test\hongten.db]
  11. 创建数据库表[student]成功!
  12. 保存数据测试...
  13. 硬盘上面:[c:\test\hongten.db]
  14. 查询所有数据...
  15. 硬盘上面:[c:\test\hongten.db]
  16. (1, 'Hongten', '男', 20, '广东省广州市', '13423****62')
  17. (2, 'Tom', '男', 22, '美国旧金山', '15423****63')
  18. (3, 'Jake', '女', 18, '广东省广州市', '18823****87')
  19. (4, 'Cate', '女', 21, '广东省广州市', '14323****32')
  20. ##################################################
  21. 查询一条数据...
  22. 硬盘上面:[c:\test\hongten.db]
  23. (1, 'Hongten', '男', 20, '广东省广州市', '13423****62')
  24. ##################################################
  25. 更新数据...
  26. 硬盘上面:[c:\test\hongten.db]
  27. 查询所有数据...
  28. 硬盘上面:[c:\test\hongten.db]
  29. (1, 'HongtenAA', '男', 20, '广东省广州市', '13423****62')
  30. (2, 'HongtenBB', '男', 22, '美国旧金山', '15423****63')
  31. (3, 'HongtenCC', '女', 18, '广东省广州市', '18823****87')
  32. (4, 'HongtenDD', '女', 21, '广东省广州市', '14323****32')
  33. ##################################################
  34. 删除数据...
  35. 硬盘上面:[c:\test\hongten.db]
  36. 查询所有数据...
  37. 硬盘上面:[c:\test\hongten.db]
  38. (2, 'HongtenBB', '男', 22, '美国旧金山', '15423****63')
  39. (4, 'HongtenDD', '女', 21, '广东省广州市', '14323****32')
  40. >>>

SHOW_SQL = True的时候:

  1. Python 3.3.2 (v3.3.2:d047928ae3f6, May 16 2013, 00:03:43) [MSC v.1600 32 bit (Intel)] on win32
  2. Type "copyright", "credits" or "license()" for more information.
  3. >>> ================================ RESTART ================================
  4. >>>
  5. show_sql : True
  6. 删除数据库表测试...
  7. 硬盘上面:[c:\test\hongten.db]
  8. 执行sql:[DROP TABLE IF EXISTS student]
  9. 删除数据库表[student]成功!
  10. 创建数据库表测试...
  11. 硬盘上面:[c:\test\hongten.db]
  12. 执行sql:[CREATE TABLE `student` (
  13. `id` int(11) NOT NULL,
  14. `name` varchar(20) NOT NULL,
  15. `gender` varchar(4) DEFAULT NULL,
  16. `age` int(11) DEFAULT NULL,
  17. `address` varchar(200) DEFAULT NULL,
  18. `phone` varchar(20) DEFAULT NULL,
  19. PRIMARY KEY (`id`)
  20. )]
  21. 创建数据库表[student]成功!
  22. 保存数据测试...
  23. 硬盘上面:[c:\test\hongten.db]
  24. 执行sql:[INSERT INTO student values (?, ?, ?, ?, ?, ?)],参数:[(1, 'Hongten', '男', 20, '广东省广州市', '13423****62')]
  25. 执行sql:[INSERT INTO student values (?, ?, ?, ?, ?, ?)],参数:[(2, 'Tom', '男', 22, '美国旧金山', '15423****63')]
  26. 执行sql:[INSERT INTO student values (?, ?, ?, ?, ?, ?)],参数:[(3, 'Jake', '女', 18, '广东省广州市', '18823****87')]
  27. 执行sql:[INSERT INTO student values (?, ?, ?, ?, ?, ?)],参数:[(4, 'Cate', '女', 21, '广东省广州市', '14323****32')]
  28. 查询所有数据...
  29. 硬盘上面:[c:\test\hongten.db]
  30. 执行sql:[SELECT * FROM student]
  31. (1, 'Hongten', '男', 20, '广东省广州市', '13423****62')
  32. (2, 'Tom', '男', 22, '美国旧金山', '15423****63')
  33. (3, 'Jake', '女', 18, '广东省广州市', '18823****87')
  34. (4, 'Cate', '女', 21, '广东省广州市', '14323****32')
  35. ##################################################
  36. 查询一条数据...
  37. 硬盘上面:[c:\test\hongten.db]
  38. 执行sql:[SELECT * FROM student WHERE ID = ? ],参数:[1]
  39. (1, 'Hongten', '男', 20, '广东省广州市', '13423****62')
  40. ##################################################
  41. 更新数据...
  42. 硬盘上面:[c:\test\hongten.db]
  43. 执行sql:[UPDATE student SET name = ? WHERE ID = ? ],参数:[('HongtenAA', 1)]
  44. 执行sql:[UPDATE student SET name = ? WHERE ID = ? ],参数:[('HongtenBB', 2)]
  45. 执行sql:[UPDATE student SET name = ? WHERE ID = ? ],参数:[('HongtenCC', 3)]
  46. 执行sql:[UPDATE student SET name = ? WHERE ID = ? ],参数:[('HongtenDD', 4)]
  47. 查询所有数据...
  48. 硬盘上面:[c:\test\hongten.db]
  49. 执行sql:[SELECT * FROM student]
  50. (1, 'HongtenAA', '男', 20, '广东省广州市', '13423****62')
  51. (2, 'HongtenBB', '男', 22, '美国旧金山', '15423****63')
  52. (3, 'HongtenCC', '女', 18, '广东省广州市', '18823****87')
  53. (4, 'HongtenDD', '女', 21, '广东省广州市', '14323****32')
  54. ##################################################
  55. 删除数据...
  56. 硬盘上面:[c:\test\hongten.db]
  57. 执行sql:[DELETE FROM student WHERE NAME = ? AND ID = ? ],参数:[('HongtenAA', 1)]
  58. 执行sql:[DELETE FROM student WHERE NAME = ? AND ID = ? ],参数:[('HongtenCC', 3)]
  59. 查询所有数据...
  60. 硬盘上面:[c:\test\hongten.db]
  61. 执行sql:[SELECT * FROM student]
  62. (2, 'HongtenBB', '男', 22, '美国旧金山', '15423****63')
  63. (4, 'HongtenDD', '女', 21, '广东省广州市', '14323****32')
  64. >>>

=========================================

具体代码:

=========================================

  1. #python sqlite
  2.  
  3. #Author : Hongten
  4. #MailTo : hongtenzone@foxmail.com
  5. #QQ : 648719819
  6. #Blog : http://www.cnblogs.com/hongten
  7. #Create : 2013-08-09
  8. #Version: 1.0
  9.  
  10. #DB-API 2.0 interface for SQLite databases
  11.  
  12. import sqlite3
  13. import os
  14. '''SQLite数据库是一款非常小巧的嵌入式开源数据库软件,也就是说
  15. 没有独立的维护进程,所有的维护都来自于程序本身。
  16. 在python中,使用sqlite3创建数据库的连接,当我们指定的数据库文件不存在的时候
  17. 连接对象会自动创建数据库文件;如果数据库文件已经存在,则连接对象不会再创建
  18. 数据库文件,而是直接打开该数据库文件。
  19. 连接对象可以是硬盘上面的数据库文件,也可以是建立在内存中的,在内存中的数据库
  20. 执行完任何操作后,都不需要提交事务的(commit)
  21.  
  22. 创建在硬盘上面: conn = sqlite3.connect('c:\\test\\test.db')
  23. 创建在内存上面: conn = sqlite3.connect('"memory:')
  24.  
  25. 下面我们一硬盘上面创建数据库文件为例来具体说明:
  26. conn = sqlite3.connect('c:\\test\\hongten.db')
  27. 其中conn对象是数据库链接对象,而对于数据库链接对象来说,具有以下操作:
  28.  
  29. commit() --事务提交
  30. rollback() --事务回滚
  31. close() --关闭一个数据库链接
  32. cursor() --创建一个游标
  33.  
  34. cu = conn.cursor()
  35. 这样我们就创建了一个游标对象:cu
  36. 在sqlite3中,所有sql语句的执行都要在游标对象的参与下完成
  37. 对于游标对象cu,具有以下具体操作:
  38.  
  39. execute() --执行一条sql语句
  40. executemany() --执行多条sql语句
  41. close() --游标关闭
  42. fetchone() --从结果中取出一条记录
  43. fetchmany() --从结果中取出多条记录
  44. fetchall() --从结果中取出所有记录
  45. scroll() --游标滚动
  46.  
  47. '''
  48.  
  49. #global var
  50. #数据库文件绝句路径
  51. DB_FILE_PATH = ''
  52. #表名称
  53. TABLE_NAME = ''
  54. #是否打印sql
  55. SHOW_SQL = True
  56.  
  57. def get_conn(path):
  58. '''获取到数据库的连接对象,参数为数据库文件的绝对路径
  59. 如果传递的参数是存在,并且是文件,那么就返回硬盘上面改
  60. 路径下的数据库文件的连接对象;否则,返回内存中的数据接
  61. 连接对象'''
  62. conn = sqlite3.connect(path)
  63. if os.path.exists(path) and os.path.isfile(path):
  64. print('硬盘上面:[{}]'.format(path))
  65. return conn
  66. else:
  67. conn = None
  68. print('内存上面:[:memory:]')
  69. return sqlite3.connect(':memory:')
  70.  
  71. def get_cursor(conn):
  72. '''该方法是获取数据库的游标对象,参数为数据库的连接对象
  73. 如果数据库的连接对象不为None,则返回数据库连接对象所创
  74. 建的游标对象;否则返回一个游标对象,该对象是内存中数据
  75. 库连接对象所创建的游标对象'''
  76. if conn is not None:
  77. return conn.cursor()
  78. else:
  79. return get_conn('').cursor()
  80.  
  81. ###############################################################
  82. #### 创建|删除表操作 START
  83. ###############################################################
  84. def drop_table(conn, table):
  85. '''如果表存在,则删除表,如果表中存在数据的时候,使用该
  86. 方法的时候要慎用!'''
  87. if table is not None and table != '':
  88. sql = 'DROP TABLE IF EXISTS ' + table
  89. if SHOW_SQL:
  90. print('执行sql:[{}]'.format(sql))
  91. cu = get_cursor(conn)
  92. cu.execute(sql)
  93. conn.commit()
  94. print('删除数据库表[{}]成功!'.format(table))
  95. close_all(conn, cu)
  96. else:
  97. print('the [{}] is empty or equal None!'.format(sql))
  98.  
  99. def create_table(conn, sql):
  100. '''创建数据库表:student'''
  101. if sql is not None and sql != '':
  102. cu = get_cursor(conn)
  103. if SHOW_SQL:
  104. print('执行sql:[{}]'.format(sql))
  105. cu.execute(sql)
  106. conn.commit()
  107. print('创建数据库表[student]成功!')
  108. close_all(conn, cu)
  109. else:
  110. print('the [{}] is empty or equal None!'.format(sql))
  111.  
  112. ###############################################################
  113. #### 创建|删除表操作 END
  114. ###############################################################
  115.  
  116. def close_all(conn, cu):
  117. '''关闭数据库游标对象和数据库连接对象'''
  118. try:
  119. if cu is not None:
  120. cu.close()
  121. finally:
  122. if cu is not None:
  123. cu.close()
  124.  
  125. ###############################################################
  126. #### 数据库操作CRUD START
  127. ###############################################################
  128.  
  129. def save(conn, sql, data):
  130. '''插入数据'''
  131. if sql is not None and sql != '':
  132. if data is not None:
  133. cu = get_cursor(conn)
  134. for d in data:
  135. if SHOW_SQL:
  136. print('执行sql:[{}],参数:[{}]'.format(sql, d))
  137. cu.execute(sql, d)
  138. conn.commit()
  139. close_all(conn, cu)
  140. else:
  141. print('the [{}] is empty or equal None!'.format(sql))
  142.  
  143. def fetchall(conn, sql):
  144. '''查询所有数据'''
  145. if sql is not None and sql != '':
  146. cu = get_cursor(conn)
  147. if SHOW_SQL:
  148. print('执行sql:[{}]'.format(sql))
  149. cu.execute(sql)
  150. r = cu.fetchall()
  151. if len(r) > 0:
  152. for e in range(len(r)):
  153. print(r[e])
  154. else:
  155. print('the [{}] is empty or equal None!'.format(sql))
  156.  
  157. def fetchone(conn, sql, data):
  158. '''查询一条数据'''
  159. if sql is not None and sql != '':
  160. if data is not None:
  161. #Do this instead
  162. d = (data,)
  163. cu = get_cursor(conn)
  164. if SHOW_SQL:
  165. print('执行sql:[{}],参数:[{}]'.format(sql, data))
  166. cu.execute(sql, d)
  167. r = cu.fetchall()
  168. if len(r) > 0:
  169. for e in range(len(r)):
  170. print(r[e])
  171. else:
  172. print('the [{}] equal None!'.format(data))
  173. else:
  174. print('the [{}] is empty or equal None!'.format(sql))
  175.  
  176. def update(conn, sql, data):
  177. '''更新数据'''
  178. if sql is not None and sql != '':
  179. if data is not None:
  180. cu = get_cursor(conn)
  181. for d in data:
  182. if SHOW_SQL:
  183. print('执行sql:[{}],参数:[{}]'.format(sql, d))
  184. cu.execute(sql, d)
  185. conn.commit()
  186. close_all(conn, cu)
  187. else:
  188. print('the [{}] is empty or equal None!'.format(sql))
  189.  
  190. def delete(conn, sql, data):
  191. '''删除数据'''
  192. if sql is not None and sql != '':
  193. if data is not None:
  194. cu = get_cursor(conn)
  195. for d in data:
  196. if SHOW_SQL:
  197. print('执行sql:[{}],参数:[{}]'.format(sql, d))
  198. cu.execute(sql, d)
  199. conn.commit()
  200. close_all(conn, cu)
  201. else:
  202. print('the [{}] is empty or equal None!'.format(sql))
  203. ###############################################################
  204. #### 数据库操作CRUD END
  205. ###############################################################
  206.  
  207. ###############################################################
  208. #### 测试操作 START
  209. ###############################################################
  210. def drop_table_test():
  211. '''删除数据库表测试'''
  212. print('删除数据库表测试...')
  213. conn = get_conn(DB_FILE_PATH)
  214. drop_table(conn, TABLE_NAME)
  215.  
  216. def create_table_test():
  217. '''创建数据库表测试'''
  218. print('创建数据库表测试...')
  219. create_table_sql = '''CREATE TABLE `student` (
  220. `id` int(11) NOT NULL,
  221. `name` varchar(20) NOT NULL,
  222. `gender` varchar(4) DEFAULT NULL,
  223. `age` int(11) DEFAULT NULL,
  224. `address` varchar(200) DEFAULT NULL,
  225. `phone` varchar(20) DEFAULT NULL,
  226. PRIMARY KEY (`id`)
  227. )'''
  228. conn = get_conn(DB_FILE_PATH)
  229. create_table(conn, create_table_sql)
  230.  
  231. def save_test():
  232. '''保存数据测试...'''
  233. print('保存数据测试...')
  234. save_sql = '''INSERT INTO student values (?, ?, ?, ?, ?, ?)'''
  235. data = [(1, 'Hongten', '男', 20, '广东省广州市', '13423****62'),
  236. (2, 'Tom', '男', 22, '美国旧金山', '15423****63'),
  237. (3, 'Jake', '女', 18, '广东省广州市', '18823****87'),
  238. (4, 'Cate', '女', 21, '广东省广州市', '14323****32')]
  239. conn = get_conn(DB_FILE_PATH)
  240. save(conn, save_sql, data)
  241.  
  242. def fetchall_test():
  243. '''查询所有数据...'''
  244. print('查询所有数据...')
  245. fetchall_sql = '''SELECT * FROM student'''
  246. conn = get_conn(DB_FILE_PATH)
  247. fetchall(conn, fetchall_sql)
  248.  
  249. def fetchone_test():
  250. '''查询一条数据...'''
  251. print('查询一条数据...')
  252. fetchone_sql = 'SELECT * FROM student WHERE ID = ? '
  253. data = 1
  254. conn = get_conn(DB_FILE_PATH)
  255. fetchone(conn, fetchone_sql, data)
  256.  
  257. def update_test():
  258. '''更新数据...'''
  259. print('更新数据...')
  260. update_sql = 'UPDATE student SET name = ? WHERE ID = ? '
  261. data = [('HongtenAA', 1),
  262. ('HongtenBB', 2),
  263. ('HongtenCC', 3),
  264. ('HongtenDD', 4)]
  265. conn = get_conn(DB_FILE_PATH)
  266. update(conn, update_sql, data)
  267.  
  268. def delete_test():
  269. '''删除数据...'''
  270. print('删除数据...')
  271. delete_sql = 'DELETE FROM student WHERE NAME = ? AND ID = ? '
  272. data = [('HongtenAA', 1),
  273. ('HongtenCC', 3)]
  274. conn = get_conn(DB_FILE_PATH)
  275. delete(conn, delete_sql, data)
  276.  
  277. ###############################################################
  278. #### 测试操作 END
  279. ###############################################################
  280.  
  281. def init():
  282. '''初始化方法'''
  283. #数据库文件绝句路径
  284. global DB_FILE_PATH
  285. DB_FILE_PATH = 'c:\\test\\hongten.db'
  286. #数据库表名称
  287. global TABLE_NAME
  288. TABLE_NAME = 'student'
  289. #是否打印sql
  290. global SHOW_SQL
  291. SHOW_SQL = True
  292. print('show_sql : {}'.format(SHOW_SQL))
  293. #如果存在数据库表,则删除表
  294. drop_table_test()
  295. #创建数据库表student
  296. create_table_test()
  297. #向数据库表中插入数据
  298. save_test()
  299.  
  300. def main():
  301. init()
  302. fetchall_test()
  303. print('#' * 50)
  304. fetchone_test()
  305. print('#' * 50)
  306. update_test()
  307. fetchall_test()
  308. print('#' * 50)
  309. delete_test()
  310. fetchall_test()
  311.  
  312. if __name__ == '__main__':
  313. main()

========================================================

More reading,and english is important.

I'm Hongten

  1. 大哥哥大姐姐,觉得有用打赏点哦!多多少少没关系,一分也是对我的支持和鼓励。谢谢。
    Hongten博客排名在100名以内。粉丝过千。
    Hongten出品,必是精品。

E | hongtenzone@foxmail.com  B | http://www.cnblogs.com/hongten

========================================================

python开发_sqlite3_绝对完整_博主推荐的更多相关文章

  1. python开发_zlib_完整版_博主推荐

    ''' python中的zlib模块提供了压缩和解压缩的方法 实现功能: 读取一个文件的内容,然后把该文件的内容以字符串的形式返回 然后对返回回来的字符串进行压缩处理,然后写入到另一个文件中 同时,也 ...

  2. python开发_shelve_完整版_博主推荐

    ''' python中的shelve模块,可以提供一些简单的数据操作 他和python中的dbm很相似. 区别如下: 都是以键值对的形式保存数据,不过在shelve模块中, key必须为字符串,而值可 ...

  3. python开发_copy(浅拷贝|深拷贝)_博主推荐

    在python中,有着深拷贝和浅拷贝,即copy模块 下面我们就来聊一下: 运行效果: ================================================== 代码部分: ...

  4. python开发_dbm_键值对存储_完整_博主推荐

    ''' 在python的应用程序中,不需要关系型数据库时,如MySQL 可以使用python提供的持久字典dbm来存储名称和值(键值对) 这个类似于java的中的java.util.Map对象. 区别 ...

  5. python开发_tkinter_菜单选项中英文切换_菜单选项不可用操作_博主推荐

    我使用的python版本为:3.3.2 如果你对python中tkinter模块的菜单操作不是很了解,你可以看看: python开发_tkinter_窗口控件_自己制作的Python IDEL_博主推 ...

  6. python开发_xml.dom_解析XML文档_完整版_博主推荐

    在阅读之前,你需要了解一些xml.dom的一些理论知识,在这里你可以对xml.dom有一定的了解,如果你阅读完之后. 下面是我做的demo 运行效果: 解析的XML文件位置:c:\\test\\hon ...

  7. python开发_configparser_解析.ini配置文件工具_完整版_博主推荐

    # # 最近出了一趟差,是从20号去的,今天回来... # 就把最近学习的python内容给大家分享一下... # ''' 在python中,configparser模块提供了操作*.ini配置文件的 ...

  8. python开发_csv(Comma Separated Values)_逗号分隔值_常用导入导出格式_完整版_博主推荐

    ## 最近出了一趟差,是从20号去的,今天回来...# 就把最近学习的python内容给大家分享一下...#''' 在python中,CSV(Comma Separated Values),从字面上面 ...

  9. python开发_gzip_压缩|解压缩gz文件_完整版_博主推荐

    ''' gzip -- 支持gzip文件 源文件:Lib/gzip.py 这个模块提供了一些简单的接口来对文件进行压缩和解压缩,类似于GNU项目的gzip和gunzip. 数据的压缩源于zlib模块的 ...

随机推荐

  1. javascript飞机大战-----009游戏结束

    /* 游戏引擎 */ var Engine = { //刚开始的游戏状态 gameStatus:false, //所以敌机 enemy:{}, //子弹 bullet:{}, //得分 scroe:0 ...

  2. spriing boot 启动报错:Cannot determine embedded database driver class for database type NONE

    最近在学习使用spring boot.使用maven创建好工程,只引用需要用到的spring boot相关的jar包,除此之外没有任何的配置. 写了一个最简单的例子,如下所示: package com ...

  3. sosi-statistics

    set echo offset scan onset lines 150set pages 66set verify offset feedback offset termout offcolumn ...

  4. Python自动发布Image service的实现

    使用Python自动发布地图服务已经在上一篇博客中讲到,使用Python创建.sd服务定义文件,实现脚本自动发布ArcGIS服务,下面是利用Python自动发布Image service的实现. -- ...

  5. LINEAR HASH Partitioning

    MySQL :: MySQL 8.0 Reference Manual :: 23.2.4.1 LINEAR HASH Partitioning https://dev.mysql.com/doc/r ...

  6. Go Configure Support hot reloading.

    Go Configure – Josh Betz https://josh.blog/2017/04/go-configure Go Configure APRIL 27, 2017 # DEVELO ...

  7. 转!idea启动后发现tomcat前面出现红色或是灰色的问号

    原博文地址:https://blog.csdn.net/z_zhy/article/details/83068168 直接在idea里 点击File------settings,在搜索框直接搜tomc ...

  8. 第1章 1.3计算机网络概述--规划IP地址介绍MAC地址

    IP地址的作用是:指定发送数据者和接收数据者. MAC地址的作用:指定数据包的下一跳转设备.就是说明数据下一步向谁发. 路由器的作用:在不同的网段中转发数据.路由器本质就是有2个网卡的设备. 网卡:用 ...

  9. linux route命令的使用详解 添加永久静态路由 tracert traceroute

    linux route命令的使用详解 添加永久静态路由  tracert  traceroute route -n    Linuxroute  print  Windows traceroute  ...

  10. 当IDENTITY_INSERT设置为OFF时不能向表插入显示值。(源:MSSQLServer,错误码:544)

    错误提示"事务和快照同步时提示:当IDENTITY_INSERT设置为OFF时不能向表插入显示值.(源:MSSQLServer,错误码:544)" 原因:在SQL2008同步时到S ...