Convert Figma logo to code with AI

Tencent logowcdb

WCDB is a cross-platform database framework developed by WeChat.

10,727
1,401
10,727
8

Top Related Projects

6,288

Fast persistent recoverable log and key-value store + cache, in C# and C++.

28,450

A library that provides an embeddable, persistent key-value store for fast storage.

36,378

LevelDB is a fast key-value storage library written at Google that provides an ordered mapping from string keys to string values.

FoundationDB - the open source, distributed, transactional key-value store

4,766

RocksDB/LevelDB inspired key-value database in Go

Core database component for the Realm Mobile Database SDKs

Quick Overview

WCDB is a high-performance, cross-platform database framework developed by Tencent. It's built on top of SQLite and provides an efficient, complete, and easy-to-use ORM for iOS, macOS, and Android. WCDB aims to provide a unified interface for database operations across different platforms.

Pros

  • High performance with optimized SQL execution and multi-threading support
  • Cross-platform compatibility (iOS, macOS, Android)
  • Built-in encryption and full-text search capabilities
  • Comprehensive ORM support with a simple and intuitive API

Cons

  • Steeper learning curve compared to simpler SQLite wrappers
  • Limited community support compared to more widely-used database solutions
  • Potential overhead for simpler applications that don't require advanced features
  • Dependency on SQLite, which may not be suitable for all use cases

Code Examples

  1. Creating a table and inserting data (iOS/Swift):
class Sample: TableCodable {
    var identifier: Int = 0
    var description: String? = nil
    
    enum CodingKeys: String, CodingTableKey {
        typealias Root = Sample
        static let objectRelationalMapping = TableBinding(CodingKeys.self)
        case identifier
        case description
    }
}

try database.create(table: Sample.self)
let object = Sample()
object.identifier = 1
object.description = "Sample"
try database.insert(objects: object, intoTable: Sample.self)
  1. Querying data (iOS/Swift):
let objects: [Sample] = try database.getObjects(fromTable: Sample.self, 
                                                where: Sample.Properties.identifier == 1)
  1. Updating data (iOS/Swift):
try database.update(table: Sample.self, 
                    on: Sample.Properties.description, 
                    with: "Updated Sample", 
                    where: Sample.Properties.identifier == 1)

Getting Started

To use WCDB in your iOS project:

  1. Add WCDB to your project using CocoaPods:

    pod 'WCDB.swift'
    
  2. Import WCDB in your Swift file:

    import WCDBSwift
    
  3. Create a database instance:

    let database = Database(withPath: "path/to/your/database.db")
    
  4. Define your model classes conforming to TableCodable protocol and start using WCDB's APIs for database operations.

Competitor Comparisons

6,288

Fast persistent recoverable log and key-value store + cache, in C# and C++.

Pros of FASTER

  • Designed for larger-than-memory data, offering better scalability for big data scenarios
  • Supports both key-value and log storage, providing more flexibility in data models
  • Offers hybrid log-structured storage for improved performance in certain workloads

Cons of FASTER

  • Less focus on mobile platforms, potentially limiting its use in mobile app development
  • May have a steeper learning curve due to its more complex architecture
  • Lacks built-in encryption features, which are important for sensitive data handling

Code Comparison

WCDB (SQL-based):

INSERT INTO users (name, age) VALUES ('John', 30);
SELECT * FROM users WHERE age > 25;

FASTER (Key-Value based):

faster.Upsert(key, value);
faster.Read(key, out value);

Summary

WCDB is a SQLite-based database optimized for mobile platforms, offering strong encryption and ACID compliance. FASTER, on the other hand, is a high-performance key-value store and log designed for larger-than-memory data scenarios. While WCDB excels in mobile app development with its SQL interface and encryption features, FASTER provides better scalability and flexibility for big data applications. The choice between them depends on the specific requirements of the project, such as platform, data size, and query complexity.

28,450

A library that provides an embeddable, persistent key-value store for fast storage.

Pros of RocksDB

  • More mature and widely adopted, with extensive documentation and community support
  • Highly optimized for SSDs and offers better performance for large-scale data storage
  • Supports a wider range of storage engines and customization options

Cons of RocksDB

  • Higher complexity and steeper learning curve compared to WCDB
  • Larger memory footprint and potentially slower for small-scale applications
  • Less focus on mobile-specific optimizations

Code Comparison

WCDB (C++):

WCDB::Database database("path/to/database");
WCDB::Table<Person> table = database.getTable<Person>("person");
table.insert(person);

RocksDB (C++):

rocksdb::DB* db;
rocksdb::Options options;
rocksdb::Status status = rocksdb::DB::Open(options, "path/to/database", &db);
db->Put(rocksdb::WriteOptions(), "key", "value");

