You need to sign in or sign up before continuing.
models_bigdata.py 31.1 KB
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467
"""
舆情大数据聚合主表ORM模型(自动由原tables.sql结构同步生成,对应大表批量搜索与内容入库)

数据模型定义位置:
- MindSpider/DeepSentimentCrawling/MediaCrawler/schema/tables.sql  # 主表结构来源文件
- 本模块(自动映射SQL表,适配MySQL/PostgreSQL,推荐手动完善注释、唯一/索引补充)
- MindSpider/schema/models_sa.py  # Base 定义来源

本模块以MindSpider\DeepSentimentCrawling\MediaCrawler\database\models.py为准
"""

from sqlalchemy.orm import Mapped, mapped_column
from sqlalchemy import Integer, String, BigInteger, Text, ForeignKey

# 使用 models_sa 中的 Base,确保所有表在同一个 metadata 中,外键引用可以正常工作
from models_sa import Base

class BilibiliVideo(Base):
    __tablename__ = "bilibili_video"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    video_id: Mapped[int] = mapped_column(BigInteger, nullable=False, index=True, unique=True)
    video_url: Mapped[str] = mapped_column(Text, nullable=False)
    user_id: Mapped[int | None] = mapped_column(BigInteger, index=True, nullable=True)
    nickname: Mapped[str | None] = mapped_column(Text, nullable=True)
    avatar: Mapped[str | None] = mapped_column(Text, nullable=True)
    liked_count: Mapped[int | None] = mapped_column(Integer, nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    video_type: Mapped[str | None] = mapped_column(Text, nullable=True)
    title: Mapped[str | None] = mapped_column(Text, nullable=True)
    desc: Mapped[str | None] = mapped_column(Text, nullable=True)
    create_time: Mapped[int | None] = mapped_column(BigInteger, index=True, nullable=True)
    disliked_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    video_play_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    video_favorite_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    video_share_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    video_coin_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    video_danmaku: Mapped[str | None] = mapped_column(Text, nullable=True)
    video_comment: Mapped[str | None] = mapped_column(Text, nullable=True)
    video_cover_url: Mapped[str | None] = mapped_column(Text, nullable=True)
    source_keyword: Mapped[str | None] = mapped_column(Text, default='', nullable=True)
    topic_id: Mapped[str | None] = mapped_column(String(64), ForeignKey("daily_topics.topic_id", ondelete="SET NULL"), nullable=True)
    crawling_task_id: Mapped[str | None] = mapped_column(String(64), ForeignKey("crawling_tasks.task_id", ondelete="SET NULL"), nullable=True)

class BilibiliVideoComment(Base):
    __tablename__ = "bilibili_video_comment"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    user_id: Mapped[str | None] = mapped_column(String(255), nullable=True)
    nickname: Mapped[str | None] = mapped_column(Text, nullable=True)
    sex: Mapped[str | None] = mapped_column(Text, nullable=True)
    sign: Mapped[str | None] = mapped_column(Text, nullable=True)
    avatar: Mapped[str | None] = mapped_column(Text, nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    comment_id: Mapped[int | None] = mapped_column(BigInteger, index=True, nullable=True)
    video_id: Mapped[int | None] = mapped_column(BigInteger, index=True, nullable=True)
    content: Mapped[str | None] = mapped_column(Text, nullable=True)
    create_time: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    sub_comment_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    parent_comment_id: Mapped[str | None] = mapped_column(String(255), nullable=True)
    like_count: Mapped[str | None] = mapped_column(Text, default='0', nullable=True)


class BilibiliUpInfo(Base):
    __tablename__ = "bilibili_up_info"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    user_id: Mapped[int | None] = mapped_column(BigInteger, index=True, nullable=True)
    nickname: Mapped[str | None] = mapped_column(Text, nullable=True)
    sex: Mapped[str | None] = mapped_column(Text, nullable=True)
    sign: Mapped[str | None] = mapped_column(Text, nullable=True)
    avatar: Mapped[str | None] = mapped_column(Text, nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    total_fans: Mapped[int | None] = mapped_column(Integer, nullable=True)
    total_liked: Mapped[int | None] = mapped_column(Integer, nullable=True)
    user_rank: Mapped[int | None] = mapped_column(Integer, nullable=True)
    is_official: Mapped[int | None] = mapped_column(Integer, nullable=True)


class BilibiliContactInfo(Base):
    __tablename__ = "bilibili_contact_info"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    up_id: Mapped[int | None] = mapped_column(BigInteger, index=True, nullable=True)
    fan_id: Mapped[int | None] = mapped_column(BigInteger, index=True, nullable=True)
    up_name: Mapped[str | None] = mapped_column(Text, nullable=True)
    fan_name: Mapped[str | None] = mapped_column(Text, nullable=True)
    up_sign: Mapped[str | None] = mapped_column(Text, nullable=True)
    fan_sign: Mapped[str | None] = mapped_column(Text, nullable=True)
    up_avatar: Mapped[str | None] = mapped_column(Text, nullable=True)
    fan_avatar: Mapped[str | None] = mapped_column(Text, nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)


class BilibiliUpDynamic(Base):
    __tablename__ = "bilibili_up_dynamic"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    dynamic_id: Mapped[int | None] = mapped_column(BigInteger, index=True, nullable=True)
    user_id: Mapped[str | None] = mapped_column(String(255), nullable=True)
    user_name: Mapped[str | None] = mapped_column(Text, nullable=True)
    text: Mapped[str | None] = mapped_column(Text, nullable=True)
    type: Mapped[str | None] = mapped_column(Text, nullable=True)
    pub_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    total_comments: Mapped[int | None] = mapped_column(Integer, nullable=True)
    total_forwards: Mapped[int | None] = mapped_column(Integer, nullable=True)
    total_liked: Mapped[int | None] = mapped_column(Integer, nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)


class DouyinAweme(Base):
    __tablename__ = "douyin_aweme"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    user_id: Mapped[str | None] = mapped_column(String(255), nullable=True)
    sec_uid: Mapped[str | None] = mapped_column(String(255), nullable=True)
    short_user_id: Mapped[str | None] = mapped_column(String(255), nullable=True)
    user_unique_id: Mapped[str | None] = mapped_column(String(255), nullable=True)
    nickname: Mapped[str | None] = mapped_column(Text, nullable=True)
    avatar: Mapped[str | None] = mapped_column(Text, nullable=True)
    user_signature: Mapped[str | None] = mapped_column(Text, nullable=True)
    ip_location: Mapped[str | None] = mapped_column(Text, nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    aweme_id: Mapped[int | None] = mapped_column(BigInteger, index=True, nullable=True)
    aweme_type: Mapped[str | None] = mapped_column(Text, nullable=True)
    title: Mapped[str | None] = mapped_column(Text, nullable=True)
    desc: Mapped[str | None] = mapped_column(Text, nullable=True)
    create_time: Mapped[int | None] = mapped_column(BigInteger, index=True, nullable=True)
    liked_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    comment_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    share_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    collected_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    aweme_url: Mapped[str | None] = mapped_column(Text, nullable=True)
    cover_url: Mapped[str | None] = mapped_column(Text, nullable=True)
    video_download_url: Mapped[str | None] = mapped_column(Text, nullable=True)
    music_download_url: Mapped[str | None] = mapped_column(Text, nullable=True)
    note_download_url: Mapped[str | None] = mapped_column(Text, nullable=True)
    source_keyword: Mapped[str | None] = mapped_column(Text, default='', nullable=True)
    topic_id: Mapped[str | None] = mapped_column(String(64), ForeignKey("daily_topics.topic_id", ondelete="SET NULL"), nullable=True)
    crawling_task_id: Mapped[str | None] = mapped_column(String(64), ForeignKey("crawling_tasks.task_id", ondelete="SET NULL"), nullable=True)

class DouyinAwemeComment(Base):
    __tablename__ = "douyin_aweme_comment"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    user_id: Mapped[str | None] = mapped_column(String(255), nullable=True)
    sec_uid: Mapped[str | None] = mapped_column(String(255), nullable=True)
    short_user_id: Mapped[str | None] = mapped_column(String(255), nullable=True)
    user_unique_id: Mapped[str | None] = mapped_column(String(255), nullable=True)
    nickname: Mapped[str | None] = mapped_column(Text, nullable=True)
    avatar: Mapped[str | None] = mapped_column(Text, nullable=True)
    user_signature: Mapped[str | None] = mapped_column(Text, nullable=True)
    ip_location: Mapped[str | None] = mapped_column(Text, nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    comment_id: Mapped[int | None] = mapped_column(BigInteger, index=True, nullable=True)
    aweme_id: Mapped[int | None] = mapped_column(BigInteger, index=True, nullable=True)
    content: Mapped[str | None] = mapped_column(Text, nullable=True)
    create_time: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    sub_comment_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    parent_comment_id: Mapped[str | None] = mapped_column(String(255), nullable=True)
    like_count: Mapped[str | None] = mapped_column(Text, default='0', nullable=True)
    pictures: Mapped[str | None] = mapped_column(Text, default='', nullable=True)


class DyCreator(Base):
    __tablename__ = "dy_creator"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    user_id: Mapped[str | None] = mapped_column(String(255), nullable=True)
    nickname: Mapped[str | None] = mapped_column(Text, nullable=True)
    avatar: Mapped[str | None] = mapped_column(Text, nullable=True)
    ip_location: Mapped[str | None] = mapped_column(Text, nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    desc: Mapped[str | None] = mapped_column(Text, nullable=True)
    gender: Mapped[str | None] = mapped_column(Text, nullable=True)
    follows: Mapped[str | None] = mapped_column(Text, nullable=True)
    fans: Mapped[str | None] = mapped_column(Text, nullable=True)
    interaction: Mapped[str | None] = mapped_column(Text, nullable=True)
    videos_count: Mapped[str | None] = mapped_column(String(255), nullable=True)


class KuaishouVideo(Base):
    __tablename__ = "kuaishou_video"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    user_id: Mapped[str | None] = mapped_column(String(64), nullable=True)
    nickname: Mapped[str | None] = mapped_column(Text, nullable=True)
    avatar: Mapped[str | None] = mapped_column(Text, nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    video_id: Mapped[str | None] = mapped_column(String(255), index=True, nullable=True)
    video_type: Mapped[str | None] = mapped_column(Text, nullable=True)
    title: Mapped[str | None] = mapped_column(Text, nullable=True)
    desc: Mapped[str | None] = mapped_column(Text, nullable=True)
    create_time: Mapped[int | None] = mapped_column(BigInteger, index=True, nullable=True)
    liked_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    viewd_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    video_url: Mapped[str | None] = mapped_column(Text, nullable=True)
    video_cover_url: Mapped[str | None] = mapped_column(Text, nullable=True)
    video_play_url: Mapped[str | None] = mapped_column(Text, nullable=True)
    source_keyword: Mapped[str | None] = mapped_column(Text, default='', nullable=True)
    topic_id: Mapped[str | None] = mapped_column(String(64), ForeignKey("daily_topics.topic_id", ondelete="SET NULL"), nullable=True)
    crawling_task_id: Mapped[str | None] = mapped_column(String(64), ForeignKey("crawling_tasks.task_id", ondelete="SET NULL"), nullable=True)

class KuaishouVideoComment(Base):
    __tablename__ = "kuaishou_video_comment"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    user_id: Mapped[str | None] = mapped_column(Text, nullable=True)
    nickname: Mapped[str | None] = mapped_column(Text, nullable=True)
    avatar: Mapped[str | None] = mapped_column(Text, nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    comment_id: Mapped[int | None] = mapped_column(BigInteger, index=True, nullable=True)
    video_id: Mapped[str | None] = mapped_column(String(255), index=True, nullable=True)
    content: Mapped[str | None] = mapped_column(Text, nullable=True)
    create_time: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    sub_comment_count: Mapped[str | None] = mapped_column(Text, nullable=True)

class WeiboNote(Base):
    __tablename__ = "weibo_note"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    user_id: Mapped[str | None] = mapped_column(String(255), nullable=True)
    nickname: Mapped[str | None] = mapped_column(Text, nullable=True)
    avatar: Mapped[str | None] = mapped_column(Text, nullable=True)
    gender: Mapped[str | None] = mapped_column(Text, nullable=True)
    profile_url: Mapped[str | None] = mapped_column(Text, nullable=True)
    ip_location: Mapped[str | None] = mapped_column(Text, default='', nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    note_id: Mapped[int | None] = mapped_column(BigInteger, index=True, nullable=True)
    content: Mapped[str | None] = mapped_column(Text, nullable=True)
    create_time: Mapped[int | None] = mapped_column(BigInteger, index=True, nullable=True)
    create_date_time: Mapped[str | None] = mapped_column(String(255), index=True, nullable=True)
    liked_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    comments_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    shared_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    note_url: Mapped[str | None] = mapped_column(Text, nullable=True)
    source_keyword: Mapped[str | None] = mapped_column(Text, default='', nullable=True)
    topic_id: Mapped[str | None] = mapped_column(String(64), ForeignKey("daily_topics.topic_id", ondelete="SET NULL"), nullable=True)
    crawling_task_id: Mapped[str | None] = mapped_column(String(64), ForeignKey("crawling_tasks.task_id", ondelete="SET NULL"), nullable=True)

class WeiboNoteComment(Base):
    __tablename__ = "weibo_note_comment"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    user_id: Mapped[str | None] = mapped_column(String(255), nullable=True)
    nickname: Mapped[str | None] = mapped_column(Text, nullable=True)
    avatar: Mapped[str | None] = mapped_column(Text, nullable=True)
    gender: Mapped[str | None] = mapped_column(Text, nullable=True)
    profile_url: Mapped[str | None] = mapped_column(Text, nullable=True)
    ip_location: Mapped[str | None] = mapped_column(Text, default='', nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    comment_id: Mapped[int | None] = mapped_column(BigInteger, index=True, nullable=True)
    note_id: Mapped[int | None] = mapped_column(BigInteger, index=True, nullable=True)
    content: Mapped[str | None] = mapped_column(Text, nullable=True)
    create_time: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    create_date_time: Mapped[str | None] = mapped_column(String(255), index=True, nullable=True)
    comment_like_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    sub_comment_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    parent_comment_id: Mapped[str | None] = mapped_column(String(255), nullable=True)


class WeiboCreator(Base):
    __tablename__ = "weibo_creator"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    user_id: Mapped[str | None] = mapped_column(String(255), nullable=True)
    nickname: Mapped[str | None] = mapped_column(Text, nullable=True)
    avatar: Mapped[str | None] = mapped_column(Text, nullable=True)
    ip_location: Mapped[str | None] = mapped_column(Text, nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    desc: Mapped[str | None] = mapped_column(Text, nullable=True)
    gender: Mapped[str | None] = mapped_column(Text, nullable=True)
    follows: Mapped[str | None] = mapped_column(Text, nullable=True)
    fans: Mapped[str | None] = mapped_column(Text, nullable=True)
    tag_list: Mapped[str | None] = mapped_column(Text, nullable=True)


class XhsCreator(Base):
    __tablename__ = "xhs_creator"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    user_id: Mapped[str | None] = mapped_column(String(255), nullable=True)
    nickname: Mapped[str | None] = mapped_column(Text, nullable=True)
    avatar: Mapped[str | None] = mapped_column(Text, nullable=True)
    ip_location: Mapped[str | None] = mapped_column(Text, nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    desc: Mapped[str | None] = mapped_column(Text, nullable=True)
    gender: Mapped[str | None] = mapped_column(Text, nullable=True)
    follows: Mapped[str | None] = mapped_column(Text, nullable=True)
    fans: Mapped[str | None] = mapped_column(Text, nullable=True)
    interaction: Mapped[str | None] = mapped_column(Text, nullable=True)
    tag_list: Mapped[str | None] = mapped_column(Text, nullable=True)


class XhsNote(Base):
    __tablename__ = "xhs_note"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    user_id: Mapped[str | None] = mapped_column(String(255), nullable=True)
    nickname: Mapped[str | None] = mapped_column(Text, nullable=True)
    avatar: Mapped[str | None] = mapped_column(Text, nullable=True)
    ip_location: Mapped[str | None] = mapped_column(Text, nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    note_id: Mapped[str | None] = mapped_column(String(255), index=True, nullable=True)
    type: Mapped[str | None] = mapped_column(Text, nullable=True)
    title: Mapped[str | None] = mapped_column(Text, nullable=True)
    desc: Mapped[str | None] = mapped_column(Text, nullable=True)
    video_url: Mapped[str | None] = mapped_column(Text, nullable=True)
    time: Mapped[int | None] = mapped_column(BigInteger, index=True, nullable=True)
    last_update_time: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    liked_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    collected_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    comment_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    share_count: Mapped[str | None] = mapped_column(Text, nullable=True)
    image_list: Mapped[str | None] = mapped_column(Text, nullable=True)
    tag_list: Mapped[str | None] = mapped_column(Text, nullable=True)
    note_url: Mapped[str | None] = mapped_column(Text, nullable=True)
    source_keyword: Mapped[str | None] = mapped_column(Text, default='', nullable=True)
    xsec_token: Mapped[str | None] = mapped_column(Text, nullable=True)
    topic_id: Mapped[str | None] = mapped_column(String(64), ForeignKey("daily_topics.topic_id", ondelete="SET NULL"), nullable=True)
    crawling_task_id: Mapped[str | None] = mapped_column(String(64), ForeignKey("crawling_tasks.task_id", ondelete="SET NULL"), nullable=True)


class XhsNoteComment(Base):
    __tablename__ = "xhs_note_comment"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    user_id: Mapped[str | None] = mapped_column(String(255), nullable=True)
    nickname: Mapped[str | None] = mapped_column(Text, nullable=True)
    avatar: Mapped[str | None] = mapped_column(Text, nullable=True)
    ip_location: Mapped[str | None] = mapped_column(Text, nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    comment_id: Mapped[str | None] = mapped_column(String(255), index=True, nullable=True)
    create_time: Mapped[int | None] = mapped_column(BigInteger, index=True, nullable=True)
    note_id: Mapped[str | None] = mapped_column(String(255), nullable=True)
    content: Mapped[str | None] = mapped_column(Text, nullable=True)
    sub_comment_count: Mapped[int | None] = mapped_column(Integer, nullable=True)
    pictures: Mapped[str | None] = mapped_column(Text, nullable=True)
    parent_comment_id: Mapped[str | None] = mapped_column(String(255), nullable=True)
    like_count: Mapped[str | None] = mapped_column(Text, nullable=True)

class TiebaNote(Base):
    __tablename__ = "tieba_note"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    note_id: Mapped[str | None] = mapped_column(String(644), index=True, nullable=True)
    title: Mapped[str | None] = mapped_column(Text, nullable=True)
    desc: Mapped[str | None] = mapped_column(Text, nullable=True)
    note_url: Mapped[str | None] = mapped_column(Text, nullable=True)
    publish_time: Mapped[str | None] = mapped_column(String(255), index=True, nullable=True)
    user_link: Mapped[str | None] = mapped_column(Text, default='', nullable=True)
    user_nickname: Mapped[str | None] = mapped_column(Text, default='', nullable=True)
    user_avatar: Mapped[str | None] = mapped_column(Text, default='', nullable=True)
    tieba_id: Mapped[str | None] = mapped_column(String(255), default='', nullable=True)
    tieba_name: Mapped[str | None] = mapped_column(Text, nullable=True)
    tieba_link: Mapped[str | None] = mapped_column(Text, nullable=True)
    total_replay_num: Mapped[int | None] = mapped_column(Integer, default=0, nullable=True)
    total_replay_page: Mapped[int | None] = mapped_column(Integer, default=0, nullable=True)
    ip_location: Mapped[str | None] = mapped_column(Text, default='', nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    source_keyword: Mapped[str | None] = mapped_column(Text, default='', nullable=True)
    topic_id: Mapped[str | None] = mapped_column(String(64), ForeignKey("daily_topics.topic_id", ondelete="SET NULL"), nullable=True)
    crawling_task_id: Mapped[str | None] = mapped_column(String(64), ForeignKey("crawling_tasks.task_id", ondelete="SET NULL"), nullable=True)

class TiebaComment(Base):
    __tablename__ = "tieba_comment"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    comment_id: Mapped[str | None] = mapped_column(String(255), index=True, nullable=True)
    parent_comment_id: Mapped[str | None] = mapped_column(String(255), default='', nullable=True)
    content: Mapped[str | None] = mapped_column(Text, nullable=True)
    user_link: Mapped[str | None] = mapped_column(Text, default='', nullable=True)
    user_nickname: Mapped[str | None] = mapped_column(Text, default='', nullable=True)
    user_avatar: Mapped[str | None] = mapped_column(Text, default='', nullable=True)
    tieba_id: Mapped[str | None] = mapped_column(String(255), default='', nullable=True)
    tieba_name: Mapped[str | None] = mapped_column(Text, nullable=True)
    tieba_link: Mapped[str | None] = mapped_column(Text, nullable=True)
    publish_time: Mapped[str | None] = mapped_column(String(255), index=True, nullable=True)
    ip_location: Mapped[str | None] = mapped_column(Text, default='', nullable=True)
    sub_comment_count: Mapped[int | None] = mapped_column(Integer, default=0, nullable=True)
    note_id: Mapped[str | None] = mapped_column(String(255), index=True, nullable=True)
    note_url: Mapped[str | None] = mapped_column(Text, nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)


class TiebaCreator(Base):
    __tablename__ = "tieba_creator"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    user_id: Mapped[str | None] = mapped_column(String(64), nullable=True)
    user_name: Mapped[str | None] = mapped_column(Text, nullable=True)
    nickname: Mapped[str | None] = mapped_column(Text, nullable=True)
    avatar: Mapped[str | None] = mapped_column(Text, nullable=True)
    ip_location: Mapped[str | None] = mapped_column(Text, nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    gender: Mapped[str | None] = mapped_column(Text, nullable=True)
    follows: Mapped[str | None] = mapped_column(Text, nullable=True)
    fans: Mapped[str | None] = mapped_column(Text, nullable=True)
    registration_duration: Mapped[str | None] = mapped_column(Text, nullable=True)


class ZhihuContent(Base):
    __tablename__ = "zhihu_content"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    content_id: Mapped[str | None] = mapped_column(String(64), index=True, nullable=True)
    content_type: Mapped[str | None] = mapped_column(Text, nullable=True)
    content_text: Mapped[str | None] = mapped_column(Text, nullable=True)
    content_url: Mapped[str | None] = mapped_column(Text, nullable=True)
    question_id: Mapped[str | None] = mapped_column(String(255), nullable=True)
    title: Mapped[str | None] = mapped_column(Text, nullable=True)
    desc: Mapped[str | None] = mapped_column(Text, nullable=True)
    created_time: Mapped[str | None] = mapped_column(String(32), index=True, nullable=True)
    updated_time: Mapped[str | None] = mapped_column(Text, nullable=True)
    voteup_count: Mapped[int | None] = mapped_column(Integer, default=0, nullable=True)
    comment_count: Mapped[int | None] = mapped_column(Integer, default=0, nullable=True)
    source_keyword: Mapped[str | None] = mapped_column(Text, nullable=True)
    user_id: Mapped[str | None] = mapped_column(String(255), nullable=True)
    user_link: Mapped[str | None] = mapped_column(Text, nullable=True)
    user_nickname: Mapped[str | None] = mapped_column(Text, nullable=True)
    user_avatar: Mapped[str | None] = mapped_column(Text, nullable=True)
    user_url_token: Mapped[str | None] = mapped_column(Text, nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    topic_id: Mapped[str | None] = mapped_column(String(64), ForeignKey("daily_topics.topic_id", ondelete="SET NULL"), nullable=True)
    crawling_task_id: Mapped[str | None] = mapped_column(String(64), ForeignKey("crawling_tasks.task_id", ondelete="SET NULL"), nullable=True)

class ZhihuComment(Base):
    __tablename__ = "zhihu_comment"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    comment_id: Mapped[str | None] = mapped_column(String(64), index=True, nullable=True)
    parent_comment_id: Mapped[str | None] = mapped_column(String(64), nullable=True)
    content: Mapped[str | None] = mapped_column(Text, nullable=True)
    publish_time: Mapped[str | None] = mapped_column(String(32), index=True, nullable=True)
    ip_location: Mapped[str | None] = mapped_column(Text, nullable=True)
    sub_comment_count: Mapped[int | None] = mapped_column(Integer, default=0, nullable=True)
    like_count: Mapped[int | None] = mapped_column(Integer, default=0, nullable=True)
    dislike_count: Mapped[int | None] = mapped_column(Integer, default=0, nullable=True)
    content_id: Mapped[str | None] = mapped_column(String(64), index=True, nullable=True)
    content_type: Mapped[str | None] = mapped_column(Text, nullable=True)
    user_id: Mapped[str | None] = mapped_column(String(64), nullable=True)
    user_link: Mapped[str | None] = mapped_column(Text, nullable=True)
    user_nickname: Mapped[str | None] = mapped_column(Text, nullable=True)
    user_avatar: Mapped[str | None] = mapped_column(Text, nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)


class ZhihuCreator(Base):
    __tablename__ = "zhihu_creator"
    id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
    user_id: Mapped[str | None] = mapped_column(String(64), unique=True, index=True, nullable=True)
    user_link: Mapped[str | None] = mapped_column(Text, nullable=True)
    user_nickname: Mapped[str | None] = mapped_column(Text, nullable=True)
    user_avatar: Mapped[str | None] = mapped_column(Text, nullable=True)
    url_token: Mapped[str | None] = mapped_column(Text, nullable=True)
    gender: Mapped[str | None] = mapped_column(Text, nullable=True)
    ip_location: Mapped[str | None] = mapped_column(Text, nullable=True)
    follows: Mapped[int | None] = mapped_column(Integer, default=0, nullable=True)
    fans: Mapped[int | None] = mapped_column(Integer, default=0, nullable=True)
    anwser_count: Mapped[int | None] = mapped_column(Integer, default=0, nullable=True)
    video_count: Mapped[int | None] = mapped_column(Integer, default=0, nullable=True)
    question_count: Mapped[int | None] = mapped_column(Integer, default=0, nullable=True)
    article_count: Mapped[int | None] = mapped_column(Integer, default=0, nullable=True)
    column_count: Mapped[int | None] = mapped_column(Integer, default=0, nullable=True)
    get_voteup_count: Mapped[int | None] = mapped_column(Integer, default=0, nullable=True)
    add_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)
    last_modify_ts: Mapped[int | None] = mapped_column(BigInteger, nullable=True)