Key Differences

  • WCDB is specifically designed for mobile platforms, while RocksDB is more general-purpose
  • WCDB offers a higher-level API with ORM-like features, whereas RocksDB provides a lower-level key-value interface
  • RocksDB focuses on performance and scalability for large datasets, while WCDB prioritizes ease of use and mobile-specific optimizations
36,378

LevelDB is a fast key-value storage library written at Google that provides an ordered mapping from string keys to string values.

Pros of LevelDB

  • Lightweight and fast key-value storage engine
  • Supports ordered mapping from string keys to string values
  • Widely used and battle-tested in various applications

Cons of LevelDB

  • Limited support for complex queries and indexing
  • Lacks built-in multi-threaded support
  • No native SQL interface

Code Comparison

LevelDB:

leveldb::DB* db;
leveldb::Options options;
options.create_if_missing = true;
leveldb::Status status = leveldb::DB::Open(options, "/tmp/testdb", &db);

WCDB:

WCTDatabase *database = [[WCTDatabase alloc] initWithPath:@"/tmp/testdb"];
[database createTableAndIndexesOfName:@"table_name" withClass:YourClass.class];

Key Differences

  • WCDB is specifically designed for mobile platforms (iOS and Android), while LevelDB is more general-purpose
  • WCDB provides ORM capabilities and supports complex SQL queries, whereas LevelDB is a simpler key-value store
  • WCDB offers built-in encryption and multi-threaded operations, features not natively available in LevelDB
  • LevelDB has a simpler API and is easier to integrate into projects that don't require complex database operations
  • WCDB is based on SQLite and extends its functionality, while LevelDB uses its own storage format

FoundationDB - the open source, distributed, transactional key-value store

Pros of FoundationDB

  • Distributed architecture for high scalability and fault tolerance
  • Multi-model database supporting key-value, document, and relational models
  • Strong ACID guarantees with serializable isolation

Cons of FoundationDB

  • Steeper learning curve due to its distributed nature
  • Limited mobile-specific optimizations compared to WCDB
  • Requires more resources for deployment and management

Code Comparison

WCDB (SQLite-based):

WCDB::Database database("path/to/database");
WCDB::Table<Person> table = database.getTable<Person>("person");
table.insert(person);

FoundationDB:

@fdb.transactional
def insert_person(tr, person):
    tr['person/' + person.id] = fdb.tuple.pack((person.name, person.age))

db.run(insert_person, person)

Key Differences

  • WCDB is optimized for mobile platforms, while FoundationDB is designed for distributed systems
  • WCDB uses SQLite as its core, whereas FoundationDB has a custom storage engine
  • FoundationDB offers stronger consistency guarantees in distributed environments
  • WCDB provides better performance for local, mobile-centric use cases

Both databases have their strengths, with WCDB excelling in mobile applications and FoundationDB shining in distributed, scalable environments.

4,766

RocksDB/LevelDB inspired key-value database in Go

Pros of Pebble

  • Designed for high-performance distributed databases, optimized for CockroachDB
  • Written in Go, offering better cross-platform compatibility
  • Actively maintained with frequent updates and improvements

Cons of Pebble

  • Less focused on mobile platforms compared to WCDB
  • May have a steeper learning curve for developers not familiar with Go
  • Lacks some specific optimizations for SQLite that WCDB provides

Code Comparison

WCDB (C++):

WCDB::Database database("path/to/database");
WCDB::Table table = database[@"tableName"];
auto objects = table.getObjects<MyObject>(where("key" == "value"));

Pebble (Go):

db, _ := pebble.Open("path/to/database", &pebble.Options{})
defer db.Close()
value, closer, _ := db.Get([]byte("key"))
defer closer.Close()

Key Differences

  • WCDB is primarily designed for mobile platforms, while Pebble targets distributed systems
  • WCDB offers tighter integration with SQLite, whereas Pebble is a standalone key-value store
  • WCDB provides an ORM-like interface, while Pebble offers a lower-level key-value API
  • Pebble is written in Go, making it more suitable for server-side applications, while WCDB (C++) is optimized for mobile devices

Core database component for the Realm Mobile Database SDKs

Pros of realm-core

  • Cross-platform support with native implementations for multiple languages
  • Advanced features like real-time synchronization and offline-first capabilities
  • Extensive documentation and active community support

Cons of realm-core

  • Steeper learning curve due to its unique object-oriented data model
  • Larger file size and memory footprint compared to some lightweight alternatives

Code Comparison

realm-core:

auto realm = Realm::get_shared_realm(config);
auto table = realm->read_group().get_table("Person");
auto obj = table->create_object_with_primary_key("Alice");
obj.set("age", 30);

wcdb:

WCDB::Database database("path/to/database");
WCDB::Table<Person> table(database);
Person person;
person.name = "Alice";
person.age = 30;
table.insert(person);

Key Differences

  • realm-core uses a unique object-oriented data model, while wcdb follows a more traditional SQL-like approach
  • realm-core offers built-in synchronization features, whereas wcdb focuses on local database operations
  • wcdb is optimized for mobile platforms, particularly iOS and Android, while realm-core targets a broader range of platforms

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

WCDB

PRs Welcome Release Version LanguagePlatform

中文版本请参看这里

WCDB is an efficient, complete, easy-to-use mobile database framework used in the WeChat application. It's based on SQLite and SQLCipher, and supports five languages: C++, Java, Kotlin, Swift and Objective-C.

Feature

Easy-to-use

  • ORM (Object Relational Mapping): WCDB provides a flexible, easy-to-use ORM for creating tables, indices and constraints, as well as CRUD through C++/Java/Kotlin/Swift/Objc objects.
  • WINQ (WCDB language integrated query): WINQ is a native data querying capability which frees developers from writing glue code to concatenate SQL query strings.

With ORM and WINQ, you can insert, update, query and delete objects from database in one line code:

// C++
database.insertObjects<Sample>(Sample(1, "text"), myTable);
database.updateRow("text2", WCDB_FIELD(Sample::content), myTable, WCDB_FIELD(Sample::id) == 1);
auto objects = database.getAllObjects<Sample>(myTable, WCDB_FIELD(Sample::id) > 0);
database.deleteObjects(myTable, WCDB_FIELD(Sample::id) == 1);
// Java
database.insertObject(new Sample(1, "text"), DBSample.allFields(), myTable);
database.updateValue("text2", DBSample.content, myTable, DBSample.id.eq(1));
List<Sample> objects = database.getAllObjects(DBSample.allFields(), myTable, DBSample.id.gt(0));
database.deleteObjects(myTable, DBSample.id.eq(1));
// Kotlin
database.insertObject<Sample>(Sample(1, "text"), DBSample.allFields(), myTable)
database.updateValue("text2", DBSample.content, myTable, DBSample.id.eq(1))
val objects = database.getAllObjects<Sample>(DBSample.allFields(), myTable, DBSample.id.gt(0))
database.deleteObjects(myTable, DBSample.id.eq(1))
// Swift
try database.insert(Sample(id:1, content:"text"), intoTable: myTable)
try database.update(table: myTable,
                    on: Sample.Properties.content,
                    with: "text2"
                    where:Sample.Properties.id == 1)
let objects: [Sample] = try database.getObjects(fromTable: myTable,
                                                where: Sample.Properties.id > 0)
try database.delete(fromTable: myTable where: Sample.Properties.id == 1)
// Objc
[database insertObject:sample intoTable:myTable];
[database updateTable:myTable
          setProperty:Sample.content
              toValue:@"text2"
                where:Sample.id == 1];
NSArray* objects = [database getObjectsOfClass:Sample.class
                                     fromTable:myTable
                                         where:Sample.id > 0];
[database deleteFromTable:myTable where:Sample.id == 1];

Efficient

Through the framework layer and sqlcipher source optimization, WCDB have more efficient performance.

  • Multi-threaded concurrency: WCDB supports concurrent read-read and read-write access via connection pooling.
  • Deeply optimized: WCDB has deeply optimized the source code and configuration of SQLite to adapt to the development scenarios of mobile terminals. At the same time, WCDB has also been optimized for common time-consuming scenarios, such as writing data in batches.

Complete

WCDB summarizes common problems in practice to provide a more complete development experience for database development:

  • Encryption Support: WCDB supports database encryption via SQLCipher.
  • Corruption recovery: WCDB provides a built-in repair kit for database corruption recovery.
  • Anti-injection: WCDB provides a built-in protection from SQL injection.
  • Database model upgrade: The database model is bound to the class definition, so that the addition, deletion and modification of database fields are consistent with the definition of class variables.
  • Full-text search: WCDB provides an easy-to-use full-text search interface and includes tokenizers for multiple languages.
  • Data Migration: WCDB supports to migrate data from one databasse to another with simple configuration. And developers don't need to care about the intermediate status and progress of the migration.
  • Data Compression: WCDB supports to compress content via Zstd within specific fields of a database table through a simple configuration. Once configured, the details of data compression and decompression become transparent to developers, and WCDB can automatically compress existing data.

Compatibility

WCDB has interfaces in three languages: C++, Java, Kotlin, Swift, and Objc. Interfaces in different languages share the same underlying logic. The code structure of WCDB is shown in the figure below:

Under such architecture, WCDB in different languages can have the same interface structure and interface capabilities. In one project, you can write database code in different languages with one WCDB. Database logic in different languages will not conflict. Some global interfaces such as error monitoring can work on database logic in different languages at the same time.

Build and Install

Following wikies contain the detailed instructions about building and installing of WCDB.

Tutorials

Tutorials of different languages can be found below:

Contributing

If you are interested in contributing, check out the [CONTRIBUTING.md], also join our Tencent OpenSource Plan.

信息公示